本文主要是介绍Linux ls-al命令实现,tree命令实现,不带缓存的文件IO,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
shell命令
ls -al 实现
stat配合目录流(目录流==链表加指针链表结点目录项dirent)
opendir,closedir,readdir。
const char *restrict pathname:路径(文件名和路径不完全对等,(文件名在当前目录下才对等))
struct stat *restrict statbuf:被调函数通过传入传出参数给主调函数传递信息。
传递信息优先用传入传出参数,返回值用于报错。
文件类型和权限 硬链接数 所有者用户ID 用户组ID 文件大小 最后修改时间 (名字(dirent))
文件类型:
权限:
查找用户名
getpwuid:
用户组名:
/etc/group:
日历时间:
把计算机时间转换为日历时间。
用time_t获取时间,
返回标准日历时间(带有换行的字符串)
格林威治时间:
本地时间:
tree 命令的实现:
深度优先遍历,栈或递归;优先采用递归(广度优先遍历用队列)
递归(大问题->小问题->找到最小问题)
大树->访问根,访问所有子树,叶子结点->访问根,没有孩子直接返回。
不带缓冲的文件IO(直接调用内核,不用用户态):
读文件用文件流,用到用户态和系统调用:
内核有一个struct file(文件对象),里面有一个内核文件缓冲区;
在struct file 中读写数据--逻辑上直接操作硬件
数组里面存地址的指针,用户通过访问数组下标来访问指针地址(实现不给用户直接访问硬件资源的功能)
文件描述符:非负整数,用来访问某个具体的文件对象。(类似于上面数组的下标),默认数组下标0,1,2分别是stdin,stdout,stderr。
ll /dev :
这篇关于Linux ls-al命令实现,tree命令实现,不带缓存的文件IO的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!