c++指针指向的内存问题
本文介绍了c++指针指向的内存问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
问 题
#include <iostream>
#include <cstring>
#include <string>
using namespace std;
int main()
{
int* str = new int[1];
str[2] = 1;
cout << str[2] << endl;
return 0;
}
为什么这段代码可以正常运行哦?str不是指向的一个大小的内存吗?
解决方案
C的数组标识符,里面并没有包含该数组长度的信息,只包含地址信息,所以语言本身无法检查,只能通过编译器检查,而早期的C语言编译器也不对数组越界进行检查,只能由程序员自己检查确保。以及在早期的CRT函数中也不对字符串指针或数组进行越界检查,都是要求程序员确保空间足够,因此也才也才有了在VS2005之后微软提供的安全的CRT函数版本。即使越界也能正常编译通过,试着扩大一下范围,同时输出地址,可以看出,确实是访问了越界的地址
#include <iostream>
#include <cstring>
#include <string>
using namespace std;
int main()
{
int* str = new int[1];
str[10000] = 1;
cout << str << endl;
cout << &str[10000] << endl;
cout << str[10000] << endl;
return 0;
}
0x100500000
0x100509c40
1
Program ended with exit code: 0
这篇关于c++指针指向的内存问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文