std::vector<T,Allocator>::data
来自 cppreference.com
T* data(); |
(1) | (自 C++11 起为 noexcept) (自 C++20 起为 constexpr) |
const T* data() const; |
(2) | (自 C++11 起为 noexcept) (自 C++20 起为 constexpr) |
返回一个指向作为元素存储的底层数组的指针。该指针使得范围[
data(),
data() +
size())
始终是有效范围,即使容器为空(在这种情况下,data()
不可解引用)。
内容 |
[编辑] 参数
(无)
[编辑] 返回值
指向底层元素存储的指针。对于非空容器,返回的指针与第一个元素的地址相等。
[编辑] 复杂度
常数。
[编辑] 注意
如果size()为0,data()
可能会或可能不会返回空指针。
[编辑] 示例
运行此代码
#include <cstddef> #include <iostream> #include <span> #include <vector> void pointer_func(const int* p, std::size_t size) { std::cout << "data = "; for (std::size_t i = 0; i < size; ++i) std::cout << p[i] << ' '; std::cout << '\n'; } void span_func(std::span<const int> data) // since C++20 { std::cout << "data = "; for (const int e : data) std::cout << e << ' '; std::cout << '\n'; } int main() { std::vector<int> container{1, 2, 3, 4}; // Prefer container.data() over &container[0] pointer_func(container.data(), container.size()); // std::span is a safer alternative to separated pointer/size. span_func({container.data(), container.size()}); }
输出
data = 1 2 3 4 data = 1 2 3 4
缺陷报告
以下行为变更缺陷报告被追溯应用于以前发布的 C++ 标准。
DR | 应用于 | 已发布的行为 | 正确行为 |
---|---|---|---|
LWG 464 | C++98 | vector 没有这个成员函数 |
已添加 |
LWG 1312 | C++98 | 返回类型为 pointer 和 const_pointer |
分别更改为 T* 和 const T* |
[编辑] 另请参阅
访问第一个元素 (公共成员函数) | |
访问最后一个元素 (公共成员函数) | |
返回元素数量 (公共成员函数) | |
访问指定元素 (公共成员函数) | |
(C++20) |
对一组连续对象的非拥有视图 (类模板) |
(C++17) |
获取指向底层数组的指针 (函数模板) |