c语⾔中,关于延迟函数的理解
对于延迟,有些c基础的⼈都能够做到⽤for或while来实现
例如:
#include <stdio.h>
int main()
{
int i, j, k;
for (i = 1; i < 1000; i++)
{
for (j = 1; j < 1000; j++)
{
for (k = 1; k < 1000; k++)
{
}
}
}
printf("hello\n");
return0;
}
但是⽤for或while来实现延迟,对于延迟的时间不好把握,也⽐较low。
在这主要想和⼤家分享的是Linux下c语⾔中的延迟函数sleep()的⽤法。
-例如:
#include <stdio.h>
int main()
{
printf("hello\n");
sleep(1); //延迟1秒
printf("world\n");
return0;
}
after 1s:
windows下 sleep(1000) 代表延迟1秒,因为sleep的参数为毫秒,
⽽在Linux下 sleep的参数为秒,所以延迟1秒为 sleep(1)。
请⼤家看以下程序
#include <stdio.h>
int main()
{
printf("hello"); /*去掉转义字符'\n'*/
sleep(1);
printf("world");
return0;
linux下的sleep函数}
after 1s:
⼤家会发现去掉转义字符‘\n’,不再执⾏任何转义操作后,延迟函数sleep不再在语句间延迟,⽽是变成延迟整个程序。 那么如何解决这⼀问题呢?
这就需要借助另⼀个函数fflush( )
#include <stdio.h>
int main()
{
printf("hello");
fflush(stdout); //强制刷新缓存,输出显⽰
sleep(10);
printf("world");
return0;
}
after 1s:
对于fflush( )函数这⾥就不多说了,这⾥主要想和⼤家分享的是关于Linux下c 中sleep( )函数的使⽤。
以上就是我对它的简单理解,希望可以帮到有需要的⼈。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论