malloc函数返回的居然是 常量指针!!!!!!!!

后知后觉,今天才发现原来malloc返回的地址的性质是“常量指针”

1.首先来看看平时的使用,一般如下

int main()
{
        char *  p = (char *)malloc(sizeof(char) * 2);
	p[0] = 'A';
	p[1] = 'B';
	printf("%c %c\n", p[0], p[1]);

	return 0;
}

malloc申请了两字节空间,我们对其分别赋值后输出,程序正常,结果如下:

A B
请按任意键继续. . .

2.上面使用[]对其内存进行写操作,接下来我们通过指针的自增试试同样的写操作,代码如下:

int main()
{
	char * p = (char *)malloc(sizeof(char) * 2);
	*p = 'A';
	p++;
	*p = 'B';
	printf("%c %c\n", p[0], p[1]);

	return 0;
}

笔者开始以为其结果和上面一样,然而并不是:

B ?
请按任意键继续. . .

从结果可以看处,p++并没有被执行,语句“*p = 'B'”覆盖了“*p = 'A'”所以在输出中仅有第一个字节是B,第二个字节?.

而这也符合常量指针的性质:指针不允许自增、自减等操作.所以笔者才有此推断.

3.为了更有效的证明,笔者接下来直接显示的将p定义为常量指针:

int main()
{
	char * const p = (char *)malloc(sizeof(char) * 2);
	*p = 'A';
	p++;
	*p = 'B';
	printf("%c %c\n", p[0], p[1]);

	return 0;
}

编译时直接在p++处报错了:

严重性	代码	说明	项目	文件	行
错误	C3892	“p”: 不能给常量赋值	c_test	d:\c及c++编程练习\c相关\程序员面试笔记c语言深度解析例子\c_test\c_test\main.cpp	40

结论:只能说malloc返回带有“常量"的性质,不过从表面上看是非显性的。

4.这也是为什么在一些地方需要辅助指针了,譬如上述代码一定要求通过指针进行操作的话,可以改为如下形式:

int main()
{
	char * const p = (char *)malloc(sizeof(char) * 2);
	char * q = p;
	*q = 'A';
	q++;
	*q = 'B';
	printf("%c %c\n", p[0], p[1]);

	return 0;
}

其输出结果和1中相同,通过局部指针q间接的修改了p的内容。

你可能感兴趣的:(C/C++)