Unix编程实践教程笔记(一)系统编程概述,实现more命令

概述

基础知识:

内存空间用来存放程序和数据

又分为系统空间:容纳操作系统的内存空间

用户空间:容纳应用程序的内存空间

操作系统:又叫内核

程序想要访问设备必须通过内核,因为只有内核才能直接管理设备

系统资源

1.处理器:执行指令(程序由指令构成)

2.输入输出(I/O):程序的所有输入输出都必须流经内核(保证正确性,有效性,安全性)

3.进程管理:进程指一次程序的运行,每个进程都有自己的资源,内核进程服务:(创建,中止,调度)

4.内存:内核需要进性内存管理,程序必须装载到内存才可以运行

5.设备:内核可以屏蔽各个设备操作方式的差异

6.计时器 7.进程间通信 8.网络

more命令作用

more的基础作用:
分页显示文件内容,底部用白字显示百分比,按空格显示下一页,q退出,h帮助,回车下一行

image

image

用法:more filename

command | more 将命令的输出分页显示

more < filename 从标准输入获取内容,(此时标准输入被重定向到filename文件)

root@ziggy-virtual-machine:~# ls -l | more
root@ziggy-virtual-machine:~# more < High_Linux_server/chapter9/lt_et.cpp

查看多个文件:

image

more命令的实现:

//注释完全
#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>

#define PAGELEN 24
#define LINELEN 512
//一次读入512字节

int see_more(FILE* cmd)
{
    int c;
    printf("\033[7m more? \033[m");
    while((c=getc(cmd))!=EOF)
    {
        if(c=='q')
        {
            return 0;
        }
        if(c==' ')
        {
            return PAGELEN;//再看PAGELEN行
        }
        if(c=='\n')
        {
            return 1;//再看一行
        }
    }
    return 0;
}

void do_more(FILE* fp)
{
    char line[LINELEN];
    int nums_of_lines = 0;//用于记录每次输出的行数
    int reply;//存储see_more的返回值(用于区分用户的输入(q,空格,等))
    FILE* fp_tty;//程序的标准输入被重定向时,可以读取/dev/tty文件获取用户输入
    fp_tty = fopen("/dev/tty","r");
    if(fp_tty==NULL)
    {
        exit(1);
    }
    while(fgets(line,LINELEN,fp))//从文件获取输入
    {
        if(nums_of_lines==PAGELEN)//如果已经输出每次要输出的最大行数
        {
            //获取用户输入
            reply = see_more(fp_tty);
            if(reply==0)
            {
                break;//如果用户输入为q,则跳出循环退出程序
            }
            nums_of_lines-=reply;//减去reply,这样就能在再多走reply遍循环,再去判断是否等于PAGELEN

        }
        if(fputs(line,stdout)==EOF)
        {
            exit(1);
        }
        nums_of_lines++;
    }

}


int main(int argc,char *argv[])
{
//     VT100 
// 一个终端类型定义,VT100控制码 用来在终端扩展显示的代码。比如果终端上任意坐标用 不同的颜色显示字符。

//   所有的控制符  \033打头 (即ESC 的ASCII码)用输出字符语句来输出。可以在命令行用echo 命 令,或者在C程序中用printf 来输出VT100 的控制字符。

// 具体格式有两种:

//          1)数字形式:\033[<数字>m .

//                如: \033[30m ,表示让后面字符输出用前景黑色输出

//                        \033[0m表示取消前面的设置。

    FILE* fp;
    if(argc==1)
    {
        do_more(stdin);//如果没有文件作为参数,则使用标准输入文件
    }
    else{
        while(--argc)
        {
            if((fp=fopen(*++argv,"r")))//如果more后有文件参数
            {
                do_more(fp);
                fclose(fp);
            }
            else{
                exit(1);
            }
        }
    }

    return 0;
}
//在more的显式上还可以改进,距离真正的more,还可以加入百分比的显示

测试功能:

image

关于输入重定向的问题

以上的代码涉及输入的重定向

ls /bin | more_2

上述命令将程序的标准输入重定向到ls的标准输出

而我们在打印固定的行数之后,需要用户从键盘的输入来判断下一步操作

此时标准输入被占用

上面程序的解决方法:Unix/Linux中有一个文件:/dev/tty

是显示器和键盘的设备描述文件,读此文件相当于从键盘获取用户输入,即使程序的输入输出被<,>重定向,我们还是可以读取这个文件来与终端交换数据

如此一来,我们需要用户输入时,就直接从/dev/tty获取数据

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值