IO进程线程,文件与目录,实现linux任意目录下ls -la

注意文件的名字、路径是如何输入的。

函数opendir打开目录,struct dirent,struct stat这些结构体的含义。

readdir()函数是一个用于读取目录内容的系统调用或库函数,在类Unix操作系统中(如Linux)广泛使用。它用于遍历目录,并逐个获取目录中的条目(文件和子目录)。

lstat和stat是用于获取文件信息的系统调用,主要在处理符号链接时存在差异。以下是它们之间的主要区别:

  1. 处理符号链接:

lstat:当使用lstat函数获取一个符号链接的信息时,它返回的是符号链接本身的信息,而不是链接所指向文件的信息。这使得你能够查看链接本身的属性,而不用跟随链接指向的文件。

stat:当使用stat函数获取一个符号链接的信息时,它会自动跟随链接,返回链接指向的文件的信息,而不是链接本身的信息。

  1. 跟随链接:

lstat:对于符号链接,lstat不会自动跟随链接,它会返回链接本身的属性,包括链接指向的路径。

stat:对于符号链接,stat会自动跟随链接,返回链接指向的文件的属性。

对于符号链接,`lstat`返回了链接本身的信息,而`stat`返回了链接指向的文件的信息。

cpp 复制代码
/*===============================================
*   文件名称:stat.c
*   创 建 者:WM
*   创建日期:2023年08月24日
*   描    述:文件目录下除了隐藏文件查看
================================================*/
#include <stdio.h>
#include <sys/types.h>
#include<sys/stat.h>
#include<unistd.h>
#include<string.h>
#include<pwd.h>
#include<grp.h>
#include<time.h>
#include<dirent.h>
int main(int argc, char *argv[])
{ 
    char path[100]={0};
    if(2!=argc)
    {
        printf("error\n");
        return -1;
    }
 
    DIR * dirp=opendir(argv[1]);//获取所有的目录下的文件名
    struct dirent *a;//接收
     strcpy(path,argv[1]);
    while (NULL!=(a=readdir(dirp)))//从第一个文件名开始遍历到最后。
    {
       struct stat st;
           strcpy(path,argv[1]);
           strcat(path,"/");
           strcat(path,a->d_name);
        if(a->d_name[0]=='.')//去除隐藏文件
           continue;
    lstat(path,&st);//链接文件读取

    if(S_ISREG(st.st_mode))//判断文件类型
        printf("-");
    else if (S_ISDIR(st.st_mode))
        printf("d");
    else if(S_ISLNK(st.st_mode))
        printf("l");

    for (  int i=8; i >= 0; i-=3)//查看文件的权限
    {
        if(st.st_mode & 1<<i)
            printf("r");
        else
            printf("-");
        if(st.st_mode&1<<(i-1))
            printf("w");
        else
            printf("-");
        if(st.st_mode&1<<(i-2))
            printf("x");
        else
            printf("-");
    }
    //链接数
    printf(" %ld",st.st_nlink);
    //用户名
    struct passwd *pw=getpwuid(st.st_uid);
    printf(" %s ",pw->pw_name);
    //用户组名
    struct group *gr =getgrgid(st.st_gid);
    printf( "%s",gr->gr_name);
    //大小
    printf(" %ld",st.st_size);
    //去除换行
    char arr[100]={0};
    strcpy(arr,ctime(&st.st_mtime));
    if(arr[strlen(arr)-1]=='\n')
      arr[strlen(arr)-1]='\0';
    printf(" %s ",arr);

    printf(" %s ",a->d_name);
    puts("");
    }
    return 0;
} 
相关推荐
.生产的驴1 小时前
Vue3 加快页面加载速度 使用CDN外部库的加载 提升页面打开速度 服务器分发
运维·服务器·前端·vue.js·分布式·前端框架·vue
程序员JerrySUN1 小时前
Linux 内核核心知识热点题分析:10 个连环打通的难点
linux·运维·服务器
R_.L2 小时前
Linux : 线程【同步与互斥】
linux
再睡一夏就好2 小时前
从硬件角度理解“Linux下一切皆文件“,详解用户级缓冲区
linux·服务器·c语言·开发语言·学习笔记
S01d13r6 小时前
LeetCode 解题思路 48(编辑距离、只出现一次的数字)
算法·leetcode·职场和发展
C_Liu_6 小时前
C语言:深入理解指针(5)
java·c语言·算法
small_wh1te_coder6 小时前
从经典力扣题发掘DFS与记忆化搜索的本质 -从矩阵最长递增路径入手 一步步探究dfs思维优化与编程深度思考
c语言·数据结构·c++·stm32·算法·leetcode·深度优先
枫景Maple6 小时前
LeetCode 45. 跳跃游戏 II(中等)
算法·leetcode
এ᭄画画的北北6 小时前
力扣-236.二叉树的最近公共祖先
算法·leetcode
honey ball7 小时前
R & S的EMI接收机面板
linux·运维·网络