对于一个32位机器而言,其寻址空间是32位,比如0x0042f3f4,地址是8位16进制数,对于其中任何一位上的一个十六进制数来说需要4个bit来存储,这样就就是4*8=32bit。
在32位机器中VS中存储一个int数据需要4个字节,所以对于一个指向int类型数据的指针来说,指针+1,即指针向后移动一位,对应的指针地址是+4;而对于一个指向char类型的指针来说,指针向后移动一位,对应的指针地址是+1.因为在32位机器中,VS中的char占的空间是1个字节。
const <type> *p 等价于 <type> const *p;
const char *p,意思是const的是*p,即存储的内容不变,*p不能作为左值被改变;
举例:
const char *p = “123456”;
char e ='a';
p = &e;//正确,p可以被改变
char * const p,意思是const的是p,即地址不能变,p不能作为左值被赋值。
举例:
char *const p = “123456”;
char e ='a';
p = &e;//错误,p可以被改变
如果要改变*p的值,请仔细学习如下:
在学习指针的过程中遇到一个简单的问题:
char *str = "resource";
str[6] = 'k'; //本想更改指针的内容,这句报内存写入错误
*(str+6) = 'k'; //这样写同样报错
但是这样就没有问题:
char *str = new char[12];
strcpy(str,"resource");
str[6] = 'k';//没问题
*(str+6) = 'k'; //没问题
这样也没问题:
char str[]="resource";
str[6] = 'k';
*(str+6) = ‘k’;
从网上搜寻资料后,找到了一个比较准确的解答:
“resource”是字符串常量。
对于cahr *str ="resource";
把“resource”的值-也就是字符串常量字面值,也就是“resource”的地址,准确来说是起始地址---赋值给字符指针str,Linux下,“resource”字符串是存放于只读数据段区的。char *str = "resource",就是把“resource”的首地址赋给str,所以str存放的是一个只读数据区的地址,对只读区的数据进行禁止写操作,具体由相应的操作系统进行判断以及处理。
而对于char str[] = "resource";
str[]是一个字符数组,编译器首先在栈中分配一定的连续空间用于存放“resource”中的字符以及结尾符,然后把字符串常量的内容,也就是“resource”中的各个字符和结尾符复制到这个栈中的连续空间中.str是数组名,用来表示这个连续栈空间的起始地址,所以str中存放的是栈地址,这个地址的数据是可写的。