昨天跟同学一起看一个C++编译错误。
代码是这样的(简化后):
int main()
{
char* buff = new char[6];
strcpy(buff, "123456");
delete[] buff;
}
程序在Debug模式下运行出错,提示非法访问内存。Release没事。
我把代码改成这样:
int main()
{
char* buff = new char[6];
for (int i=0; i<6; i++)
{
buff[i] = i + 48; // 数字转化成对应的字符
}
delete[] buff;
}
程序运行正常。。。
就是说在strcpy里除了附值外他肯定还干了什么。于是想到字符串结尾"/0",他肯定是在后面自动加一个0然后内存溢出边界了。
原来的改成:
int main()
{
char* buff = new char[7];
strcpy(buff, "123456");
delete[] buff;
}
OK,一切正常了!
希望明天是个艳阳天。。。
代码是这样的(简化后):
int main()
{
char* buff = new char[6];
strcpy(buff, "123456");
delete[] buff;
}
程序在Debug模式下运行出错,提示非法访问内存。Release没事。
我把代码改成这样:
int main()
{
char* buff = new char[6];
for (int i=0; i<6; i++)
{
buff[i] = i + 48; // 数字转化成对应的字符
}
delete[] buff;
}
程序运行正常。。。
就是说在strcpy里除了附值外他肯定还干了什么。于是想到字符串结尾"/0",他肯定是在后面自动加一个0然后内存溢出边界了。
原来的改成:
int main()
{
char* buff = new char[7];
strcpy(buff, "123456");
delete[] buff;
}
OK,一切正常了!
希望明天是个艳阳天。。。