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可能有什么问题?谢谢。
P.S。 memmove没有帮助。
答案 0 :(得分:5)
“如果复制构造函数实现为从字符串到字符串,那么一切正常。”
Seq(const Seq<_size> &seq) {
Seq(seq.str().c_str());
}
真的?因为该构造函数根本不初始化_bytes[]
。 (相反,它会创建一个不同的临时Seq
对象,该对象未使用并立即销毁。)
答案 1 :(得分:0)
只是一个猜测:你的str()函数返回_bytes作为字符串,试图从一个非空终止的缓冲区构建它。