zoukankan      html  css  js  c++  java
  • 文件目录相关函数

    //-rw-rw-r-- 2 zijiao zijiao 16 Feb 24 13:20 hello
    
    #include <stdio.h>
    #include <unistd.h>
    #include <sys/types.h>
    #include <sys/stat.h>
    #include <fcntl.h>
    #include <string.h>
    #include <time.h>
    #include <pwd.h>
    #include <grp.h>
    
    int main(int argc, char* argv[]){
        if(argc!=2){
            printf("need filename
    ");
            return -1;
        }
        //stat func to get file information
        struct stat sb;
        stat(argv[1],&sb);
    
        //parse the info st_mode, uid, gid, time 
        //st_mode 
        char stmode[11]={0};
        memset(stmode,'-',10);
        if(S_ISREG(sb.st_mode)) {
            stmode[0]='-';
        }
        if(S_ISDIR(sb.st_mode)){
            stmode[0]='d';
        }
        if(S_ISCHR(sb.st_mode)){
            stmode[0]='c';
        }
        if(S_ISBLK(sb.st_mode)){
            stmode[0]='b';
        }
        if(S_ISFIFO(sb.st_mode)){
            stmode[0]='p';
        }
        if(S_ISLNK(sb.st_mode)){
            stmode[0]='l';
        }
        if(S_ISSOCK(sb.st_mode)){
            stmode[0]='s';
        }
        
        //parse permission
        if(sb.st_mode & S_IRUSR) stmode[1]='r';
        if(sb.st_mode & S_IWUSR) stmode[2]='w';
        if(sb.st_mode & S_IXUSR) stmode[3]='x';
        
        if(sb.st_mode & S_IRGRP) stmode[4]='r';
        if(sb.st_mode & S_IWGRP) stmode[5]='w';
        if(sb.st_mode & S_IXGRP) stmode[6]='x';
        
        if(sb.st_mode & S_IROTH) stmode[7]='r';
        if(sb.st_mode & S_IWOTH) stmode[8]='w';
        if(sb.st_mode & S_IXOTH) stmode[9]='x';
        
        //username, groupname can be obtained by func getpwuid and getgrgid 
        
        //time can be obtained by func localtime
        struct tm *filetm=localtime(&sb.st_atim.tv_sec);
        char timebuf[20];
        sprintf(timebuf, "%dmonth  %dday %02d:%02d", filetm->tm_mon+1, filetm->tm_mday, filetm->tm_hour, filetm->tm_min);
        printf("%s %d %s %s %d %s %s", stmode, sb.st_nlink,getpwuid(sb.st_uid)->pw_name, 
               getgrgid(sb.st_gid)->gr_name, sb.st_size,timebuf ,argv[1]);
        return 0;
    }

    stat 函数实现 ls -l

    若查看软链接的,会追溯到源文件。若只想查看软连接,需 lstat

     

     

     

     

     

    access 函数查看文件权限

    查看最大可以打开的文件数

     3-1023

    truncate 截断文件

     可用于扩展文件, 长度大于源文件就扩展。

     截断文件到4B, 长度小于源文件就截断。

    link 函数

    创建硬连接

     创建软链接

     获取软链接源文件

     unlink删除链接

    注意: unlink("hello") hello这个文件就被删除了

     可以写入,但是文件最后不存在。unlink删除硬连接计数,若到0,则删除文件,如果有进程引用当前文件,先不删除此文件,等到进程退了以后再删。

    chown 函数

    rename 函数

     改文件/目录均可

    getcwd 获得当前工作路径

    chdir 改变工作路径

    只是改变程序进程的工作路径,shell的工作路径并没有变。工作路径是进程独有的。

     

     在bbb目录下写文件temp

    mkdir 函数

    rmdir 函数

    目录必须为空

    需求: 统计目录下普通文件的个数,子目录递归

    shell: find ./ -type f | wc -l

    #include <stdio.h>
    #include <unistd.h>
    #include <dirent.h>
    #include <sys/types.h>
    #include <string.h>
    int count =0;
    int fileCount(char *dir){
        //open dir
        DIR* dirp=opendir(dir);
        if(dirp==NULL){
            perror("opendir err
    ");
            return -1;
        }
        struct dirent* drt=NULL;
        while((drt=readdir(dirp))!=NULL){ // if null, reach the end of dir
            if(drt->d_type==DT_DIR){
                if(strcmp(".",drt->d_name)==0 || strcmp("..",drt->d_name)==0 ) continue;
                char newdirname[256]={0};
                sprintf(newdirname,"%s/%s", dir, drt->d_name);
                fileCount(newdirname);
            }else if(drt->d_type==DT_REG){
                count++;
            }
        }
        closedir(dirp);
        return 0;
    }
    
    int main(int argc, char* argv[])
    {   
        if(argc!=2){
            printf("need dir
    ");
            return -1;
        }
        fileCount(argv[1]);
        printf("total file count: %d
    ", count);
        return 0;
    }

    dup 和 dup2

     需求:执行两次输出HW,一次输出到文件中,一次输出到屏幕上

  • 相关阅读:
    [BZOJ]1018 堵塞的交通(SHOI2008)
    [BZOJ]1069 最大土地面积(SCOI2007)
    HDU5739:Fantasia——题解
    洛谷6186:[NOI Online 提高组]冒泡排序——题解
    洛谷4631 & UOJ415 & LOJ2586:[APIO2018] Circle selection 选圆圈——题解
    洛谷2014:[CTSC1997]选课——题解
    洛谷2758:编辑距离——题解
    洛谷4148 & BZOJ4066:简单题——题解
    洛谷4357 & BZOJ4520:[CQOI2016]K远点对——题解
    洛谷4320:道路相遇——题解
  • 原文地址:https://www.cnblogs.com/FEIIEF/p/12365953.html
Copyright © 2011-2022 走看看