Copy of const char * using std::string constructor(使用 std::string 构造函数复制 const char *)
问题描述
这段代码可以吗?
void SomeClass :: foo(const char * _name) {
//name is of type const char *
name = std::string(_name).c_str();
}
看起来它正在工作,但我不确定它是否正常
it looks like it is working, but iam not sure if it is ok
我应该做一个老式的 strcpy 吗?
should i do an old school strcpy ?
推荐答案
没关系,因为它可以编译并且不会导致未定义的行为.
It's ok since it compiles and doesn't cause undefined behavior.
不没问题,因为 name 在语句执行完成后指向无效内存.
It's not ok since name points to an invalid memory after the statement completes execution.
name = std::string(_name).c_str();
在这个语句的最后,临时的 std::string 被销毁,它释放了 c_str() 的内存.
At the end of this statement the temporary std::string is destroyed and it frees the memory of c_str().
我应该做一个老式的 strcpy 吗?
should i do an old school strcpy ?
不,只需将名称更改为 std::string:
No, just change name to be std::string:
void SomeClass :: foo(const char * _name) {
//name is of type std::string
name = _name;
}
这篇关于使用 std::string 构造函数复制 const char *的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:使用 std::string 构造函数复制 const char *


- C++ 协变模板 2021-01-01
- Stroustrup 的 Simple_window.h 2022-01-01
- 如何对自定义类的向量使用std::find()? 2022-11-07
- 静态初始化顺序失败 2022-01-01
- 与 int by int 相比,为什么执行 float by float 矩阵乘法更快? 2021-01-01
- STL 中有 dereference_iterator 吗? 2022-01-01
- 近似搜索的工作原理 2021-01-01
- 一起使用 MPI 和 OpenCV 时出现分段错误 2022-01-01
- 使用/clr 时出现 LNK2022 错误 2022-01-01
- 从python回调到c++的选项 2022-11-16