20155333 实现mypwd

学习pwd命令

Linux中用 pwd 命令来查看”当前工作目录“的完整路径。

  1. 命令格式:pwd [选项]
  2. 命令功能:查看”当前工作目录“的完整路径
  3. 用参数:一般情况下不带任何参数,如果目录是链接时,格式:

    pwd -P 显示出实际路径,而非使用连接(link)路径。

    pwd -L:与pwd -P完全相反,显示链接路径

研究pwd实现需要的系统调用(man -k; grep),写出伪代码

实现pwd打印当前目录
  • 所需函数 getcwd
  • 函数原型:char *getcwd( char *buffer, int maxlen );
  • 功 能:获取当前工作目录
  • 参数说明:getcwd()会将当前工作目录的绝对路径复制到参数buffer所指的内存空间中,参数maxlen为buffer的空间大小。
  • 返 回 值:成功则返回当前工作目录,失败返回 FALSE。
  • 在某些 Unix 的变种下,如果任何父目录没有设定可读或搜索模式,即使当前目录设定了,getcwd()还是会返回 FALSE。有关模式与权限的更多信息见 chmod()。
  • 头文件:unistd.h(windows下为direct.h)
#include <unistd.h>
#include <stdio.h>
int main(void){
printf("%s\n",getcwd(NULL,0)); //输出获取路径
return 0;
}

实现mypwd

mypwd.c
#include<stdio.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<dirent.h> //获得一个目录的inode号
//以便于配合readdir筛选
ino_t get_inode(char *); //利用递归,由根目录向外
//依次显示各级目录
void printpathto(ino_t); //在当前目录中
//根据inode号,寻找对应的
//文件或文件夹名称,保存在数组里
//注意:inode有对应类型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("..");
//把上级目录的文件夹名存到its_name里
inum_to_name(this_inode,its_name,BUFSIZ);
//将当前目录(刚才切换的“上级目录”)
//的内容给my_inode
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);
}
//显示不停读取目录中的内容,if将每条内容加以判断
//判断inode号是否是我们需要的
//如果是,
while((direntp = readdir(dir_ptr)) != NULL)
if(direntp->d_ino == inode_to_find)
{
//将文件夹名复制到namebuf中,并添加'\0'
strncpy(namebuf, direntp->d_name,buflen);
namebuf[buflen-1] = '\0';
closedir(dir_ptr);
return;
}
//如果程序正常,在上面就return了
fprintf(stderr,"error looking for inum %dn",inode_to_find);
exit(1);
} //怎么获得的?
//stat把文件名(目录文件)信息放到结构体
//返回结构体st_ino元素
//这里增加了一步出错处理
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;
}

测试mypwd

20155333 实现mypwd的更多相关文章

  1. 2017-2018-1 20155205 实现mypwd

    2017-2018-1 20155205 实现mypwd 课堂总结 根据上课对ls -l功能的实现,我总结了实现一个linux命令需要的步骤: 使用man -k xx | grep xx查看帮助文档, ...

  2. 20155227 实现mypwd

    20155227 实现mypwd 1 学习pwd命令 2 研究pwd实现需要的系统调用(man -k; grep),写出伪代码 3 实现mypwd 4 测试mypwd 课堂学习笔记 实现mypwd 在 ...

  3. 2017-2018-1 20155306 mypwd的实现

    2017-2018-1 20155306 mypwd的实现 一.pwd的使用 功能: Linux中用 pwd 命令来查看"当前工作目录"的完整路径. 命令格式:pwd [选项] 命 ...

  4. 实现mypwd

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

  5. 2018-2019-1 20165231 实现mypwd(选做)

    实现mypwd 要求: 学习pwd命令 研究pwd实现需要的系统调用(man -k; grep),写出伪代码 实现mypwd 测试mypwd pwd: 在Linux层次结构中,想要知道当前所处的目录, ...

  6. 20165223 《信息安全系统设计基础》 实现mypwd

    一.学习pwd命令 1. pwd命令简介 英文原名:Print Working Directory 指令功能:打印出当前工作目录 执行权限:All User 指令所在路径:/usr/bin/pwd 或 ...

  7. 2018-2019-1 20165234 实现mypwd

    实现mypwd(选做,加分) 1 学习pwd命令 2 研究pwd实现需要的系统调用(man -k; grep),写出伪代码 3 实现mypwd 4 测试mypwd 提交过程博客的链接

  8. 实现mypwd和mybash

    一.pwd 1.学习pwd命令 man pwd查看pwd功能 可以得知pwd功能是打印当前目录 2.研究pwd实现需要的系统调用(man -k; grep),写出伪代码 (1)man -k direc ...

  9. 20155228 2017-11-19 实现mypwd(选做,加分)

    20155228 2017-11-19 实现mypwd(选做,加分) 题目和要求 学习pwd命令 研究pwd实现需要的系统调用(man -k; grep),写出伪代码 实现mypwd 测试mypwd ...

随机推荐

  1. 利用 NGINX 最大化 Python 性能,第二部分:负载均衡和监控

    [编者按]本文主要介绍 NGINX 的主要功能以及如何通过 Nginx 优化 Python 应用性能.本文系国内 ITOM 管理平台 OneAPM 编译呈现. 本文上一篇系: 利用 NGINX 最大化 ...

  2. leetCode题解之判断一个句子中的字符和数字是否构成回文

    1.问题描述 Given a string, determine if it is a palindrome, considering only alphanumeric characters and ...

  3. C++易混淆概念

    1. 引用和指针有什么区别? 本质:一个是别名,一个是地址1. 指针可以在运行时改变其所指向的值,引用一旦和某个对象绑定就不再改变2. 引用没有const, 指针有const 3. 从内存上看,指针会 ...

  4. 用字典给Model赋值并支持map键值替换

    用字典给Model赋值并支持map键值替换 这个是昨天教程的升级版本,支持键值的map替换. 源码如下: NSObject+Properties.h 与 NSObject+Properties.m / ...

  5. php解决约瑟夫环的问题

    php里面解决约瑟夫环还是比较方面的,但是下面的方法太费空间 <?php class SelectKing{ private $m;//幅度 private $n;//总数 public fun ...

  6. SGU---105 水题

    题目链接: https://cn.vjudge.net/problem/SGU-105 题目大意: 定义一个数列 1,12,123,1234,12345......12345678910,123456 ...

  7. VM下,装centos7系统,配置nginx的问题

    一.流程 1.先安装nginx依赖的包 (1)yum install gcc-c++ (2)yum install -y pcre pcre-devel (3)yum install -y zlib ...

  8. impdp导入expdp导出数据库实例

    impdp命令在cmd下直接用,不必登录oracle.只能导入expdp导出的dmp文件. expdp导出的时候,需要创建 DIRECTORY 导出什么表空间,导入也要什么表空间. 导出什么用户,导入 ...

  9. Sequelize-nodejs-10-Hooks

    Hooks钩子 Hooks (also known as lifecycle events), are functions which are called before and after call ...

  10. leetcode 141. Linked List Cycle 、 142. Linked List Cycle II

    判断链表有环,环的入口结点,环的长度 1.判断有环: 快慢指针,一个移动一次,一个移动两次 2.环的入口结点: 相遇的结点不一定是入口节点,所以y表示入口节点到相遇节点的距离 n是环的个数 w + n ...