20155212 C语言实现linux下pwd命令的两种方法

学习pwd命令

  • 通过man pwd命令查看
  • pwd [OPTION],一般不加参数
    • -P显示当前目录的物理路径
    • -L显示当前目录的连接路径
  • 该命令用来显示目前所在的工作目录。指令英文原义:print work directory

系统调用

  • 使用man -k dir | grep 2命令查看有哪些跟pwd相关的系统调用

  • 这里有两个系统调用可能用到pwd中
    • getcwd()

      • 功能:获取当前目录
      • 参数
        • char *buf:存储当前路径的字符串
        • size_t size:buf的空间大小
      • 返回值: 成功则返回指向当前路径字符串的指针,错误则返回NULL
    • readdir()
      • 功能:readdir()返回参数dir目录流的下个目录进入点
      • 参数:DIR * dir。结构dirent定义如下:
        struct dirent{
        ino_t d_ino;//此目录进入点的inode
        off_t d_off;//目录文件开头至此目录进入点的位移
        unsigned short int d_reclen;//记录的长度
        unsigned char d_type;//文件类型
        char d_name[256];
        };
      • 返回值:成功则返回下个目录进入点。有错误发生或读取到目录文件尾则返回NULL
  • 但是发现readdir()不能单独使用,
    • opendir()

      • 功能:opendir()用来打开参数name指定的目录,并返回DIR*形态的目录流,和open()类似,接下来对目录的读取和搜索都要使用此返回值
      • 参数:路径名
      • 返回值:成功则返回DIR* 型态的目录流,打开失败则返回NULL。
    • chdir()
      • 功能:切换当前目录
      • 参数:路径名

伪代码

  • 使用getcwd()
定义数组buf[MAXPATH];
调用getcwd(buf, MAXPATH);
输出返回值;
  • 使用readdir()
while(1)
{
读取"."和".."的信息
if("."的inode==".."的inode)
{
退出;
}
else
{
chdir("..");
while(dirent->inode!=前面"."的inode)
{
dirent=readdir();
}
dirent->name入栈;
}
}
for 栈顶->栈底
print 栈顶信息

产品代码

  • 使用getcwd()
#include <stdio.h>
#include <unistd.h>
#define MAXPATH 50 int main()
{
char path[MAXPATH];
puts(getcwd(path, MAXPATH));
return 0;
}
  • 使用readdir()
#include <stdio.h>
#include <dirent.h>
#include <unistd.h>
#include <sys/types.h>
#include <string.h> int main()
{ DIR *dirptr=NULL;
struct dirent *current_dirent=NULL, *parent_dirent=NULL, *tmp_dirent=NULL;
int count=0;
ino_t current_inode;
char path[256][256]; while(1)
{
dirptr=opendir(".");
do
{
current_dirent=readdir(dirptr);
}while(strcmp(current_dirent->d_name, ".")!=0);
current_inode=current_dirent->d_ino;
closedir(dirptr);
dirptr=opendir(".");
do
{
parent_dirent=readdir(dirptr);
}while(strcmp(parent_dirent->d_name, "..")!=0);
closedir(dirptr);
if(((long)parent_dirent->d_ino)==((long)current_dirent->d_ino))
{
break;
}
else
{
chdir("..");
dirptr=opendir(".");
do
{
tmp_dirent=readdir(dirptr);
}while(tmp_dirent->d_ino!=current_inode);
closedir(dirptr);
count++;
strcpy(path[count], tmp_dirent->d_name);
}
}
int i;
for(i=count;i>0;i--)
{
printf("/%s", path[i]);
}
printf("\n"); return 0;
}

测试

  • 实现一:使用getcwd()实现pwd

  • 实现二:使用readdir()实现pwd

码云链接

