• 2017-2018-1 20155209 《信息安全系统设计基础》第四周学习总结


    2017-2018-1 20155209 《信息安全系统设计基础》第四周学习总结

    补充完成课上没有完成的内容(2分)

    • 用Linux IO相关系统调用编写myod.c 用myod XXX实现Linux下od -tx -tc XXX的功能,注意XXX是文件名,通过命令行传入,不要让用户输入文件名

    • 请教结对伙伴张瑞琦同学得知,在C语言编程用到命令行时,经常遇到main函数中argc和argv[]这两个参数。argc是argument count的缩写,即参数的个数;argv是argument vector的缩写,即参数列表。argv[0]是程序本身的名字,argv[1]是在命令行中输入的第一个程序的参数,argv[argc]是NULL。

    • 在main函数中加入argc和argv[]两个参数,然后使用c语言open函数打开文件,其余操作跟myod基本类似。

    • c语言open函数详解:

    • int open(const char *path, int access,int mode);

    • 作用:以各种方式打开文件

    • 返回值:返回打开的文件句柄,-1 打开失败

    • 输入参数说明:1.path 要打开的文件路径和名称
      2.access 访问模式,宏含义如下:O_RDONLY 1 只读; O_WRONLY 2 只写; O_RDWR 4 读写 3.mode值因为本例选择对文件只读所以输入0即可。

    • 实现结果如下:

    • 代码截图如下:
      -

    -

    码云链接

    学习教材附录A,第十章内容

    • 打开和关闭文件。

    参考别出心裁的Linux系统调用学习法,学习视频,掌握两个重要命令:

    man -k key1 | grep key2| grep 2 : 根据关键字检索系统调用
    grep -nr XXX /usr/include :查找宏定义,类型定义

    完成head,tail的使用,相关API的分析,伪代码,产品代码,测试代码的编写(3分)

    head命令

    • head命令用于显示文件的开头的内容。
    • 伪代码:
    命令行下获取要输出的行数和文件
    begin:
    打开文件;
    将命令行中输入的字符型数字换成整型;
    for(小于等于输入的行数)
    {
        while(没有遇到换行符合和错误)
        {将文件中的内容输出;}
    }
    关闭文件;
    
    • 根据伪代码很容易写出产品代码,产品代码截图:

    • 通过在命令行中运行测试代码,截图如下:

    • 代码中遇到的API函数:

    • int atoi(const char *nptr);
      用法:将字符串里的数字字符转化为整形数。返回整形值。

    • fopen函数用于打开文件, 其调用格式为:FILE *fopen(char *filename, *type);

    • fclose()函数用来关闭一个由fopen()函数打开的文件 , 其调用格式为: int fclose(FILE *stream);该函数返回一个整型数。当文件关闭成功时, 返回0, 否则返回一个非零值。可以根据函数的返回值判断文件是否关闭成功。

    tail命令

    • tail命令用于输入文件中的尾部内容。
    • 伪代码
    命令行下获取要输入的行数和文件
    begin:
    打开文件;
    将命令行中输入的字符型数字换成整型;
    统计文件中共有多少行;
    关闭文件;
    打开文件;
    for(循环文件行数)
    {
        if(输入的行数)
        {输出字符};
        }
    关闭文件;
    
    • 根据伪代码很容易写出产品代码,产品代码如下:

    • 通过在命令行测试代码,截图如下:

    • 代码中用的API函数

    • 同上

    • 码云链接

  • 相关阅读:
    vim常用命令
    转:CRF++总结1
    转:CRF++总结2
    并查集算法程序
    CRF++使用小结(转)
    并查集算法程序
    C#winform 画图
    转:字符识别
    转:A Survey On Relation Extraction
    转:生产计划问题
  • 原文地址:https://www.cnblogs.com/lhyhahaha/p/7674126.html
Copyright © 2020-2023  润新知