看网上很多人谭浩强c语言教材的这个程序有错误,我看不出错误在哪里,请高手告诉我
voidcopy_string(char*from,char*to){for(;*from!='\0';from++,to++)*to=*from;*to='\0';}v...
void copy_string(char *from, char * to)
{
for(;*from!='\0';from++,to++)
*to=*from;
*to='\0';
}
void main()
{
char *a="I am a teacher";
char *b="You are a student.";
printf("\nstring a=%s\nstring b=%s\n",a,b);
copy_string(a,b);
printf("\nstring a=%s\nstring b=%s\n",a,b);
} 展开
{
for(;*from!='\0';from++,to++)
*to=*from;
*to='\0';
}
void main()
{
char *a="I am a teacher";
char *b="You are a student.";
printf("\nstring a=%s\nstring b=%s\n",a,b);
copy_string(a,b);
printf("\nstring a=%s\nstring b=%s\n",a,b);
} 展开
1个回答
展开全部
错的一塌糊涂,烂书一本
void copy_string(char *from, char * to)
//第一句就错,不是一个良好的习惯,应该定义 void copy_string(const char *from, char * to, int nSize),方式from字符串被误修改,防止 to字符串越界访问
{
for(;*from!='\0';from++,to++)
*to=*from;
*to='\0'; //这句应该在循环外,程序逻辑错误,导致最终to是个空串
}
//main函数定义不符合C语言规范,应该定义 int main(void)
void main()
{
char *a="I am a teacher";// 这句应该是 const char *a="I am a teacher";
char *b="You are a student."; //b作为目标缓存,应该开成数组。这种写法b指向的内存应该分配在只读区里。在vc下用32位编译一下吧,对*b的赋值操作必然会导致死机
printf("\nstring a=%s\nstring b=%s\n",a,b);
copy_string(a,b);
printf("\nstring a=%s\nstring b=%s\n",a,b);
}
void copy_string(char *from, char * to)
//第一句就错,不是一个良好的习惯,应该定义 void copy_string(const char *from, char * to, int nSize),方式from字符串被误修改,防止 to字符串越界访问
{
for(;*from!='\0';from++,to++)
*to=*from;
*to='\0'; //这句应该在循环外,程序逻辑错误,导致最终to是个空串
}
//main函数定义不符合C语言规范,应该定义 int main(void)
void main()
{
char *a="I am a teacher";// 这句应该是 const char *a="I am a teacher";
char *b="You are a student."; //b作为目标缓存,应该开成数组。这种写法b指向的内存应该分配在只读区里。在vc下用32位编译一下吧,对*b的赋值操作必然会导致死机
printf("\nstring a=%s\nstring b=%s\n",a,b);
copy_string(a,b);
printf("\nstring a=%s\nstring b=%s\n",a,b);
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询