LINUX系统API---操作目录

简介: LINUX系统API---操作目录

C++程序员必会的知识


目录操作函数

  • int mkdir(const char *pathname,mode_t mode);       //创建一个目录
#include <stdio.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <fcntl.h> 
int main(){
    int res = mkdir("mkdirDemo",0777);
    if(res == -1){
        perror("mkdir");
        return 0;
    }
    printf("mkdir sucessful\n");
    return 0;
}

参数: pathname-->目录的路径(名称)

mode-->表示目录的权限,八进制数(实际权限mode & umask & 0777)

返回值:成功返回0,失败返回-1

注:umask称为掩码,通常是用来显示某些权限,防止误操作,umask操作系统规定已经规定好了。

  • int rmdir(const char *pathname) ;//只能删除一个空目录

参数: pathname-->目录的路径(名称)

返回值:成功返回0,失败返回-1

#include <unistd.h>
#include <stdio.h>
int main(){
    int res = rmdir("mkdirDemo");
    if(res == -1){
        perror("rmdir");
        return 0;
    }
      printf("rmdir sucessful\n");
    return 0;
}
  • int rename(const char * oldpath,const char *newpath);   //重命名

参数: oldpath-->旧文件名      newpath--->新文件名

返回值:成功返回0,失败返回-1

#include <stdio.h>
int main(){
    int res = rename("mkdirDemo", "newmkdir");
    if(res == -1){
        perror("rename");
        return 0;
    }
      printf("rename sucessful\n");
    return 0;
}
  • int chdir(cosnt char*path)   //修改当前进程的工作目录,这个经常用到(eg:创建守护进程)

参数: path-->目录名

返回值:成功返回0,失败返回-1

#include <unistd.h>
#include <stdio.h>
int main(void){
    int res = chdir("/home/chen");
    if(res == -1){
        perror("chdir");
        return 0;
    }
      printf("chdir sucessful\n");
    return 0;
}
  • char *getcwd(char *buf,size_t size);  //获取当前进程的工作目录

参数:buf-->传出参数,保存当前的工作目录    size-->buf的大小

         注:我们在写API时,通常都是提供一个首地址和长度

返回值:成功 返回指向的一块内存,其实就是指向buf

               失败返回NULL

#include <unistd.h>
#include <stdio.h>
#include <string.h>
int main(){
    char buf[1024] = {0};
    if(getcwd(buf,sizeof(buf))==NULL){
        perror("getcwd");
        return 0;
    }else{
        printf("%s\n",buf);
    }
    chdir("/home/chen");
    memset(buf,0,sizeof(buf));
    if(getcwd(buf,sizeof(buf))==NULL){
        perror("getcwd");
        return 0;
    }else{
        printf("%s\n",buf);
    }
    return 0;
}

目录的遍历函数

  • DIR * opendir(const char *name);      //打开目录
  • struct dirent *readdir(DIR *dirp);        //读目录
  • int  closedir(DIR *dirp);                      //关闭目录

DIR:一个目录结构指针,类似于FILE结构指针。保存着一些目录的信息。

dirent:是一个结构体

      struct dirent{

               ino_t  d_ino;       //此目录的进入节点

               ff_t     d_off;        //目录文件开头至此目录进入点的位移

               signed short int d_reclen;   //d_name的长度

               unsigned char d_type;    //d_name所指向的文件类型

               char   d_name[256];     //文件名,256

       }

       t_type:指向的很多宏定义,代表不同类型的文件

DT_BLK  块文件             DT_CHR  字符设备
DT_DIR  目录               DT_LNK  软链接
DT_FIFO 管道               DT_REG  普通文件
DT_SOCK 套接字             DT_UNKONW  未知

       目录函数小实践(递归获取文件的个数)