20155212 C语言实现linux下pwd命令的两种方法的更多相关文章

  1. Linux 下操作GPIO(两种方法,驱动和mmap)(转载)

    目前我所知道的在Linux下操作GPIO有两种方法: 1.编写驱动,这当然要熟悉Linux下驱动的编写方法和技巧,在驱动里可以使用ioremap函数获得GPIO物理基地址指针,然后使用这个指针根据io ...

  2. Linux 下操作gpio(两种方法,驱动和mmap)

    目前我所知道的在linux下操作GPIO有两种方法: 1.  编写驱动,这当然要熟悉linux下驱动的编写方法和技巧,在驱动里可以使用ioremap函数获得GPIO物理基地址指针,然后使用这个指针根据 ...

  3. 加分项——C语言实现Linux的pwd命令

    加分项--C语言实现Linux的pwd命令 实现要求 1 学习pwd命令 2 研究pwd实现需要的系统调用(man -k; grep),写出伪代码 3 实现mypwd 4 测试mypwd pwd pw ...

  4. 20155308 加分项——C语言实现Linux的pwd命令

    20155308 加分项--C语言实现Linux的pwd命令 实现要求 学习pwd命令 什么是pwd pwd' 代表的是'Print Working Directory'(打印当前目录).如它的名字那 ...

  5. Linux下进程通信的八种方法

    Linux下进程通信的八种方法:管道(pipe),命名管道(FIFO),内存映射(mapped memeory),消息队列(message queue),共享内存(shared memory),信号量 ...

  6. python执行linux命令的两种方法

    python执行linux命令有两种方法: 在此以Linux常用的ls命令为例: 方法一:使用os模块 1 2 3 shell# python >> import os >> ...

  7. Linux系统实现虚拟内存有两种方法:交换分区(swap分区)和交换文件

    Linux系统实现虚拟内存有两种方法:交换分区(swap分区)和交换文件 交换文件 查看内存:free -m , -m是显示单位为MB,-g单位GB 创建一个文件:touch /root/swapfi ...

  8. Linux下ps命令详解 Linux下ps命令的详细使用方法

    http://www.jb51.net/LINUXjishu/56578.html Linux下的ps命令比较常用 Linux下ps命令详解Linux上进程有5种状态:1. 运行(正在运行或在运行队列 ...

  9. linux 下部署nodejs(两种方式)

    本次博客的编写时用的系统环境,刚装好的Centos 6.4  64位虚拟机. 另外关于linux 其他系统的安装 可以参考https://github.com/joyent/node/wiki/Ins ...

随机推荐

  1. Mysql中的delimiter详解

    初学mysql时,可能不太明白delimiter的真正用途,delimiter在mysql很多地方出现,比如存储过程.触发器.函数等. 学过oracle的人,再来学mysql就会感到很奇怪,百思不得其 ...

  2. oracle截取字符串去掉字段末尾指定长度的字符

    lengthb(string)计算string所占的字节长度:返回字符串的长度,单位是字节 length(string)计算string所占的字符长度:返回字符串的长度,单位是字符 eg: //去掉该 ...

  3. twemproxy源码分析

    twemproxy是twitter开源的redis/memcached 代理,数据分片提供取模,一致性哈希等手段,维护和后端server的长连接,自动踢除server,恢复server,提供专门的状态 ...

  4. 使用ASP.Net WebAPI构建REST服务——客户端

    原文的链接:http://www.cnblogs.com/TianFang/p/3724449.html WebAPI是标准的Http协议,支持Http协议的客户端(如浏览器)都可以访问.但是,有的时 ...

  5. mysql-sql-standard

    https://github.com/zhishutech/mysql-sql-standard

  6. 初始Flask

    一.Flask介绍(轻量级的框架,非常快速的就能把程序搭建起来) Flask 主要特点小而轻,原生组件几乎为0, 三方提供的组件请参考Django 非常全面,属于短小精悍型框架 Flask是一个基于P ...

  7. elastic search报错——“failed to obtain node locks”

    启动时报错信息: 这里写图片描述 寻找主要信息:failed to obtain node locks这里写图片描述简单理解为:绑定节点失败!!! 百度后,好多人同样遇到了这个问题,导致的原因可能是因 ...

  8. November 18th 2016 Week 47th Friday

    Get a livelihood and then practise virtue. 先谋生,而后修身. If you can't earn a life, all the things you ha ...

  9. BZOJ 2330 糖果 差分约束求最小值

    题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=2330 题目大意: 幼儿园里有N个小朋友,lxhgww老师现在想要给这些小朋友们分配糖果 ...

  10. Spring AbstractApplicationContext抽象类的refresh()方法--笔记

    Spring中AbstractApplicationContext抽象类的refresh()方法是用来刷新Spring的应用上下文的.下面Spring的应用上下文我都叫作context @Overri ...