有一个 4 字母字母序列的模板类(=> 每个字母 2 位):
template <size_t _size>
class Seq {
private:
const static size_t _byteslen = (_size / 4) + (_size % 4 != 0);
char _bytes[_byteslen];
public:
Seq() {};
Seq(const char* s);
Seq(const Seq<_size> &seq);
...
std::string str() const;
...
}
如果复制构造函数被实现为愚蠢的“从到字符串”,那么一切正常。
Seq(const Seq<_size> &seq) {
Seq(seq.str().c_str());
}
否则,如果复制构造函数像这样使用 memcpy:
Seq(const Seq<_size> &seq) {
memcpy(_bytes, seq._bytes, _byteslen);
}
程序在几秒钟后出现段错误(使用完全不同的 std::string 执行 += 或 [] 操作)。这样的 memcpy 会出现什么问题?谢谢。
附注memmove 没有帮助。
最佳答案
“如果复制构造函数被实现为愚蠢的从到字符串,那么一切都会正常。”
Seq(const Seq<_size> &seq) {
Seq(seq.str().c_str());
}
真的吗?因为该构造函数根本不初始化_bytes[]
。 (相反,它创建了一个不同的临时 Seq
对象,该对象未使用并立即销毁。)
关于c++ - 复制构造函数中类级数组的 memcpy 会导致段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5124140/