mypwd
- 参考资料
- pwd概述
- pwd的工作原理
- 所要用到的函数
- 分析(运行的步骤逻辑)
- 代码实现
- 效果展示
参考资料 man手册
Unix-Linux编程实践教程
pwd概述 命令pwd用来显示到达当前目录的路径。例如:
文章图片
pwd的工作原理
在每个目录文件下都会有".“和” . . “两个目录,”.“指的是当前目录,”. .“指的是上一级目录。所要用到的函数
我们可以通过”.“获得当前目录的inode-id,然后再进入该目录的上一级目录,通过刚刚获得的inode-id去匹配当前目录中文件的inode-id从而找到刚刚目录的目录名。
然后不断重复上面操作,当”.“和”. ."的inode-id相同时就可以认为已经到达了文件树的顶端
文章图片
分析(运行的步骤逻辑)
(1).得到**"."的inode-id(使用stat)代码实现
(2) .使用chdir返回上一级目录
(3).判断是否到达文件数的顶端(判断".“和”. .**"的inode-id是否相同,若到达程序执行完成,若没有继续下面步骤)
(4).找到inode-id连接的文件名字
(5).重复上面步骤,直到到达树的顶端.
#include
#include
#include
#include
#include
#include
#include
ino_t get_inode(char*);
void printpathto(ino_t);
void inum_to_name(ino_t,char*,int );
int main()
{
printpathto(get_inode("."));
putchar('\n');
return 0;
}
void printpathto(ino_t this_inode)
{
ino_t my_inode;
char its_name[BUFSIZ];
if(get_inode("..")!=this_inode)
{
chdir("..");
inum_to_name(this_inode,its_name,BUFSIZ);
my_inode = get_inode(".");
printpathto(my_inode);
printf("/%s",its_name);
}
}
void inum_to_name(ino_t inode_to_find,char *namebuf,int buflen)
{
DIR *dir_ptr;
struct dirent*direntp;
dir_ptr=opendir(".");
if(dir_ptr==NULL)
{
perror(".");
exit(1);
}
while((direntp =readdir(dir_ptr))!=NULL)
if(direntp->d_ino==inode_to_find)
{
strncpy(namebuf,direntp->d_name,buflen);
namebuf[buflen-1]='\0';
closedir(dir_ptr);
return;
}
fprintf(stderr,"error looking for inum %d\n",inode_to_find);
exit(1);
}
ino_t get_inode(char *fname)
{
struct stat info;
if(stat(fname,&info)==-1)
{
fprintf(stderr,"Cannot stat");
perror(fname);
exit(1);
}
return info.st_ino;
}
效果展示 【Linux|Linux命令pwd的自我实现】
文章图片
推荐阅读
- 算法|2021年图灵奖,花落高性能计算先驱、田纳西大学教授Jack Dongarra
- Linux|centos7 安装 mysql5.7走过的坑
- linux|zookeeper-3.4.14 出现 Client port found: 2181. Client address: localhost. 的解决办法
- 实用经验|【mysql】解决MySQL GPG密钥过期问题
- java|Spring框架漏洞总结
- 求解COP 5536
- 数据库|MySQL 主从复制原理
- 数据库|MySQL SQL的完整处理流程
- 数据库|MySQL SQL和索引优化总结