目录IO 2月19日学习笔记

news/发布时间2024/5/14 16:48:40

 1. lseek
       off_t lseek(int fd, off_t offset, int whence);
       功能:
            重新设定文件描述符的偏移量
       参数:
            fd:文件描述符
            offset:偏移量
            whence:
                SEEK_SET    文件开头
                SEEK_CUR    文件当前位置
                SEEK_END    文件末尾
       返回值:
            成功返回当前偏移量
            失败返回-1 

 1.mkdir 


      int mkdir(const char *pathname, mode_t mode);
      功能:
        创建目录文件
      参数:
        pathname:文件路径
        mode:文件的权限
      返回值:
        成功返回0 
        失败返回-1 

        rwx rwx rwx
        111 111 111
        0777

        r: 目录中是否能够查看文件
        w: 目录中是否能够新建文件
        x: 目录是否能够进入

   2.rmdir


      int rmdir(const char *pathname);
      功能:
        删除空目录文件,rmdir 函数只能删除空目录。如果目录中还包含有其他文件或子目录,
        则不能直接使用 rmdir 函数来删除,需要使用其他相关的函数或命令来删除非空目录。
      返回值:
        成功返回0 
        失败返回-1 

#include "head.h"int main(void)
{mkdir("dir", 0777);rmdir("dir");return 0;
}

   3.opendir


      DIR *opendir(const char *name);
      功能:
        打开目录获得目录流指针
      参数:
        name:目录文件路径
      返回值:
        成功返回目录流指针
        失败返回NULL

  4.closedir


      int closedir(DIR *dirp);
      功能:
        关闭目录流指针


    5.readdir


      struct dirent   *readdir(DIR *dirp);
      功能:
        从目录流中读取下一个目录项的结构体信息
      参数:
        dirp:目录流指针
      返回值:
        成功返回包含目录项信息的空间首地址
        失败返回NULL
        读到文件末尾返回NULL

        struct dirent {
            ino_t          d_ino;       /* Inode number */
            off_t          d_off;       /* Not an offset; see below */
            unsigned short d_reclen;    /* Length of this record */
            unsigned char  d_type;      /* Type of file; not supported
                                            by all filesystem types */
            char           d_name[256]; /* Null-terminated filename */
        };

 

  • ino_t d_ino:表示目录条目的 inode 号。
  • off_t d_off:表示目录条目在目录中的偏移。
  • unsigned short d_reclen:表示目录条目的长度。
  • unsigned char d_type:表示目录条目的类型。
  • char d_name[]:表示目录条目的名称。

 

int main(void)
{
    DIR *dp = NULL;   
    struct dirent *pp = NULL;  // 定义一个 dirent 结构体指针 pp,并初始化为 NULL

    dp = opendir("dir");    //打开名为 “dir” 的目录,并将返回的目录流指针赋给 dp
    if (NULL == dp)
    {
        perror("fail to opendir");
        return -1;
    }

    while (1)
    {
        pp = readdir(dp);    //读取当前目录流 dp 指向的文件或子目录,并将结果存储在 pp 中
        if (NULL == pp)
        {
            break;
        }

        if ('.' == *pp->d_name)//检查当前读取到的文件或子目录的名称是否以 ‘.’ 开头,如果                                                 //     是,则表示是当前目录(“.”)或父目录(“…”),需要跳过。
        {
            continue;
        }

        printf("%s/%s\n", "dir", pp->d_name);   //打印当前目录下的文件或子目录的完整路径,                                                                格式为 “dir/文件名”。
    }

    closedir(dp);

    return 0;
}
 

 

 6.chdir 


      int chdir(const char *path);
      功能:
        切换当前代码的工作路径

在上一级创建一个名为 dirname 的目录 

#include "head.h"int main(void)
{chdir("..");mkdir("dirname", 0777);return 0;
}

 7.getcwd


      char *getcwd(char *buf, size_t size);
      功能:
        获得当前目录的绝对路径

#include "head.h"int main(void)
{char tmpbuff[4096] = {0};getcwd(tmpbuff, sizeof(tmpbuff));printf("tmpbuff = %s\n", tmpbuff);chdir("..");   getcwd(tmpbuff, sizeof(tmpbuff));  //获取上级目录的路径printf("tmpbuff = %s\n", tmpbuff);return 0;
}

 8.access 


      int access(const char *pathname, int mode);
      功能:
        检测调用函数的程序对文件是否拥有指定权限
      参数:
        pathname:文件路径
        mode:
            R_OK    检测是否拥有读权限
            W_OK    检测是否拥有写权限
            X_OK    检测是否拥有执行权限
            F_OK    检测文件是否存在
      返回值:
        有该权限返回0
        出错返回-1 

