//////return语句for循环
char* duplicate(char* string, int count)
{
char* duped = (char*) malloc(sizeof(char)*(count*strlength(string)+1));
int i=0,j=0,t=0;
for(i=0; i<count*strlength(string); i++,j++)
{
if (j==(strlength(string)))
{
j=0;
t++;
}
if (t==count)
{
duped[i] = '\0';
break;
}
duped[i] = string[j];
}
return duped;
}
上面的代码完美地工作,但下面的人给分段错误。他们有什么区别?看到回报时不应该停止功能吗?
char* duplicate(char* string, int count)
{
char* duped = (char*) malloc(sizeof(char)*(count*strlength(string)+1));
int i=0,j=0,t=0;
for(i=0; i<count*strlength(string); i++,j++)
{
if (j==(strlength(string)))
{
j=0;
t++;
}
if (t==count)
{
duped[i] = '\0';
return duped;
}
duped[i] = string[j];
}
}
[请参阅此讨论关于为什么不在'C'中投射'malloc()'和家族的返回值。](http://stackoverflow.com/q/605845/2173917)。 –
请修复缩进,希望你的一半问题得到排序,如果不是更多。\ –
什么是'strlength()'?你为什么使用它而不是标准的'strlen()'? –