zoukankan      html  css  js  c++  java
  • pwd命令学习

    pwd命令学习

    1. 学习pwd命令

    pwd命令功能为输出当前所在工作目录的绝对路径名称。

    绝对路径和相对路径:

    绝对路径:从根目录开始直到文件位置
    相对路径:相对于程序当前所在目录到文件位置
    例:程序运行在C:/user/dell下,假设有一个文件test.txt
    绝对路径:C:/user/dell/test.txt
    相对路径:./test.txt
    

    系统手册的查询

    • 我们首先通过man pwd 命令查看pwd的详细功能

    • 可以看到pwd中有两个带参数的执行方式分别为man -lman -p

      • pwd -l 功能为从环境中执行PWD命令,即使它包含符号链接;
      • pwd -p 功能为避免所有符号链接,执行pwd命令。
    • 由于路径中无特殊符号链接,因此执行两个命令结果并无区别

    • 输入man -k dir grep 2 查看系统调用,我们可以发现getpwd函数,功能为获取当前工作目录

    • 接下来通过man getcwd 命令查看getcwd函数功能
      • char *getcwd(char *buf, size_t size); 该函数的第一个参数为数组首地址,第二个参数为空间值;
      • 该函数返回一个以null结尾的字符串,其中包含一个绝对路径名,该路径名是调用进程的当前工作目录。

    使用getcwd命令实现pwd功能

    代码如下
    #include <stdio.h>
    #include <stdlib.h>
    #include <unistd.h>
    
    int main(void)
    {
        char buf[1024];
    
        char *cwd =getcwd(buf, sizeof(buf));
    
        if (cwd == NULL) {
            perror("Get cerrent working directory fail.
    ");
            exit(-1);
        } else {
            printf("%s
    ", cwd);
        }
    
        return 0;
    }
    
    测试结果

    通过icode-number值实现pwd命令

    • 此外,我们还可以通过文件的icode值方式输出它的绝对路径
    伪代码如下
    获取初始目录名称
    next:
        获取当前目录的icode_number
        通过chdir() 返回上一级目录
        获得上一级目录的icode_number_ago
        icode_number==icode_number_ago ?
        不相等:
            获取当前目录名称
            返回next
        相等
            已经找到根目录,输出绝对路径
    
    代码如下
    #include <stdio.h>
    #include <sys/types.h>
    #include <sys/stat.h>
    #include <dirent.h>
    ino_t get_inode(char*);
    void print(ino_t);
    void inum_to_name(ino_t,char*,int);
    
    int main()
    {
    	ino_t node=get_inode(".");
    	print(node);  //打印当前目录绝对路径
    	putchar('
    ');
       	return 0;
    }
    
    void print(ino_t this_inode)
    {
        ino_t my_inode;
        char its_name[BUFSIZ];
        /*如果本目录的inode-number与上级目录不同,即本目录不是根目录*/
        if (get_inode("..")!=this_inode)                                 
        {
            chdir("..");         //进入上级目录
            inum_to_name(this_inode,its_name,BUFSIZ);
            my_inode = get_inode(".");
            print(my_inode);
            printf("/%s",its_name);
        }
    }
    void inum_to_name(ino_t inode_to_find,char* namebuf,int buflen)   //找到inode-number节点对应的文件名,并放在字符数组里
    {
        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] = '';
                closedir( dir_ptr);
                return;
            }
        }
        fprintf( stderr , "error looking for inum % d
    " ,inode_to_find);
        exit (1) ;
    }
    ino_t get_inode(char* fname)            //根据文件名,返回inode-number
    {
        struct stat info;
        if ( stat( fname, &info) == -1){
            fprintf( stderr , "Cannot stat ");
            perror(fname);
            exit (1);
        }
        return info.st_ino;
    }
    
    测试结果

  • 相关阅读:
    越长大越孤单
    关于ASP.NET 启动Process的讨论
    利用selenium开发一个功能测试的框架
    开博啦(上班时间)
    利用回发 实现一个简单的AutoComplete功能
    FIFO和双端口RAM
    8位定点数开方程序(贴下来以后研究)
    Eclipse下文件读取的问题:Failed to reading file xxxxx
    Error:NgdBuild:604解决方法(添加NGC文件方法)
    Mandelbrot:美丽的分形
  • 原文地址:https://www.cnblogs.com/wangzihong0213/p/12024732.html
Copyright © 2011-2022 走看看