vector::data()是C++11引入的标准方法,返回底层数组首元素指针,空vector时安全返回nullptr;而&vec[0]在空时触发未定义行为,存在崩溃风险。
vector::data() 返回指向底层连续存储数组首元素的指针(T*),是 C++11 引入的标准方式。它和 &vec[0] 表面效果相似,但关键区别在

vec 为空时,&vec[0] 是未定义行为(UB),而 vec.data() 明确定义为返回 nullptr(C++11 起)。很多旧代码用 &vec[0] 混过去,但一旦遇到空 vector,就可能崩溃或静默出错。
&vec[0],否则触发 UBvec.data() 在空 vector 下返回 nullptr,可直接判空,更健壮&vec[0] 空容器做运行时检查并中止vector::data() 是 C++11 标准特性,在所有符合 C++11 及以上标准的编译器中可用。但要注意实际项目中的隐含限制:
data() 对 const vector 返回 const T*,且保证 noexcept,C++11/14 中未强制要求 noexcept,但主流实现都满足data(),只能用 &vec[0] + 显式判空(且接受 UB 风险)或封装安全 wrapper如果不能依赖 C++11,或需要在模板中统一处理空/非空情况,可写一个内联 helper:
templateT* safe_data(std::vector & v) { return v.empty() ? nullptr : v.data(); } // 或 C++11 前: template T* safe_data(std::vector & v) { return v.size() ? &v[0] : nullptr; }
v[0],但加了 size 判定,避免 UB —— 因为 v.size() == 0 时不会执行 &v[0]
v.size() && &v[0],这是短路求值陷阱:&v[0] 仍会在左操作数为 true 时求值,UB 不可避std::data(v)(C++17 起的 ADL 友好泛型函数)把 vec.data() 传给 C 函数(如 memcpy、glBufferData)很常见,但容易忽略长度与生命周期匹配:
vec.data() 本身不携带长度信息,必须额外传 vec.size() * sizeof(T),别漏乘 sizeof
vector::data() 不能移交,因为 vector 仍管理该内存;此时应改用 std::unique_ptr 或手动 new 数组C++11 起,data() 是唯一既安全又标准的取底层数组指针方式;空容器、迭代器失效、跨平台 ABI 这些坑,都藏在看似简单的指针背后。