首页 > 其他分享 >mypwd的实现

mypwd的实现

时间:2022-10-22 14:46:48浏览次数:53  
标签:stat 实现 filename current ino mypwd include

学习任务

0 推荐在openEuler中完成
1 学习pwd命令
2 研究pwd实现需要的系统调用(man -k; grep),写出伪代码
3 实现mypwd
4 测试mypwd
提交过程博客的链接或截图

1.学习pwd命令

查询pwd功能,输入man pwd查询手册

2.研究pwd实现需要的系统调用

输入man -k directory | grep 2查询与目录有关的系统调用

chdir、getcwd、readdir符合结果

打开readdir手册页

了解过后写出基于inode的伪代码:

while(未到根目录)
    {
      读取当前目录名称;
      打开父目录;
    }
printf(目录);

3.实现mypwd

#include <stdio.h>
#include <stdlib.h>
#include <dirent.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <string.h>
#include <unistd.h>
  
  //获取文件的inode-number
  ino_t get_ino_byname(char *filename)
  {
    struct stat file_stat;
    if(0 != stat(filename, &file_stat)) //stat()通过文件名filename获取文件信息,并保存在buf所指的结构体stat中
    {
        perror("stat");
        exit(-1);
    }  
  return file_stat.st_ino;
    }

    //根据inode-number, 在当前目录中查找对应文件名
  char *find_name_byino(ino_t ino)
  {
      DIR *dp = NULL;
      struct dirent *dptr = NULL;
      char *filename = NULL;
       if(NULL == (dp = opendir("."))) //opendir()打开一个目录,在失败的时候返回一个空的指针,成返回DIR结构体
  {
      fprintf(stderr, "Can not open Current Directory\n");
      exit(-1);
  }
  else
  {
      while(NULL != (dptr = readdir(dp))) //readdir()用来读取目录。返回是dirent结构体指针
      {
          if(dptr->d_ino == ino)
          {
              filename = strdup(dptr->d_name); //strdup()将串拷贝到新建的位置处,返回一个指针,指向为复制字符串分配的空间;如果分配空间失败,则返回NULL值.
              break;
          }
      }

      closedir(dp);
  }

  return filename;
    }
  int main(int argc, char *argv[])
  {
      //记录目名的栈
      char *dir_stack[256];
      unsigned current_depth = 0;
  while(1)
  {
      ino_t current_ino = get_ino_byname("."); //通过"."获取当期目录inode
      ino_t parent_ino = get_ino_byname(".."); //通过".."获取当前目录的父目录的inode
      if(current_ino == parent_ino)
          break;               //达到根目录,推出循环
  
      /*若两个inode不一样*/
      chdir(".."); //更改当前工作目录,变为当前目录的父目录
      dir_stack[current_depth++] = find_name_byino(current_ino); //"文件名"地址存放
  }

  int i = current_depth - 1;
  for(i = current_depth - 1; i >= 0; i--) //打印路径
  {
      fprintf(stdout, "/%s", dir_stack[i]);
  }
  fprintf(stdout, "%s\n", current_depth == 0 ? "/" : "");

  return 0;
    }

4.测试mypwd

标签:stat,实现,filename,current,ino,mypwd,include
From: https://www.cnblogs.com/zhou-huilin/p/16816056.html

相关文章

  • linux实现 五子棋(人人对战)
    分步解析对于game函数的解析进入game函数中,通过创建一个二维数组来打印棋盘,进入dowhile循环中,策略是先打印出棋盘,然后先让用户1落子,进行判定,看是否需要继续,若需......
  • C语言实现vector结构
    C语言实现vector结构 1.使用说明本例vector结构以单链表方式实现,结合了stack与queue结构:pop_front+push_front使用方式为stack;pop_front+push_back使用方式是queue。......
  • 对于在指定目录下实现遍历其所有子文件的实现
    特地来强调一下这个方法下面这个图片,是利用递归来遍历输出指定目录下的子文件路径名:上述内容是遍历输出指定目录下的子文件路径名,要是想要实现循环遍历该目录下的所有......
  • vue.js中实现阻止事件冒泡
    当父子元素中都有点击事件的时候,为了让触发子元素中的事件时,不去触发父元素中的事件,可以在子元素事件中添加stop来阻止事件冒泡。 .stop是阻止冒泡行为,不让当前元素的......
  • 实现mypwd
    实验内容1.学习pwd命令2.研究pwd实现需要的系统调用(man-k;grep),写出伪代码3.实现mypwd4.测试mypwd实践过程学习pwd命令1.pwd命令功能Linux中,pwd命令用于显示工......
  • mypwd
    mypwd学习任务:0推荐在openEuler中完成1学习pwd命令2研究pwd实现需要的系统调用(man-k;grep),写出伪代码3实现mypwd4测试mypwd提交过程博客的链接或截图1.......
  • 数据库连接池_实现介绍和数据库连接池_c3p0基本使用
    数据库连接池_实现介绍:1.实现∶   1.标准接口:Datasource  javax.sql包下的1.方法∶获取连接:getconnection()归还连接:connection.close()。如果连接对象C......
  • 在线问题反馈模块实战(十四):实现在线答疑功能
    ......
  • 基于Astar算法实现飞行轨迹的三维规划附Matlab代码
    ✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。......
  • 数据库连接池概述和实现介绍
    数据库连接池-概述概念:其实就是一个容器(集合),存放数据库连接容器当系统初始化好后,容器被创建,容器中会申请一些连接对象,当用户来访问数据库时,从容器中获取连接对象......