#include "head.h"int main(int argc, const char *argv[])
{int ret = 0;if (argc != 2){fprintf(stderr, "Usage:./a.out filename\n");return -1;}ret = access(argv[1], F_OK);if (0 == ret){printf("该文件存在!\n");}else {printf("该文件不存在!\n");}return 0;
}

用迭代的方法获取指定目录下的所以文件的文件名

递归遍历指定目录下的所有文件和子目录,并输出它们的完整路径

#include "head.h"

int ListDir(const char *pdirname)   //定义了一个名为 ListDir 的函数,用于递归遍历目录
{
    DIR *dp = NULL;
    struct dirent *pp = NULL;
    char tmpbuff[4096] = {0};   //定义一个大小为 4096 的字符数组 tmpbuff,用于临时存储拼接后的路径。

    dp = opendir(pdirname);    //打开参数传入的目录 pdirname,并将返回的目录流指针赋给 dp。
    if (NULL == dp)
    {
        perror("fail to opendir");
        return -1;
    }

    while (1)
    {
        pp = readdir(dp);
        if (NULL == pp)
        {
            break;
        }

        if ('.' == pp->d_name[0])    //检查当前读取到的文件或子目录的名称是否以 ‘.’ 开头,如果是,则表示是当前目录(“.”)或父目录(“…”),需要跳过。
        {
            continue;
        }

        sprintf(tmpbuff, "%s/%s", pdirname, pp->d_name);          //将目录名和当前文件(或子目录)名拼接成完整路径,存储在 tmpbuff 中。
        printf("%s\n", tmpbuff);

        if (pp->d_type == DT_DIR)      //判断当前文件或子目录的类型是否为目录
        {
            ListDir(tmpbuff);
        }
    }

    closedir(dp);

    return 0;
}

int main(int argc, const char *argv[])        //定义程序入口函数 main,接收命令行参数
{
    if (argc != 2)                                 //检查命令行参数数量,如果参数个数不为 2(包括程序名和目录名),则输出错误提示。
    {
        fprintf(stderr, "Usage:./a.out dirname\n");
        return -1;
    } 

    ListDir(argv[1]);         //调用 ListDir 函数,传入命令行参数指定的目录名,开始遍历目录

    return 0;
}

#include "head.h"int ListDir(const char *pdirname)   //定义了一个名为 ListDir 的函数,用于递归遍历目录
{DIR *dp = NULL;struct dirent *pp = NULL;char tmpbuff[4096] = {0};   //定义一个大小为 4096 的字符数组 tmpbuff,用于临时存储拼接后的路径。dp = opendir(pdirname);    //打开参数传入的目录 pdirname,并将返回的目录流指针赋给 dp。if (NULL == dp){perror("fail to opendir");return -1;}while (1){pp = readdir(dp);if (NULL == pp){break;}if ('.' == pp->d_name[0])    //检查当前读取到的文件或子目录的名称是否以 ‘.’ 开头,如果是,则表示是当前目录(“.”)或父目录(“…”),需要跳过。{continue;}sprintf(tmpbuff, "%s/%s", pdirname, pp->d_name);          //将目录名和当前文件(或子目录)名拼接成完整路径,存储在 tmpbuff 中。printf("%s\n", tmpbuff);if (pp->d_type == DT_DIR)      //判断当前文件或子目录的类型是否为目录{ListDir(tmpbuff);}}closedir(dp);return 0;
}int main(int argc, const char *argv[])        //定义程序入口函数 main,接收命令行参数
{if (argc != 2)                                 //检查命令行参数数量,如果参数个数不为 2(包括程序名和目录名),则输出错误提示。{fprintf(stderr, "Usage:./a.out dirname\n");return -1;} ListDir(argv[1]);         //调用 ListDir 函数,传入命令行参数指定的目录名,开始遍历目录return 0;
}

运行结果: 

9.sprintf 

int sprintf(char *str, const char *format, ...);

 

sprintf() 函数的工作方式与 printf() 函数类似,但输出结果不是打印到标准输出,而是存储在 str 中。 