#include <stdio.h>
#include <sys/types.h>
#include <dirent.h>
#include <stdlib.h>
#include <dirent.h>
#include <string.h>
int getFileCount(const char *root){
    //打开一个目录,得到DIR*
    DIR *dir = opendir(root);
    if(dir == NULL){
        perror("opendir");
        exit(0);
    }
    struct dirent* resRead = NULL;
    char buf[1024] = {0};
    int total = 0;
    while ((resRead = readdir(dir)) != NULL)//打开一个目录中会有很多条记录的
    {
        //过滤掉 .   ..   避免死循环
        if(strcmp(resRead->d_name,".")==0 || strcmp(resRead->d_name,"..")==0){
            continue;
        }
        if(resRead->d_type == DT_DIR){//是子目录
            sprintf(buf,"%s/%s",root,resRead->d_name);
            total += getFileCount("buf");
        }else if(resRead->d_type == DT_REG){//普通文件
            total++;
        }else{
            continue;
        }
    }
    //关闭目录
    int res = closedir(dir);
    if(res == -1){
        perror("closedir");
         exit(-1);
    }
    return total;
}
int main(int argc,char *argv[]){
    //判断终端输入参数
    if(argc < 2){
        printf("%s dirname\n",argv[0]);
        exit(0);
    }
    //读取目录-->因为目录里面可能还要子目录,像一颗树,所以我们可以用递归
    int total = getFileCount(argv[1]);
    printf("%s has %d file\n",argv[1],total);
    return 0;
}
相关文章
|
1月前
|
存储 Linux
Linux 目录名称
Linux系统目录结构简介:根目录(/)下包含各类功能目录,如/bin存放用户命令,/etc存储配置文件,/home为用户主目录,/var记录日志等可变数据,/usr存放用户工具,/tmp用于临时文件。各目录分工明确,保障系统有序运行。(238字)
201 5
|
2月前
|
Ubuntu Linux Anolis
Linux系统禁用swap
本文介绍了在新版本Linux系统(如Ubuntu 20.04+、CentOS Stream、openEuler等)中禁用swap的两种方法。传统通过注释/etc/fstab中swap行的方式已失效,现需使用systemd管理swap.target服务或在/etc/fstab中添加noauto参数实现禁用。方法1通过屏蔽swap.target适用于新版系统,方法2通过修改fstab挂载选项更通用,兼容所有系统。
207 3
Linux系统禁用swap
|
2月前
|
Linux
Linux系统修改网卡名为eth0、eth1
在Linux系统中,可通过修改GRUB配置和创建Udev规则或使用systemd链接文件,将网卡名改为`eth0`、`eth1`等传统命名方式,适用于多种发行版并支持多网卡配置。
287 3
|
Ubuntu Linux 网络安全
Linux系统初始化脚本
一款支持Rocky、CentOS、Ubuntu、Debian、openEuler等主流Linux发行版的系统初始化Shell脚本,涵盖网络配置、主机名设置、镜像源更换、安全加固等多项功能,适配单/双网卡环境,支持UEFI引导,提供多版本下载与持续更新。
273 0
Linux系统初始化脚本
|
3月前
|
运维 Linux 开发者
Linux系统中使用Python的ping3库进行网络连通性测试
以上步骤展示了如何利用 Python 的 `ping3` 库来检测网络连通性,并且提供了基本错误处理方法以确保程序能够优雅地处理各种意外情形。通过简洁明快、易读易懂、实操性强等特点使得该方法非常适合开发者或系统管理员快速集成至自动化工具链之内进行日常运维任务之需求满足。
219 18
|
2月前
|
安全 Linux Shell
Linux系统提权方式全面总结:从基础到高级攻防技术
本文全面总结Linux系统提权技术,涵盖权限体系、配置错误、漏洞利用、密码攻击等方法,帮助安全研究人员掌握攻防技术,提升系统防护能力。
261 1
|
2月前
|
监控 安全 Linux
Linux系统提权之计划任务(Cron Jobs)提权
在Linux系统中,计划任务(Cron Jobs)常用于定时执行脚本或命令。若配置不当,攻击者可利用其提权至root权限。常见漏洞包括可写的Cron脚本、目录、通配符注入及PATH变量劫持。攻击者通过修改脚本、创建恶意任务或注入命令实现提权。系统管理员应遵循最小权限原则、使用绝对路径、避免通配符、设置安全PATH并定期审计,以防范此类攻击。
958 1
|
2月前
|
算法 API 数据库
生鲜电商技术实践:基于保质期API的自动下架系统保障食品安全
基于保质期提醒API与自动化工作流,实现生鲜商品临期智能预警与自动下架。通过设定差异化预警阈值(如蔬菜2天、冷冻品7天),每日扫描数据库并触发下架指令,确保食品安全合规,降低损耗与客诉,提升运营效率。
234 0
|
3月前
|
缓存 监控 Linux
Linux系统清理缓存(buff/cache)的有效方法。
总结而言,在大多数情形下你不必担心Linux中buffer与cache占用过多内存在影响到其他程序运行;因为当程序请求更多内存在没有足够可用资源时,Linux会自行调整其占有量。只有当你明确知道当前环境与需求并希望立即回收这部分资源给即将运行重负载任务之前才考虑上述方法去主动干预。
1499 10
|
3月前
|
安全 Linux 数据安全/隐私保护
为Linux系统的普通账户授予sudo访问权限的过程
完成上述步骤后,你提升的用户就能够使用 `sudo`命令来执行管理员级别的操作,而无需切换到root用户。这是一种更加安全和便捷的权限管理方式,因为它能够留下完整的权限使用记录,并以最小权限的方式工作。需要注意的是,随意授予sudo权限可能会使系统暴露在风险之中,尤其是在用户不了解其所执行命令可能带来的后果的情况下。所以在配置sudo权限时,必须谨慎行事。
550 0