Linux ls-al命令实现,tree命令实现,不带缓存的文件IO(open,read,write)

news2024/11/28 0:52:00

shell命令

ls -al  实现

#include <43func.h>
void error_check(int ret, const char *msg) {
    if (ret == -1) {
        perror(msg);
        exit(EXIT_FAILURE);
    }
}

char get_file_type(mode_t mode) {
    if (S_ISREG(mode)) return '-';//检查给定的文件模式(通常是从 stat 或 lstat 系统调用中获得的)是否表示一个常规文件(regular file)
    if (S_ISDIR(mode)) return 'd';//检查给定的文件模式(通常是从 stat 或 lstat 系统调用中获得的)是否表示一个目录
    if (S_ISCHR(mode)) return 'c';//字符设备(character device)
    if (S_ISBLK(mode)) return 'b';//块设备(block device)
    if (S_ISFIFO(mode)) return 'p';// FIFO(First In First Out,先进先出)文件,也称为命名管道(named pipe)。
    if (S_ISLNK(mode)) return 'l';//符号链接(symbolic link),也称为软链接
    if (S_ISSOCK(mode)) return 's';//套接字(socket)文件
    return '?';
}

char * get_permissions(mode_t mode) {
    static char permissions[10];
    strcpy(permissions, "rwxrwxrwx");
    permissions[9] = '\0';
    for (int i = 0; i < 9; ++i) {
        if (!(mode & (1 << (8 - i)))) {//把权限位从后往前移,i=0,把1左移八位,0代表true,1代表flase;
            permissions[i] = '-';
        }
    }
    return permissions;
}

int main(int argc, char *argv[]) {
    ARGS_CHECK(argc,2);
    DIR *dirp = opendir(argv[1]);
    ERROR_CHECK(dirp,NULL,"opendir");
    int ret = chdir(argv[1]);文件名只有在当前目录下才是路径,改变工作路径
    ERROR_CHECK(ret,-1,"chdir");
    struct dirent *pdirent;
    struct stat statbuf;
    
    while ((pdirent = readdir(dirp)) != NULL) {
        ret = stat(pdirent->d_name, &statbuf);//文件名只有在当前目录下才是路径
        ERROR_CHECK(stat,-1,"stat");
        char file_type = get_file_type(statbuf.st_mode);
        char *permissions = get_permissions(statbuf.st_mode);
        struct passwd *pw = getpwuid(statbuf.st_uid);//getpwuid 函数用于根据给定的用户ID(UID)检索用户信息
        struct group *gr = getgrgid(statbuf.st_gid);//getgrgid 函数用于根据给定的组ID(GID)检索组信息
        char mtime[20];
        strftime(mtime, 20, "%b %d %H:%M", localtime(&statbuf.st_mtime));
        printf("%c%s %ld %s %s %8ld %s %s\n",
               file_type, permissions, statbuf.st_nlink,
               pw ? pw->pw_name : "unknown", gr ? gr->gr_name : "unknown",
               (long) statbuf.st_size, mtime, pdirent->d_name);
    }
    closedir(dirp);
    return 0;
}

stat配合目录流(目录流==链表加指针链表结点目录项dirent)

opendir,closedir,readdir。

const char *restrict pathname:路径(文件名和路径不完全对等,(文件名在当前目录下才对等))

struct stat *restrict statbuf:被调函数通过传入传出参数给主调函数传递信息。

传递信息优先用传入传出参数,返回值用于报错。


文件类型和权限     硬链接数 所有者用户ID 用户组ID  文件大小 最后修改时间 (名字(dirent))


文件类型:

权限:


查找用户名

getpwuid:

        struct passwd *pw = getpwuid(statbuf.st_uid);//getpwuid 函数用于根据给定的用户ID(UID)检索用户信息

        struct group *gr = getgrgid(statbuf.st_gid);//getgrgid 函数用于根据给定的组ID(GID)检索组信息


用户组名:

/etc/group:


日历时间:

把计算机时间转换为日历时间。

用time_t获取时间,


返回标准日历时间(带有换行的字符串)


格林威治时间:


本地时间:


 tree 命令的实现:

深度优先遍历,栈或递归;优先采用递归(广度优先遍历用队列)

递归(大问题->小问题->找到最小问题)

大树->访问根,访问所有子树,叶子结点->访问根,没有孩子直接返回。


不带缓冲的文件IO(直接调用内核,不用用户态):

读文件用文件流,用到用户态和系统调用:

内核有一个struct file(文件对象),里面有一个内核文件缓冲区;

