乐趣区

关于linux:在Linux上实现自定义的-ls命令

  1. 浏览联机帮助

列出无关文件的信息(默认为当前目录)。如果未指定 -cftuvSUX 或 –sort,则按字母程序对条目进行排序。

能够看到,ls 命令 可能找出当前目录中所有文件的文件名,按字典序排序后输入。

ls 命令 还能显示其余信息,如果加上 -l 选项,ls 会列出每个文件的详细信息,也叫 ls 的长格局,在 man 手册 中能够看到:

应用长列表格局

当初在咱们的终端键入命令:

通过试验和联机帮助能够晓得 ls 做了以下两件事(ls 能断定参数指定的是文件还是目录):

列出目录的内容
显示文件的信息
在正式开始之前,来看一下 Unix 是如何组织磁盘上的文件的。

大方框示意目录,大方框内的小方框示意文件,目录之间的连线示意目录之间的组织关系。
https://www.doc88.com/p-38773…

  1. ls 是如何工作的
    通过联机帮助(过程省略)能够晓得,从目录读数据与从文件读数据是相似的,opendir 关上一个目录,readdir 返回目录中的以后项,closedir 敞开一个目录,seekdir、telldir、rewinddir 与 lseek 的性能相似。

接下来用 man 手册 查问一下 readdir(3),能够看到:

readdir() 函数返回一个指向 dirent 构造的指针,该构造示意 dirp 指向的目录流中的下一个目录条目。它在达到目录流开端或产生谬误时返回 NULL。

也就是说,readdir() 来读取 struct dirent 取得目录中的记录。

  1. 如何编写 ls
    最高级的 ls 命令

上面实现了一个最高级的 ls 命令

include <stdio.h>

include <sys/types.h>

include <dirent.h> // opendir() readdir() closedir()

https://www.doc88.com/p-38773…
void do_ls(char*);

int main(int argc, char* argv[]) {

if (argc == 1) {do_ls(".");
}
else {while (--argc) {printf("%s:\n", *(++argv));
        do_ls(*argv);
    }
}

return 0;

}

void do_ls(char dirname[]) {

DIR* dir_ptr;       // 记录 opendir()后的返回值
struct dirent* direntp; // 记录 readdir()后的返回值

if ((dir_ptr = opendir(dirname)) == NULL) {fprintf(stderr, "ls1: cannot open %s\n", dirname);
}
else {while ((direntp = readdir(dir_ptr)) != NULL) {printf("%s\n", direntp->d_name);
    }
    closedir(dir_ptr);
}

https://www.doc88.com/p-38773…
运行后果:

  1. 改良 ls 命令
    退出以下性能:

    排序
    解决办法:把所有的文件名读入一个数组,用 qsort 函数排序

分栏:规范的 ls 输入是分栏排列的,有些以行排列,有些以列排列
解决办法:把文件名读入数组,而后计算入列的宽度和行数

“.”文件:ls 列出了“.”文件,而规范的 ls 只有在给出 -a 选项时才会列出
解决办法:使 ls1 可能接管选项 -a,并在没有 -a 的时候不显示暗藏文件

选项 -l:如果选项中有 -l,规范的 ls 会列出文件的详细信息,而 ls1 不会
解决办法:上面探讨

退出移动版