学习贵在坚持,兜兜转转,发现还是从基础做起吧,打好基础,才会长期的坚持下去。。。

  第一个练习: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的实现与递归的更多相关文章

  1. JAVA基础知识(2)--堆栈和递归的操作

    2015-07-26 18:16:21/***该应用程序对堆栈和递归方法进行实例操作: *1.堆栈操作:先进后出,*2.递归方法:直接或者调用自己的方法:*@author lhm *Email:912 ...

  2. Python基础_函数闭包、调用、递归

    这节的主要内容是函数的几个用法闭包,调用.递归. 一.函数闭包 对闭包更好的理解请看:https://www.cnblogs.com/Lin-Yi/p/7305364.html 我们来看一个简单的例子 ...

  3. Python函数基础-函数调用,定义,参数,递归

    Python内置了很多函数供调用,eg 求绝对值函数abs() >>>abs(-1) 1 >>>abs(1) 求和函数sum(),sum(iterable,star ...

  4. java复习小知识(基础不算,有反射,递归)

    顺序选择循环,三种 1.至于循环和递归 循环效率更高,但是递归在处理文件递归的时候更为常见快捷 在java中实现传多参 2.public static void main(String[]  args ...

  5. 020--python函数基础知识考试(包括:函数_递归等知识)

    1.列举布尔值为 False 的值 空,None,0, False, '', [], {}, () 2.写函数: 根据范围获取其中 3 和 7 整除的所有数的和,并返回调用者:符合条件的数字个数以及符 ...

  6. 零基础入门学习Python(24)--递归:汉诺塔

    知识点 这节课主要讲解用递归的方法,实现汉诺塔的解答 对于游戏的玩法,我们可以简单分解为三个步骤: 1) 将前63个盘子从X移动到Y上. 2) 将最底下的第64个盘子从X移动到Z上. 3) 将Y上的6 ...

  7. 零基础入门学习Python(23)--递归:这帮小兔崽子

    知识点 我们都知道兔子繁殖能力是惊人的,如下图: 我们可以用数学函数来定义: 假设我们需要求出经历了20个月后,总共有多少对小兔崽子? 迭代实现 def fab(n): n1 = 1 n2 = 1 n ...

  8. JAVA 基础编程练习题22 【程序 22 递归求阶乘】

    22 [程序 22 递归求阶乘] 题目:利用递归方法求 5!. 程序分析:递归公式:fn=fn_1*4! package cskaoyan; public class cskaoyan22 { @or ...

  9. 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 -------------------- ...

随机推荐

  1. 品Spring:关于@Scheduled定时任务的思考与探索,结果尴尬了

    非Spring风格的代码与Spring的结合 现在的开发都是基于Spring的,所有的依赖都有Spring管理,这没有问题. 但是要突然写一些非Spring风格的代码时,可能会很不习惯,如果还要和Sp ...

  2. vim设置golang语法高亮 (Centos)

    Go语言自带vim 的语法高亮文件. http://www.golangtc.com/download 下载   go1.3.3.src.tar.gzgo1.3.3 (source only),解压缩 ...

  3. Mysql高手系列 - 第24篇:如何正确的使用索引?【高手进阶】

    Mysql系列的目标是:通过这个系列从入门到全面掌握一个高级开发所需要的全部技能. 欢迎大家加我微信itsoku一起交流java.算法.数据库相关技术. 这是Mysql系列第24篇. 学习索引,主要是 ...

  4. 深入理解C#多线程 -戈多编程

    引用(http://www.cnblogs.com/luxiaoxun/p/3280146.html) 一.使用线程的好处   1.可以使用线程将代码同其他代码隔离,提高应用程序的可靠性. 2.可以使 ...

  5. asp.net mvc select用法

    var statusSelectItems = new List<SelectListItem> { "}, "}, "}, "}, "} ...

  6. SQL SERVER数据库批量替换某个数据表里的数据update

    批量替换:将A表CMC里面所有包含a替换成b而不影响其他内容UPDATE A SET CMC=REPLACE(CMC,'a','b')

  7. 使用TryGetComponent取代GetComponent以避免Editor中的内存分配

    作为Unity开发人员,可能或多或少都会遇到过一个常见的Unity的GC分配问题——在Editor中使用GetComponent方法来获取一个不存在的Component时会分配额外的内存.就像下图 需 ...

  8. C# 求Π Π/4=1-1/3+1/5-1/7+......+1/(2*n-3)-1/(2*n-1); (n=2000)

    double a = 0.0;//最终Π的结果 double类型 int n; for (n = 1; n <= 2000; n++) { if (n % 2 == 1) { a += 1.0 ...

  9. 15.Linux软件管理

    1.什么是rpm? rpm软件包的组成部分有哪些? redhat packages manager 红帽推出软件包管理工具... rpm工具 xxxxx.rpm bash-4.2.46-28.el7. ...

  10. iOS cocoapods导入项目 出现 "___gxx_personality_v0", referenced from: 或者 clang: error: linker command failed with exit code 1 (use -v to see invocation) 错误

    今天想导入PNChart 编译的时候出现了  "___gxx_personality_v0", referenced from:  和 clang: error: linker c ...