简单的进度条程序 ------行缓冲区概念,/r与/n的区别

先来了解以下:
/r 与 /n 的区别:
’\r’是回车,前者使光标到行首,(carriage return)
'\n’是换行,后者使光标下移一格,(line feed)

\r 是回车,return
\n 是换行,newline

行缓冲区概念
行缓冲:在I/O操作时,输入输出遇到换行符时进行,进行真正的I/O操作。对于行缓冲,标准I/O每一行缓冲区的长度是固定的,所以只要填满了缓冲区,即使没有遇到换行符,也换刷新缓冲区。
当然除了换行,我们也可以进行手动刷新缓冲区:这里用到的C语言提供的 fflush 功能。
看下面的代码:
在liunx环境下:

#include <stdio.h>
#include<unistd.h>
int main()
 {    
 printf("hello world!\n");   
  sleep(3);    
  return 0; 
  }

什么现象?
先打印出 hello world!后睡眠三秒,程序退出

#include <stdio.h>
#include<unistd.h>
int main()
 {    
 printf("hello world!");   //去掉换行符
  sleep(3);    
  return 0; 
  }

什么现象?
先睡眠三秒,后打印出 hello world!,程序退出。
造成这两个现象的原因就是:这里的换行符刷新了缓冲区。
使用fflush手动刷新缓冲区:

#include <stdio.h>
#include<unistd.h>
int main()
 {    
 printf("hello world!");   //去掉换行符
 fflush(stdout);			//刷新输出缓冲区
  sleep(3);    
  return 0; 
  }

结果与使用换行符相同。
好了 ,内容很简单,看了是上面,我们再来看看一个简单的进度条的代码:

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

运行结果:
在这里插入图片描述

发布了70 篇原创文章 · 获赞 12 · 访问量 9769

猜你喜欢

转载自blog.csdn.net/lovehang99/article/details/102688110