#include <stdio.h>int main() {char buffer[100];int num = 10;float pi = 3.14159;// 将格式化的字符串存储到字符数组 buffer 中sprintf(buffer, "Number: %d, PI: %.2f", num, pi);// 打印结果printf("%s\n", buffer);return 0;
}
Number: 10, PI: 3.14

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.bcls.cn/AMDb/1818.shtml

如若内容造成侵权/违法违规/事实不符,请联系编程老四网进行投诉反馈email:xxxxxxxx@qq.com,一经查实,立即删除!

相关文章

使用 Coze 搭建 TiDB 助手

导读 本文介绍了使用 Coze 平台搭建 TiDB 文档助手的过程。通过比较不同 AI Bot 平台&#xff0c;突出了 Coze 在插件能力和易用性方面的优势。文章深入讨论了实现原理&#xff0c;包括知识库、function call、embedding 模型等关键概念&#xff0c;最后成功演示了如何在 Coze…

单片机学习笔记---红外遥控红外遥控电机调速(完结篇)

目录 低电平触发中断和下降沿触发中断的区别 红外遥控 Int0.c Int.h Timer0.c Timer0.h IR.c IR.h main.c 红外遥控电机调速 Timer1.c Timer.h Motor.c Motor.h main.c 上一节讲了红外发送和接收的工作原理&#xff0c;这一节开始代码演示&#xff01; 提前说…

启迪灵感:大广赛获奖作品赏析

2024年第16届全国大学生广告艺术大赛即将到来&#xff01;自2005年第一届以来&#xff0c;共成功举办了14届15届比赛&#xff0c;共有1869所大学参加&#xff0c;100多万学生提交作品&#xff0c;学生可以积极参与哦&#xff0c;作品分为平面、视频、动画、互动、广播、策划、文…

XMall 开源商城 SQL注入漏洞复现(CVE-2024-24112)

0x01 产品简介 XMall 开源电商商城 是开发者Exrick的一款基于SOA架构的分布式电商购物商城 前后端分离 前台商城:Vue全家桶 后台管理:Dubbo/SSM/Elasticsearch/Redis/MySQL/ActiveMQ/Shiro/Zookeeper等。 0x02 漏洞概述 XMall 开源商城 /item/list、/item/listSearch、/sys/…

软件项目整个项目生命周期所需文件,全套文档下载

一个软件项目从开始到结束需要一系列的文档来支撑&#xff0c;这些文档用于记录、规划、设计、测试、维护和管理软件项目。以下是一个软件项目从开始到结束可能需要的部分文档列表&#xff1a; 项目计划书/立项报告&#xff1a;描述项目的目标、范围、预期成果、资源需求、时间…

基于STL的演讲比赛流程管理系统(个人学习笔记黑马学习)

1、演讲比赛程序需求 1.1比赛规则 学校举行一场演讲比赛&#xff0c;共有12个人参加。比赛共两轮&#xff0c;第一轮为淘汰赛&#xff0c;第二轮为决赛。每名选手都有对应的编号&#xff0c;如 10001~10012比赛方式:分组比赛&#xff0c;每组6个人;第一轮分为两个小组&#xff…

stable diffusion webui学习总结(2):技巧汇总

一、脸部修复&#xff1a;解决在低分辨率下&#xff0c;脸部生成异常的问题 勾选ADetailer&#xff0c;会在生成图片后&#xff0c;用更高的分辨率&#xff0c;对于脸部重新生成一遍 二、高清放大&#xff1a;低分辨率照片提升到高分辨率&#xff0c;并丰富内容细节 1、先通过…

unity学习(16)——服务器组装(3)命名空间问题

using GameServer.logic; using GameServer.NetModel; 代码中这两句存在命名空间的引用问题&#xff0c;c#和c不一样&#xff0c;用的的using和命名空间&#xff0c;之前的惯性思维都是include和文件路径。 错误&#xff1a;直接把逆向文件夹粘到项目文件夹中&#xff0c;这样…

什么是CODESYS开发系统

CODESYS是一种用于工业自动化领域的开发系统软件&#xff0c;提供了一个完整集成的开发环境。该软件由德国CODESYS GmbH&#xff08;原 3S-Smart Software Solutions GmbH&#xff09;公司开发&#xff0c;其最新版本为CODESYS V3。 CODESYS开发系统具有多种特性和优点。首先&a…

PHP分析二维数据表(长度|数字字段|空值|纯姓名|英文用户名|科学计数|是否等长|是否唯一)

