以下代码为什么会报错,以及如何正确删除ch,释放内存。
char *ch = new char(100); char tmp[10] = "e100"; strtod(tmp, &ch); cout << *ch << endl; delete ch; system("pause");
以下代码为什么会报错,以及如何正确删除ch,释放内存。
char *ch = new char(100); char tmp[10] = "e100"; strtod(tmp, &ch); cout << *ch << endl; delete ch; system("pause");
这里是strtod函数用法有误吧——说ch没有初始化也行
请查看strtod用法:
http://baike.baidu.com/view/1876981.h...
ch没有初始化的化,其内容是不确定的,strtod极有可能遇不上字符串结束符号(“NULL”)
另外,最后一句 delete[] ch 更好。
2 回答1.7k 阅读✓ 已解决
2 回答1k 阅读✓ 已解决
1 回答1.6k 阅读✓ 已解决
1 回答1.1k 阅读✓ 已解决
1 回答933 阅读
1 回答1.1k 阅读
2 回答1.1k 阅读
你写错了,应该是new char[100],同时删除语句应该是delete[] ch,new char(100)的意思是构造一个char并且初始化值为100。