我正在C中编写一个小函数,它接收一个char *并通过“慢动作”打印它,这意味着在一定时间之后每个char,从而使它看起来像一个打字动画。
我的代码是:
void funnyprint(char* string)
{
int i=0;
int len=strlen(string);
if(len==0)
return;
int k=0;
char temp[1];
temp[0]=string[k];
for(i=0; i<7142800*len; i++)
{
fflush(stdout);
if((i!=0) && (i%7142800==0))
{
printf(temp);
k++;
if(k<len)
temp[0]=string[k];
}
}
}
现在,问题是它不会打印字符串,而是部分地给我的char *而不是部分的乱码。
我发现问题在于内存,所以我尝试将“string”复制到一个名为“new”的新char *。 我得到了那段代码:
void funnyprint(char* string)
{
int i=0;
int len=strlen(string);
if(len==0)
return;
int k=0;
char temp[1];
char * new=malloc(len*sizeof(char));
strncpy(new,string,len);
temp[0]=new[k];
for(i=0; i<7142800*len; i++)
{
fflush(stdout);
if((i!=0) && (i%7142800==0))
{
printf(temp);
k++;
if(k<len)
temp[0]=new[k];
}
}
}
但结果并没有改变。我觉得我在这里错过了一个小问题,如果有人可以开导我会很高兴。
谢谢!
答案 0 :(得分:2)
printf(temp);
你的临时数组不是以null结尾的,因此是奇怪的(也就是未定义的)行为。我不认为这里需要一个char数组。它应该是一个单一的字符。
char temp = string[k];
然后再
printf("%c", temp);
答案 1 :(得分:1)
我也会关注整数,如果i
是一个32位的有符号整数,那么在大约300个字符后你会溢出它。作为计数器的无符号(32位)int会将其推回600,但我建议使用sleep(),nanosleep()或类似函数,具体取决于您所使用的平台/操作系统。 / p>