简单进度条的实现

首先让我们先来看进度条实现的代码:

#include 
#include 
#include 
int main()
{
  char bar[102];
  memset(bar,0,102*sizeof(char));
  char s[]="|/-\\";
  bar[0]='\0';
  int i=0;
  while(i<=100)
{
   printf("[%-101s][%d%%][%c]\r",bar,i,s[i%4]);
   fflush(stdout);
   bar[i]='#';
   i++;
   bar[i]=0;
   usleep(100000);  
} 
printf("\n");
return 0;
}

其中用了一个函数usleep,在gcc编译器中,它包含在头文件unistd.h中,其单位为微秒,Sleep单位为毫秒,sleep单位为秒。
‘\r’表示回车,表示输出一行后,又回到当前行的起始位置。
在linux写的运行结果为:
这里写图片描述
这里用到了fflush,来清空缓冲区,由此说明一下缓冲机制的问题,
1:什么是缓冲机制
为了提高文件系统性能,内核利用一部分物理内存分配出缓冲区,用于缓存系统操作和数据文件,当内核收到读写的请求时,内核先去缓存区找是否有请求的数据,有就直接返回,如果没有则通过驱动程序直接操作磁盘。
2:缓存机制优点
减少系统调用次数,降低CPU上下文切换和磁盘访问频率。
看下边两段代码:
简单进度条的实现_第1张图片
这两段代码的运行结果为:
简单进度条的实现_第2张图片
第一段程序先执行了printf函数,而后停了3秒,第二个程序先停顿了3秒再输出了printf函数的内容,原因是printf函数将输出的内容写入到缓冲区中,加入换行符时,它具有清空缓冲区的作用,将缓冲区中的内容显示在标准输出中,而不加入换行符时,只有当return时才会将缓冲区中的内容显示到屏幕上。

你可能感兴趣的:(linux)