先看图&#xff0c;后有完整代码 <?php $t "Excel数据转Sql查询系统字段半智能分析"; $s "Excel复制过来的二维结构表内容,分析查询条件&#xff01;"; $x "字段|最大长度|长度有|数字字段|空值存在|纯姓名|英文用户名|科学计数|是否等长|是否…

3D人体姿态估计(教程+代码)

3D人体姿态估计是指通过计算机视觉技术和深度学习算法&#xff0c;从图像或视频数据中准确地推测出人体的三维姿态信息&#xff0c;包括关节位置、角度和运动轨迹等。这项技术在虚拟现实、增强现实、运动分析、人体动作捕捉等领域具有广泛的应用前景。 实现3D人体姿态估计的关…

如何在Ubuntu部署Emlog,并将本地博客发布至公网可远程访问

文章目录 前言1. 网站搭建1.1 Emolog网页下载和安装1.2 网页测试1.3 cpolar的安装和注册 2. 本地网页发布2.1 Cpolar临时数据隧道2.2.Cpolar稳定隧道&#xff08;云端设置&#xff09;2.3.Cpolar稳定隧道&#xff08;本地设置&#xff09; 3. 公网访问测试总结 前言 博客作为使…

计算机网络Day1--计算机网络体系

1.三网合一 电信网络、广播电视网络、计算机网络&#xff08;最基础最重要发展最快&#xff09; 2.Internet 名为国际互联网、因特网&#xff0c;指当前全球最大的、开放的、由众多网络相互连接而成的特定互连网&#xff0c;采用TCP/IP 协议族作为通信的规则&#xff0c;前…

IDEA实现ssh远程连接本地Linux服务器

文章目录 1. 检查Linux SSH服务2. 本地连接测试3. Linux 安装Cpolar4. 创建远程连接公网地址5. 公网远程连接测试6. 固定连接公网地址7. 固定地址连接测试 本文主要介绍如何在IDEA中设置远程连接服务器开发环境&#xff0c;并结合Cpolar内网穿透工具实现无公网远程连接&#xf…

Golang for 循环

从基础知识到高级技术、并发和通道 Go&#xff08;Golang&#xff09;编程语言中的“for”循环是一个基本而多功能的结构&#xff0c;用于迭代集合、重复执行代码块以及管理循环控制流。Golang的“for”循环语法简洁却强大&#xff0c;为处理多样的循环场景提供了一系列能力。无…

RSA之前端加密后端解密

RSA之前端加密后端解密 RSA加密解密方式有&#xff1a; &#xff08;1&#xff09;公钥加密&#xff0c;私钥解密&#xff1b; &#xff08;2&#xff09;私钥加密&#xff0c;公钥解密&#xff1b; 此文章中以下我使用的是前端公钥加密&#xff0c;后端私钥解密&#xff1b; …

重复导航到当前位置引起的。Vue Router 提供了一种机制,阻止重复导航到相同的路由路径。

代码&#xff1a; <!-- 侧边栏 --><el-col :span"12" :style"{ width: 200px }"><el-menu default-active"first" class"el-menu-vertical-demo" select"handleMenuSelect"><el-menu-item index"…

SQL中的各种连接的区别总结

前言 今天主要的内容是要讲解SQL中关于Join、Inner Join、Left Join、Right Join、Full Join、On、 Where区别和用法&#xff0c;不用我说其实前面的这些基本SQL语法各位攻城狮基本上都用过。但是往往我们可能用的比较多的也就是左右连接和内连接了&#xff0c;而且对于许多初学…

【Qt】环境安装与初识

目录 一、Qt背景介绍 二、搭建Qt开发环境 三、新建工程 四、Qt中的命名规范 五、Qt Creator中的快捷键 六、QWidget基础项目文件详解 6.1 .pro文件解析 6.2 widget.h文件解析 6.3 widget.cpp文件解析 6.4 widget.ui文件解析 6.5 main.cpp文件解析 七、对象树 八、…

蓝桥杯备赛_python_BFS搜索算法_刷题学习笔记

1 bfs广度优先搜索 1.1 是什么 1.2怎么实现 2案例学习 2.1.走迷宫 2.2.P1443 马的遍历 2.3. 九宫重排&#xff08;看答案学的&#xff0c;实在写不来&#xff09; 2.4.青蛙跳杯子&#xff08;学完九宫重排再做bingo&#xff09; 2.5. 长草 3.总结 1 bfs广度优先搜索 【P…
推荐文章