char *p=(char*)malloc(sizeof(char)*(strlen(a)+1));//你也可以用数组,但是数组不能返回
char*p=(char*)malloc(sizeof(char)*(strlen(a)+1));//你也可以用数组,但是数组不能返回inti;for(i=strlen(...
char *p=(char*)malloc(sizeof(char)*(strlen(a)+1));//你也可以用数组,但是数组不能返回
int i;
for(i=strlen(a)-1;i>0;i--)
*(p++)=*(a+i);
*p='\0';//p已经往后移了,你原来的写法*(p+strlen(a))='\0';是错误的
puts(p);
return p;//这里不适合返回,因为str是在这个函数里面malloc的,其实应该在这里free掉
为什么我这里直接用p开辟空间就不行了呢? 展开
int i;
for(i=strlen(a)-1;i>0;i--)
*(p++)=*(a+i);
*p='\0';//p已经往后移了,你原来的写法*(p+strlen(a))='\0';是错误的
puts(p);
return p;//这里不适合返回,因为str是在这个函数里面malloc的,其实应该在这里free掉
为什么我这里直接用p开辟空间就不行了呢? 展开
4个回答
展开全部
char* str = (char*)malloc(sizeof(char*) * (strlen(a)+1));
char* p = str;
for(int i = strlen(a)-1; i>=0; i--)
*(p++) = *(a+i);
*p = '\0'; //这时候p这个指针已经指向刚才分配的那块内存的最后一个字节了。如果再puts(p) 只会输出'\0';free(p)会出问题;
puts(str);
return str;
char* p = str;
for(int i = strlen(a)-1; i>=0; i--)
*(p++) = *(a+i);
*p = '\0'; //这时候p这个指针已经指向刚才分配的那块内存的最后一个字节了。如果再puts(p) 只会输出'\0';free(p)会出问题;
puts(str);
return str;
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不大清楚你想问啥,但是你return p; p都被你移到最后了,p指向'\0'了都,所以建议你如果最后要返回这个字符串的话,最好
char *des=(char*)malloc(sizeof(char)*(strlen(a)+1));
char *p =des;
最后return str;别忘记free就行。
char *des=(char*)malloc(sizeof(char)*(strlen(a)+1));
char *p =des;
最后return str;别忘记free就行。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你的问题是啥啊?感觉后面的注释就是答案似的
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询