目录
一、进度条小程序
1.缓冲区
2.进度条程序实现
(1)文件创建
(2)完善makefile文件
(3)头文件proc.h完善
(4)测试文件testproc.c完善
(5)函数定义文件proc.c文件完善
在接触linux中虽然我们也写过部分小程序,但基本仅仅只是打印,没有接触到与系统相关的程序。为了加深认识,在这里我们就写一个进度条小程序展示代码与系统的关联。
在写进度条小程序时,我们要先了解几个系统相关概念
在系统中存在着缓冲区。缓冲区现在我们还无法很好的理解,现在只用了解缓冲区是存放输出的数据的地方即可。我们要打印的数据都会先放到缓冲区里面,当遇到“\n”的时候则会立即将对应内容打印到屏幕上,否则则需要等待缓冲区刷新。
我们可以写以下两个程序来对比:
第一个程序的光标会先闪烁2s,再显示打印内容;第二个程序则会先打印内容,然后光标闪烁2s后结束。sleep(2)会让系统“睡眠”2s后才继续执行代码。
这其实就是因为第一个程序没有“\n”,打印内容需要等待缓冲区刷新。而第二个程序则带有“\n”,会立即刷新缓冲区。
如果想不加“\n”的情况下刷新缓冲区,就需要在对应的位置加上fflush(stdout)这个函数就是用来刷新缓冲区的。
有了这些知识,我们就可以写一个非常简单的倒计时程序:
#include
int main()
{
int i = 10;
while(i > 0)
{
printf("%-2d\r",i--);
fflush(stdout);
sleep(1);
}
return 0;
}
这个程序就会在原地每隔1s打印一个数字。“\r”是返回该行开头
该程序非常简单,因此代码量很小。主要看的不是其功能实现,而是实现该功能时与系统之间的交互
此次的进度条程序我们采用多文件的形式来写。即头文件proc.h、函数定义文件proc.h和测试函数文件testproc.c三个文件。最后再将自动化编辑工具makefile文件创建好:
现在我们在makefile文件里面将需要的指令写好:
myproc:testproc.c proc.c
gcc testproc.c proc.c -o myproc
.PHONY:clean
clean:
rm -f myproc
注意,此处的依赖关系中无需包含头文件,因为此时头文件就在当前目录中,系统可以自己找到。
#pragma once
#include
#include
#include
#define NUM 101//进度条内的数据个数
#define ST_NUM 4//四种进度条风格选择
#define N 3选择第三种进度条风格
void myproc();
#include"proc.h"
int main()
{
myproc();
return 0;
}
#include "proc.h"
void myproc()
{
int cnt = 0;//进度条数字,到100结束
char bar[NUM];//进度条显示样式
char style[ST_NUM] = {'-', '.', '#', '>'};//进度条可选样式
memset(bar, '\0', sizeof(bar));//将bar里面的空间全清理为\0
char* lable = "-/|\\";//类似沙漏的显示进度条正常运行的标志
while(cnt <= 100)
{
printf("[%-100s][%d%%][%c]\r", bar, cnt, lable[cnt%4]);//进度条打印
fflush(stdout);//刷新缓冲区
bar[cnt++] = style[N];//更新bar内的数据
usleep(30000);//3s完成进度条显示
}
printf("\n");
}
通过上述的程序,我们就可以打印出如下如所示的进度条:
这里面所用到的usleep()函数是以微秒为单位使系统休眠