zoukankan      html  css  js  c++  java
  • 20175305张天钰 实现mypwd

    20175305 实现mypwd(选做,加分))


    一、学习任务

    1 学习pwd命令
    2 研究pwd实现需要的系统调用(man -k | grep ),写出伪代码
    3 实现mypwd
    4 测试mypwd

    二、学习内容

    1.命令格式:
    pwd [选项]
    --help:显示帮助信息;
    --version:显示版本信息。

    2.命令功能:
    查看”当前工作目录“的完整路径

    3.常用参数:
    一般情况下不带任何参数
    如果目录是链接时:
    格式:pwd -P 显示出实际路径,而非使用连接(link)路径。

    4.学习pwd命令

    1:查看pwd命令的帮助信息man pwd

    2:显示当前目录所在路径 pwd

    3:显示当前目录的物理路径 pwd –P

    4:显示当前目录的连接路径:pwd -L

    通过man学习pwd

    三、完整代码

    #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
    ");
              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
    ", current_depth == 0 ? "/" : "");
    
          return 0;
      }
    

    四、运行结果截图

  • 相关阅读:
    JDK源码分析之hashmap就这么简单理解
    JVM笔记11-类加载器和OSGI
    JVM笔记10-性能优化之高级特性
    Java并发编程笔记之ThreadLocal内存泄漏探究
    Java并发编程笔记之FutureTask源码分析
    Java并发编程笔记之SimpleDateFormat源码分析
    Java并发编程笔记之Timer源码分析
    Java并发编程笔记之Semaphore信号量源码分析
    Java并发编程笔记之CyclicBarrier源码分析
    Java并发编程笔记之 CountDownLatch闭锁的源码分析
  • 原文地址:https://www.cnblogs.com/zhangtianyu/p/12046406.html
Copyright © 2011-2022 走看看