在struct file 中读写数据--逻辑上直接操作硬件

数组里面存地址的指针,用户通过访问数组下标来访问指针地址(实现不给用户直接访问硬件资源的功能)

 文件描述符(file descriptor):非负整数,用来访问某个具体的文件对象。(类似于上面数组的下标),默认数组下标0,1,2分别是stdin,stdout,stderr。

ll /dev :

open:

字符串:路径,flages(int类型32bit)

每一个属性都是某一位为1其余位为0,多个独立属性共存用或(|

常见的文件描述符(umaskflages(int类型32bit):(flag的选择)

将默认权限中的特定位关闭,以提高系统的安全性

打开方式必须三选一。三种打开方式彼此互斥。

如果存在O_CREAT,就要使用三参数版本的open。


  1. 标准输入(stdin):文件描述符为0。这通常是键盘输入或者从其他进程通过管道(pipe)或重定向(redirection)传递过来的数据。

  2. 标准输出(stdout):文件描述符为1。这是程序用于输出信息的地方,通常默认是终端(命令行界面)或者写入到文件中。

  3. 标准错误(stderr):文件描述符为2。与标准输出类似,但是用于输出错误信息。这样,在编写程序时,可以将正常的输出和错误输出分别处理,比如分别重定向到不同的文件或管道。

在程序启动之后,如果它打开新的文件、套接字(socket)或其他类型的I/O资源,那么将会使用更高的文件描述符编号,通常是从3开始递增。这些额外的文件描述符由操作系统内核分配和管理,以确保每个打开的文件或资源都有一个唯一的标识。

fd ,文件描述符会选择最小可用的,当stdin,stdout,stderr占用了该012三位后testFile的文件描述符变为3.

O_RDONLY

O_WRONLY

O_RDWR

使用chmod u-r testFile 移除testFile的用户对读权限后,再使用open的读写方式打开会出现权限拒绝许可的提示。


umask码(掩码)

O_CREAT

umask 命令在 Linux 和 Unix 系统中用于设置用户文件创建时的默认权限掩码。这个掩码决定了新创建的文件或目录的初始权限。具体来说,umask 决定了哪些权限会被从默认权限中“剥夺”或“屏蔽”掉。

计算实际权限

当创建新文件或目录时,系统会使用默认的权限减去 umask 掩码来确定新文件或目录的初始权限。例如,如果默认的文件权限是 0666,并且 umask 设置为 022,则新文件的实际权限将是 0666 - 022 = 0644(即 rw-r--r--)。

当 flags 参数中包含了 O_CREAT 时,open 函数的第三个参数就变得有意义了。这个参数是文件权限,用于指定新创建文件的权限。

创建文件的行为总是收到umask码的影响,

成功返回一个文件描述符;失败返回-1;


O_EXCL 确保创建新的文件


O_TRUNC 清空文件内容,如果文件存在则将文件的长度截至0

fopen底层是调用了open的属性;


读写文件

read

文件对象中的指针数组通过文件描述符指向文件对象,读操作通过文件描述符取到文件对象存入缓冲内存buf中。所以buf是传入传出参数;count 表示多少个字节;

echo -n : 不在输出的末尾添加一个换行符 

echo -n 0 > file :向file文件末尾添加0,不换行

od -h   file     :显示file的十六进制

vim编辑器中使用:%!xxd   显示16进制;

文本文件:底层是ASCII码的序列,以字符串形式读写

二进制文件:底层不是ASCII的序列

(文件怎么写就怎么读)

int main(int argc, char *argv[]) {  
//     ARGS_CHECK(argc, 2);  
  
//     int fd = open(argv[1], O_RDWR | O_CREAT, S_IRUSR | S_IWUSR); // 添加O_CREAT和权限  
//     ERROR_CHECK(fd, -1, "open");  
  
//     printf("fd = %d\n", fd);  
  
//     char buf[10];  
//     ssize_t bytesRead = read(fd, buf, sizeof(buf) - 1); // 读取时留一个位置给'\0'  
//     if (bytesRead == -1) {  
//         perror("read");  
//         exit(EXIT_FAILURE);  
//     }  
//     buf[bytesRead] = '\0'; // 确保buf是一个有效的C字符串  
//     puts(buf);  
  
//     close(fd);  
  
//     return 0;  
// }
read的返回值:

>0 :成功读取了字符数;小于等于count;

=0:EOF;

-1: 报错;

count 是申请内存的大小;read之前清空buf;


write

写入文本数据;

 

写入二进制数据:读取二进制数据

读写二进制文档所需要的空间比读取文本文档所需要的空间小,这主要是由于二进制和文本文件在存储和表示数据时的差异

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1844996.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

36.6K star!Immich - 一款开源高性能的自托管照片和视频备份方案

大家好&#xff0c;今天给大家分享的是一个高性能的自托管照片和视频备份方案。 Immich 是一个图片管理和分享平台&#xff0c;它允许用户高效地组织、存储和访问他们的照片和视频集合。这个项目特别设计来优化个人和家庭的多媒体内容管理体验&#xff0c;提供了诸如自动备份、…

贾英才主任受聘担任“两个中心”专家委员会委员

近日&#xff0c;第二届海峡两岸中西医结合肾脏病学术大会授牌仪式在北京隆重举行。 这一盛会吸引了众多医学领域的专家学者&#xff0c;共同探讨中西医结合治疗肾脏病的最新进展和未来发展方向。 在此次大会上&#xff0c;崇文门中医医院的贾英才主任凭借其在肾脏病领域的卓…

绝地求生PUBG联名补偿奖励来了 补偿奖励介绍详情解析

绝地求生》(PUBG) 作为一款战术竞技型射击类沙盒游戏&#xff0c;从上线以来就深受玩家小伙伴们的喜爱&#xff0c;即便是没有玩过的小伙伴&#xff0c;对“吃 鸡”二字想必也是很耳熟的&#xff0c;这正是《绝地求生》(PUBG) 的别称。 在北京时间6月12日&#xff0c;由于绝地求…

挑战从不是终点,而是人生的起点

对于交易员来说&#xff0c;每一次市场的起伏都是对内心坚韧与技能精进的考验。无论遭遇的是挫败还是辉煌&#xff0c;它们都是通向卓越道路上不可或缺的磨砺。正是在这些磨难与历练中&#xff0c;我们不断重塑自我&#xff0c;锤炼技术&#xff0c;直至面对看似难以逾越的障碍…

行业唯一!三翼鸟场景品牌战略推动价值凸显

文 | 智能相对论 作者 | 佘凯文 当你的一只羊跑进别人的羊群中&#xff0c;怎么才能找到它&#xff1f; 从前人们为了区分自己的财产&#xff0c;会用烧红的铁块印在动物身上作为标记。在中世纪的欧洲&#xff0c;手工艺匠人用这种烧灼的方法在自己的手工艺品上烙下标记&…

会声会影2024 视频编辑创作利器 #AI智能剪辑 #特效资源库 #共创共享 #视频创作爱好者

&#x1f31f;【全新升级&#xff01;会声会影2024&#xff0c;视频编辑的革新之作】&#x1f31f; 嗨&#xff0c;CSDN的朋友们&#xff0c;今天要跟大家分享一款让我彻底震撼的视频编辑软件——会声会影2024最新版本&#x1f3ac;&#xff01;作为一位热爱创作的内容创作者&a…

昇思25天学习打卡营第3天|数据集 Dataset|数据变换 Transforms

学AI还能赢奖品&#xff1f;每天30分钟&#xff0c;25天打通AI任督二脉 (qq.com) 数据集 Dataset 数据是深度学习的基础&#xff0c;高质量的数据输入将在整个深度神经网络中起到积极作用。MindSpore提供基于Pipeline的数据引擎&#xff0c;通过数据集&#xff08;Dataset&am…

chatgpt: linux 下用纯c 编写一按钮,当按钮按下在一新窗口显示hello world

用这个程序模板&#xff0c;就可以告别只能在黑框框的终端中编程了。 在 Linux 环境下使用纯 C 语言编写一个按钮&#xff0c;当按钮按下时&#xff0c;在一个新窗口显示 "Hello World"。我们可以使用 GTK 库来实现这个功能。GTK 是一个用于创建图形用户界面的跨平台…

论文辅导 | 基于K-means聚类和ELM神经网络的养殖水质溶解氧预测

辅导文章 模型描述 1&#xff09;相似度统计量构造。数据归一化后&#xff0c;利用皮尔森相关系数确定环境因子权重&#xff0c;构造相似日的统计量&#xff0d;相似度。 2&#xff09;K-means 聚类。根据相似度应用 K-means 聚类法对历史日数据样本聚类&#xff0c;找出合适样…

clean code-代码整洁之道 阅读笔记(第十一章)

第十一章 系统 “复杂要人命,它消磨开发者的生命&#xff0c;让产品难以规划、构建和测试。” --RayOzzie&#xff0c;微软公司首席技术官 11.1 如何建造一个城市 每个城市都有一组组人管理不同的部分&#xff0c;有些人负责全局&#xff0c;其他人负责细节。 城市能运转&#…

昨天发的 npm 包,却因为 registry 同步问题无法安装使用

用过 HBuilderX 云打包的都知道&#xff0c;云上面的 Android 环境很有限&#xff0c;其实并不能覆盖 uniapp 生态所有的版本&#xff0c;甚至说只能覆盖最新的一两个版本。 如果你需要用到 HBuilderX 安卓云打包&#xff0c;就必须及时跟进 HBuilderX 的版本更新&#xff0c;…

【人机交互 复习】第7章 可视化设计

一、窗口界面类型 1.多文档界面 &#xff08;1&#xff09;优点 a.节省系统资源 b.最小的可视集 c.协同工作区 d.多文档同时可视化 &#xff08;2&#xff09;缺点 a.菜单随活动文档窗口状态变化&#xff0c;导致不一致性 b.文档窗口必须在主窗口内部&#xff0c;减弱多文档显…

[C++][数据结构][B-树][上]详细讲解

目录 0.常见的搜索结构1.B树概念2.B-树的插入分析1.流程分析2.插入过程总结 0.常见的搜索结构 种类数据格式时间复杂度顺序查找无要求 O ( N ) O(N) O(N)二分查找有序 O ( l o g 2 N ) O(log_2 N) O(log2​N)二叉搜索树无要求 O ( N ) O(N) O(N)二叉平衡树无要求 O ( l o g 2 …

【计算机网络仿真】b站湖科大教书匠思科Packet Tracer——实验5 交换机的自学习算法

一、实验目的 1.验证交换机的自学习算法&#xff1b; 2.了解交换机对帧的过滤特性&#xff1b; 3.学习交换机如何登记接收到的数据包&#xff1b; 4.学习交换机如何转发数据包&#xff08;明确转发&#xff0c;盲目转发&#xff0c;丢弃&#xff09;。 二、实验要求 1.使用Cisc…

自动化办公04 使用pyecharts制图

目录 一、柱状图 二、折线图 三、饼图 四、地图 1. 中国地图 2. 世界地图 3. 省会地图 五、词云 Pyecharts是一个用于数据可视化的Python库。它基于Echarts库&#xff0c;可以通过Python代码生成各种类型的图表&#xff0c;如折线图、柱状图、饼图、散点图等。 Pyecha…

养车小程序系统源码,汽修源码,仿途虎养车系统源码,车辆保养小程序系统

用户端&#xff0b;商家端&#xff0b;师傅端 功能介绍: 支持下单上门服务、到店核销&#xff0c;支持单独选择项目、 也支持选择服务人员、和选择门店多种下单方式&#xff0c; 支持上门服务和到店核销两种服务方式&#xff0c;支持自营和多商家联营两种运营模式&#xff…

静态路由(Static-Route)-Cisco

路由&#xff08;Route&#xff09; 世界上数亿的计算机大海 通过路由将世界连接 路由连接LAN、WAN、MAN&#xff0c;也连接世界 路由的工作 路由器将大块信息分解为小数据包 以实现可靠和高效的传输 过程称为“反汇编”和“封装数据有效负载” 路由表是一种逻辑数据结构…

Linux 服务管理(待更)

服务(service)本质就是进程&#xff0c;但是是运行在后台的&#xff0c;通常都会监听某个端口&#xff0c;等待其它程序的请求&#xff0c;比如(mysqld , sshd防火墙等)&#xff0c;因此又称为守护进程。 比如通过xshell进行连接的时候&#xff0c;需要输入的端口号就是通过守护…

PyTorch梯度直通反传

有时我们想在层的输出端放置一个阈值函数。这可能出于多种原因。其中之一是我们想将激活总结为二进制值。这种激活的二值化在自编码器中很有用。 然而&#xff0c;阈值化在反向传播过程中会带来问题&#xff1a;阈值函数的导数为零。这种梯度的缺乏导致我们的网络无法学习任何…

CSDN图片居中、左对齐、右对齐、大小设置

图片居中、左对齐、右对齐 ![在这里插入图片描述](https://img-blog.csdnimg.cn/99dc1072e8f1471990b700e1c85d301a.jpeg#pic_center) 大小设置 空格400x150 空格30%x # 长400 宽200 ![在这里插入图片描述](https://img-blog.csdnimg.cn/99dc1072e8f1471990b700e1c85d301a.…