变量使用前要先分配空间

来源:互联网 发布:windows 卡在欢迎界面 编辑:程序博客网 时间:2024/06/05 10:02


typedef struct pool_padding_s{    void *head;    void *body;    void *tail;}pool_padding_t;m = malloc(size);========================pool_padding_t *buffer;   //buffer 没有自己的位置、空间buffer->head = m;         //head指针没有自己的独立的空间来存放m! 虽然它是指向了别的物理空间buffer->body = (u_char *)m + PADDING_LENGH; //body指针没有自己的独立的空间来存放数据!buffer->tail = (u_char *)m + size - PADDING_LENGH;  //The same.u_char *pHead, *pTail;pHead = (u_char *)buffer->head;pTail = (u_char *)buffer->tail;for(int j=0; j<PADDING_LENGH; j++){    //padding}========================pool_padding_t buffer; //OK!buffer.head = m;  //OK!buffer.body = (u_char *)m + PADDING_LENGH;  //OK!buffer.tail = (u_char *)m + size - PADDING_LENGH;  //OK!u_char *pHead, *pTail;pHead = (u_char *)buffer.head;pTail = (u_char *)buffer.tail;for(int j=0; j<PADDING_LENGH; j++){    //padding}.



简单的问题:char指针无法赋值

一个简单的问题:

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"是字符串常量。   对于 char *str = "resource";    把"resource"的值----也就是字符串常量字面值,也就是"resource"的地址,准确来说是起始地址----赋给字符指针 str,Linux下,"resource"字符串常量是存放于只读数据区的,一般来说,32位机器上,在Linux中,堆,全局数据,常量等都是存放于从0x8048000开始的内存地址,向上增长。可以打印一下"resource"的地址来进行验证。char *str = "resource",就是把"resource"的首地址赋给str,所以str 存放的是一个只读数据区的地址,对只读区的数据进行写操作是禁止,具体由相应的操作系统进行判断以及处理。   

而对于 char str[] = "resource";    str[]是一个字符数组,编译器首先在栈中分配一定的连续空间用于存放“resource”中的字符以及结尾符,然后把字符串常量的内容,也就是"resource"中的各个字符和结尾符复制到这个栈中的连续空间中。str是数组名,用来表示这个连续栈空间的起始地址,所以str中存放的是栈地址,这个地址的数据是可写的。一般来说,32位机器上,在Linux中,栈地址空间从3G(0xbfffffff)开始向下增长。







0 0
原创粉丝点击