基础练习1——ls的实现与递归
学习贵在坚持,兜兜转转,发现还是从基础做起吧,打好基础,才会长期的坚持下去。。。
第一个练习:shell命令 “ls"的实现与递归
1、简介:ls 的作用是列举当前目录下所有的目录和文件。
2、用到的结构体——struct dirent;
struct dirent
{
long d_ino; /* inode number 索引节点号 */
off_t d_off; /* offset to this dirent 在目录文件中的偏移 */
unsigned short d_reclen; /* length of this d_name 文件名长 */
unsigned char d_type; /* the type of d_name 文件类型 */
char d_name [NAME_MAX+]; /* file name (null-terminated) 文件名,最长255字符 */
}
struct dirent 结构体中成员d_type文件类型的分类:
enum
{
DT_UNKNOWN = , //类型未知。少数文件系统会出现此函数不支持的文件类型,另一些则总是返回这个值。译者注:总之这个值是为了应对不兼容的文件系统而设置的;
# define DT_UNKNOWN DT_UNKNOWN
DT_FIFO = , // 一个命名管道,或FIFO
# define DT_FIFO DT_FIFO
DT_CHR = , // 字符设备
# define DT_CHR DT_CHR
DT_DIR = , // 目录
# define DT_DIR DT_DIR
DT_BLK = , // 块设备
# define DT_BLK DT_BLK
DT_REG = , // 常规文件
# define DT_REG DT_REG
DT_LNK = , // 符号链接
# define DT_LNK DT_LNK
DT_SOCK = , // 套接字
# define DT_SOCK DT_SOCK
DT_WHT =
# define DT_WHT DT_WHT
};
3、目录文件的操作函数——opendir、readdir、closedir;
opendir(打开目录)
|
相关函数
|
open,readdir,closedir,rewinddir,seekdir,telldir,scandir |
|
表头文件
|
#include<sys/types.h> #include<dirent.h> |
|
定义函数
|
DIR * opendir(const char * name); |
|
函数说明
|
opendir()用来打开参数name指定的目录,并返回DIR*形态的目录流,和open()类似,接下来对目录的读取和搜索都要使用此返回值。 |
|
返回值
|
成功则返回DIR* 型态的目录流,打开失败则返回NULL。 |
|
错误代码
|
EACCESS 权限不足 EMFILE 已达到进程可同时打开的文件数上限。 ENFILE 已达到系统可同时打开的文件数上限。 ENOTDIR 参数name非真正的目录 ENOENT 参数name 指定的目录不存在,或是参数name 为一空字符串。 ENOMEM 核心内存不足。 |
|
readdir(读取目录) |
|
相关函数
|
open,opendir,closedir,rewinddir,seekdir,telldir,scandir |
|
表头文件
|
#include<sys/types.h> #include<dirent.h> |
|
定义函数
|
struct dirent * readdir(DIR * dir); |
|
函数说明
|
readdir()返回参数dir目录流的下个目录进入点。 结构dirent定义如下 struct dirent { ino_t d_ino; ff_t d_off; signed short int d_reclen; unsigned char d_type; har d_name[256; }; d_ino 此目录进入点的inode d_off 目录文件开头至此目录进入点的位移 d_reclen _name的长度,不包含NULL字符 d_type d_name 所指的文件类型 d_name 文件名 |
|
返回值
|
成功则返回下个目录进入点。有错误发生或读取到目录文件尾则返回NULL。 |
|
附加说明
|
EBADF参数dir为无效的目录流。 |
closedir(关闭目录)
|
相关函数
|
opendir |
|
表头文件
|
#include<sys/types.h> #include<dirent.h> |
|
定义函数
|
int closedir(DIR *dir); |
|
函数说明
|
closedir()关闭参数dir所指的目录流。 |
|
返回值
|
关闭成功则返回0,失败返回-1,错误原因存于errno 中。 |
|
错误代码
|
EBADF 参数dir为无效的目录流 |
|
范例
|
参考readir()。 |
4、代码示例:
#include <stdio.h>
#include <sys/types.h>
#include <dirent.h>
#include <string.h>
#include <errno.h> #if 0
struct dirent
{
long d_ino; /* inode number 索引节点号 */
off_t d_off; /* offset to this dirent 在目录文件中的偏移 */
unsigned short d_reclen; /* length of this d_name 文件名长 */
unsigned char d_type; /* the type of d_name 文件类型 */
char d_name [NAME_MAX+]; /* file name (null-terminated) 文件名,最长255字符 */
} // d_type表示档案类型: enum
{
DT_UNKNOWN = , //类型未知。少数文件系统会出现此函数不支持的文件类型,另一些则总是返回这个值。译者注:总之这个值是为了应对不兼容的文件系统而设置的;
# define DT_UNKNOWN DT_UNKNOWN
DT_FIFO = , // 一个命名管道,或FIFO
# define DT_FIFO DT_FIFO
DT_CHR = , // 字符设备
# define DT_CHR DT_CHR
DT_DIR = , // 目录
# define DT_DIR DT_DIR
DT_BLK = , // 块设备
# define DT_BLK DT_BLK
DT_REG = , // 常规文件
# define DT_REG DT_REG
DT_LNK = , // 符号链接
# define DT_LNK DT_LNK
DT_SOCK = , // 套接字
# define DT_SOCK DT_SOCK
DT_WHT =
# define DT_WHT DT_WHT
}; #endif void listDir(char *dir)
{
DIR *dp;
struct dirent *dirp;
char childpath[]; memset(childpath,,sizeof(childpath));
if ((dp = opendir(dir)) == NULL)
{
printf("can't open the directory %s,Error = %s!\n",dir,strerror(errno));
return;
} while ((dirp = readdir(dp)) != NULL)
{
// printf("dir = %s,dir_type = %d,DT_DIR = %d\n",dirp->d_name,dirp->d_type,DT_DIR);
if (dirp->d_type == DT_DIR)
{
if (strcmp(dirp->d_name,".") == || strcmp(dirp->d_name,"..") == )
continue;
sprintf(childpath,"%s/%s",dir,dirp->d_name);
printf("childpath = %s\n",childpath);
listDir(childpath);
}
else
{
printf("filename = %s\n",dirp->d_name);
}
}
closedir(dp);
} int main(int argc,char *argv[])
{
if (argc != )
{
printf("Usage: ls directory name!\n");
return -;
}
listDir(argv[]);
return ;
}
基础练习1——ls的实现与递归的更多相关文章
- JAVA基础知识(2)--堆栈和递归的操作
2015-07-26 18:16:21/***该应用程序对堆栈和递归方法进行实例操作: *1.堆栈操作:先进后出,*2.递归方法:直接或者调用自己的方法:*@author lhm *Email:912 ...
- Python基础_函数闭包、调用、递归
这节的主要内容是函数的几个用法闭包,调用.递归. 一.函数闭包 对闭包更好的理解请看:https://www.cnblogs.com/Lin-Yi/p/7305364.html 我们来看一个简单的例子 ...
- Python函数基础-函数调用,定义,参数,递归
Python内置了很多函数供调用,eg 求绝对值函数abs() >>>abs(-1) 1 >>>abs(1) 求和函数sum(),sum(iterable,star ...
- java复习小知识(基础不算,有反射,递归)
顺序选择循环,三种 1.至于循环和递归 循环效率更高,但是递归在处理文件递归的时候更为常见快捷 在java中实现传多参 2.public static void main(String[] args ...
- 020--python函数基础知识考试(包括:函数_递归等知识)
1.列举布尔值为 False 的值 空,None,0, False, '', [], {}, () 2.写函数: 根据范围获取其中 3 和 7 整除的所有数的和,并返回调用者:符合条件的数字个数以及符 ...
- 零基础入门学习Python(24)--递归:汉诺塔
知识点 这节课主要讲解用递归的方法,实现汉诺塔的解答 对于游戏的玩法,我们可以简单分解为三个步骤: 1) 将前63个盘子从X移动到Y上. 2) 将最底下的第64个盘子从X移动到Z上. 3) 将Y上的6 ...
- 零基础入门学习Python(23)--递归:这帮小兔崽子
知识点 我们都知道兔子繁殖能力是惊人的,如下图: 我们可以用数学函数来定义: 假设我们需要求出经历了20个月后,总共有多少对小兔崽子? 迭代实现 def fab(n): n1 = 1 n2 = 1 n ...
- JAVA 基础编程练习题22 【程序 22 递归求阶乘】
22 [程序 22 递归求阶乘] 题目:利用递归方法求 5!. 程序分析:递归公式:fn=fn_1*4! package cskaoyan; public class cskaoyan22 { @or ...
- linux中的一些基础命令的使用(which,whereis,locate,find,alias,file,ls,cat,echo,tar,bzip2,gzip,history,mv,cp,rm)
which whereis locate find alias file ls cat echotar bzip2 gzip history mv cp rm -------------------- ...
随机推荐
- 列表 元祖 range
1.列表 list 存放一些数据的容器 比如 衣柜 书包 作用:存储一些数据,数据量比较大 可以下标 可以切片 可以步长 和字符串的完全一样 lst = [1,2,3] print(lst) #[1, ...
- 漫谈 GOF 设计模式在 Spring 框架中的实现
原文地址:梁桂钊的博客 博客地址:http://blog.720ui.com 欢迎关注公众号:「服务端思维」.一群同频者,一起成长,一起精进,打破认知的局限性. 漫谈 GOF 设计模式在 Spring ...
- 最近学到的Git知识,大厂的Git机制还是很方便的
本文首发于微信公众号:程序员乔戈里 转载请注明:https://blog.csdn.net/WantFlyDaCheng/article/details/102538508 一.两次的 git com ...
- 采坑指南——k8s域名解析coredns问题排查过程
正文 前几天,在ucloud上搭建的k8s集群(搭建教程后续会发出).今天发现域名解析不了. 组件版本:k8s 1.15.0,coredns:1.3.1 过程是这样的: 首先用以下yaml文件创建了一 ...
- day 21作业
目录 一.定义一个类:圆形,该类有半径,周长,面积等属性,将半径隐藏起来,将周长与面积开放 二.使用abc模块定义一个phone抽象类 并编写一个具体的实现类 一.定义一个类:圆形,该类有半径,周长, ...
- Kafka 介绍
Apache Kafka是一个分布式流式平台. 流平台有三个关键的能力: 发布和订阅记录流,类似于消息队列或企业消息传递系统. 使用容错耐用的方式存储记录流. 记录产生时处理数据. Kafka主要是用 ...
- windows上gedit 安装
1. 用浏览器打开https://wiki.gnome.org/Apps/Gedit 下载并安装 gedit 文本编辑器.这个操作无需管理员权限. 2. 把 gedit 放到桌面或者快速启动栏,这样你 ...
- WPF编程,C#中对话框自动关闭的一种方法(转载)
本文原文链接:https://blog.csdn.net/qq_43307934/article/details/84933196———————————————— MessageBoxTimeout是 ...
- 零基础:如何快速学习JavaScript,html+css技术
前端开发要学的知识内容涉及的会很宽泛,虽然说主要是HTML.CSS和JavaScript这些基础知识点,但达妹今天想强调一下,学前端开发除了要学这些基础知识外,学员还要在这之上进行延伸和深入的去学,而 ...
- Java学习笔记之抽象类与接口
抽象类(abstract) 抽象类概述:一个类被abstract修饰表示这个类是抽象类, 自己定义方法但是不实现方法,后代去实现 抽象方法: 一个方法被abstract修饰表示这个方法是抽象方法 ...