std::vector<T,Allocator>:: data
|
T
*
data
(
)
;
|
(1) |
(自 C++11 起为 noexcept)
(自 C++20 起为 constexpr) |
|
const
T
*
data
(
)
const
;
|
(2) |
(自 C++11 起为 noexcept)
(自 C++20 起为 constexpr) |
返回指向作为元素存储的底层数组的指针。该指针满足范围
[
data
(
)
,
data
(
)
+
size()
)
始终是
有效范围
如果
*
this
为空,则
data()
不可解引用。
目录 |
返回值
指向底层元素存储的指针。对于非空容器,返回的指针与首元素地址比较结果相等。
复杂度
常量。
注释
如果
*
this
为空,
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}; // 优先使用 container.data() 而非 &container[0] pointer_func(container.data(), container.size()); // std::span 是分离指针/大小参数的安全替代方案 span_func({container.data(), container.size()}); }
输出:
data = 1 2 3 4 data = 1 2 3 4
缺陷报告
以下行为变更缺陷报告被追溯应用于先前发布的C++标准。
| 缺陷报告 | 适用范围 | 发布时行为 | 正确行为 |
|---|---|---|---|
| LWG 464 | C++98 |
vector
没有此成员函数
|
已添加 |
| LWG 1312 | C++98 |
返回类型为
pointer
和
const_pointer
|
分别改为 T * 和 const T * |
参见
|
访问首元素
(公开成员函数) |
|
|
访问末元素
(公开成员函数) |
|
|
返回元素数量
(公开成员函数) |
|
|
访问指定元素
(公开成员函数) |
|
|
(C++20)
|
对连续对象序列的非拥有视图
(类模板) |
|
(C++17)
|
获取底层数组的指针
(函数模板) |