C/C++/CPP中与虚拟存储器(指针)有关错误汇总(一)

一, 指针引用错误。

现代操作系统中普通使用虚拟存储器系统,使得每个进程可以使用的地址空间达到2^N,N为机器的位数,但是实际中并不需要如此大的内存,所以如果间接将引用的指针指向一块没有使用的内存空间中,操作系统会会报出segment error错误。

int val;
scanf("%d" , val);
很明显上面scanf的使用是错误的,正确的做法应该是将val的地址传给scanf,但此却将val的值传给了scanf, scanf会使用向val值使用指向的地址写入数据,此时就出现错误。


二,读取未初始化的存储器

在C/C++中僵尸变量会被初始化成0,但是堆分配的内存却不会被初始化为0, 例如 int * pval =  (int *) malloc(sizeof(int)); 此时pval指向内存值是不确定的。 不过可以使用calloc来申请内存,此时内存会被初始化为0


三,缓冲区溢出

考虑一个接受从标准输入字符串的程序 

	char buff[128];
	gets(buff);
此时如果输出的字符串长度大于127位,就位出现缓冲区溢出,因为gets函数并不检查缓冲区边界。正确的写法是指定缓冲区的长度。
	fgets(buff , sizeof(buff), stdin);
这样只会向buff中写入长度-1个字符。


四,错误假设指针大小(4位)和他们指向的对象大小相同

考虑申请一个int类型的二维数组,代码可以如下

int ** Array = (int **) malloc(N * sizeof(int));
for (int i = 0; i < N; ++i)
{
	Array[i] = (int *)malloc(M * sizeof(int));
}
注意在本例中上面的代码可以正确执行,但是问题在哪呢。仔细分析会发现,其它第一行的代码意图是为了申请一个N个大小的 指针数组, 由于指针的大小和int类型大小一样,帮而该程序可以正确执行,但是正确的写法应该是这样的
int ** Array = (int **) malloc(N * sizeof(int*));

 

五,取值优先级使用错误

int *count = (int *)malloc(sizeof(int));
* count = 1;
*count--;
cout << *count <<endl;
看一下上面代码的输出?我们期望的输出是0,但是由于--的优先级高于*,因此现在的结果变成了*(count--)。

C/C++/CPP中与虚拟存储器(指针)有关错误汇总(二)

你可能感兴趣的:(存储)