STL Vector:临时调用 data() 时的未定义行为
STL Vector: undefined behaviour when calling data() on a temporary?
有人对这种行为有解释吗?
我的代码:
#include <vector>
#include <iostream>
using namespace std;
class Packet {
private:
vector<unsigned char> data;
public:
vector<unsigned char> getRawBlock() const {
return data;
}
Packet() {
data.push_back('a');
data.push_back('b');
}
};
int main() {
Packet packet;
cout << "vector byte0: " << packet.getRawBlock().at(0) << ", byte1: " << packet.getRawBlock().at(1) << endl;
unsigned char *badBytes = packet.getRawBlock().data();
cout << "bad byte0: " << badBytes[0] << ", byte1: " << badBytes[1] << endl;
vector<unsigned char> copy = packet.getRawBlock();
unsigned char *goodBytes = copy.data();
cout << "good byte0: " << goodBytes[0] << ", byte1: " << goodBytes[1] << endl;
}
我的输出:
vector byte0: a, byte1: b
bad byte0: @, byte1: 0
good byte0: a, byte1: b
问:为什么我的"坏字节"损坏了?我会(天真地)怀疑"badBytes"和"goodBytes"都准确地返回我放入向量的内容。
unsigned char *badBytes = packet.getRawBlock().data();
一旦 getRawBlock()
的临时返回值被销毁,badBytes
就会失效(此处位于语句末尾)。
相反,您可以返回一个const
-reference:
vector<unsigned char> const& getRawBlock() const {
return data;
}
为什么我的"坏字节"损坏了?
因为临时在行尾被破坏,使指针悬空。访问它会产生未定义的行为。
我会(天真地)怀疑"badBytes"和"goodBytes"都准确地返回我放入向量的内容。
它们都返回了一个指向您放入向量的内容的指针。该指针仅在修改或销毁矢量之前有效。
根据类的使用方式,您可能希望返回引用(可能是const
),而不是向量的副本。只要Packet
对象存在,该对象就一直有效。
getRawBlock() 返回一个 r 值,该值在执行此行后立即销毁:
unsigned char *badBytes = packet.getRawBlock().data();
因此,badBytes 指向未分配的数据,当您在下一行中取消引用它时。未定义的行为。
相关文章:
- 编译C++时未定义的引用
- vscode g++链路故障:体系结构x86_64的未定义符号
- 如何修复此错误:未定义对"距离(浮点数,浮点数,浮点数,浮点数,浮点数)"的引用
- 我的项目不会像"undefined reference to `grpc::g_core_codegen_interface'"那样使用未定义的引用错误进行编译
- 不知道某个东西是否被忽略会引入未定义的行为吗
- 对C宏的未定义引用,但在定义它时会出现重新定义错误
- 未定义的引用在哪里
- 编译时的 CImg 库返回对"__imp_SetDIBitsToDevice"的未定义引用
- 对Py_Initialize()的未定义引用
- c++11评估顺序(未定义的行为)
- 使用mysql c++连接器的未定义引用
- 从python调用openMP共享库时,未定义opnMP函数
- 在 Mac 上使用 CMAKE 将 FFTW 和 FFTWPP 链接到项目中时未定义的符号
- Cmake 链接问题:未定义对 Button::mousePressEvent(QGraphicsSceneMouseE
- 未定义的引用 .. 使用 OpenCV 编译 C++ 代码时,从命令行
- 具有外部"c"和程序集的未定义函数
- 此增量后语句是否会导致未定义的行为?
- 使用 std::vector,为什么 &vec[0] 未定义的行为,而 vec.data() 是安全的?
- STL Vector:临时调用 data() 时的未定义行为
- .data.rel.ro+0x8 错误:未定义对"typeinfo for android::MediaSource"的引用