65,209
社区成员
发帖
与我相关
我的任务
分享
#include <iostream>
#include <string>
using namespace std;
int main()
{
string str("IamSpierman");
cout << str << endl;
string substr = str.substr(1);
cout << substr << endl;
const char* result = (str.substr(1)).c_str();
cout <<"\nresult == "<< result << endl;
}
const char * result =new char[substr,size()+1];
strcpy(result,substr.c_str());
cout<< result<<endl;
delete result;
理解和讨论之前请先学会如何观察!
计算机组成原理→DOS命令→汇编语言→C语言(不包括C++)、代码书写规范→数据结构、编译原理、操作系统→计算机网络、数据库原理、正则表达式→其它语言(包括C++)、架构……
对学习编程者的忠告:
多用小脑和手,少用大脑、眼睛和嘴,会更快地学会编程!
眼过千遍不如手过一遍!
书看千行不如手敲一行!
手敲千行不如单步一行!
单步源代码千行不如单步Debug版对应汇编一行!
单步Debug版对应汇编千行不如单步Release版对应汇编一行!
单步类的实例“构造”或“复制”或“作为函数参数”或“作为函数返回值返回”或“参加各种运算”或“退出作用域”的语句对应的汇编代码几步后,就会来到该类的“构造函数”或“复制构造函数”或“运算符重载”或“析构函数”对应的C/C++源代码处。
VC调试时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Turbo C或Borland C用Turbo Debugger调试,Linux或Unix下用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
string substr = str.substr(1);
cout << substr << endl;
const char* result = substr.c_str();
cout <<"\nresult == "<< result << endl;
这个也错了
const char* result = substr.c_str();这行之后 result也不一定有效
这样才正确
cout <<"\nresult == "<< substr.c_str()<< endl;
#include <iostream>
#include <string>
using namespace std;
int main()
{
string str("IamSpierman");
cout << str << endl;
string substr = str.substr(1);
cout << substr << endl;
const char* result = (str.substr(1)).c_str();
/*猜想可能是由于result只是一个指针,没有分配空间,而(str.substr(1))只是一个临时数值,在赋值语句之后就释放掉了。
可以将(str.substr(1)).c_str()改为 substr.c_str()或者是
char result[64] = { 0 };
strcpy(result , str.substr(1).c_str());
*/
cout <<"\nresult == "<< result << endl;
}