目录IO 2月19日学习笔记

news2024/11/24 17:02:06

 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.coloradmin.cn/o/1457461.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++ 浮点数二分 数的三次方根

给定一个浮点数 n &#xff0c;求它的三次方根。 输入格式 共一行&#xff0c;包含一个浮点数 n 。 输出格式 共一行&#xff0c;包含一个浮点数&#xff0c;表示问题的解。 注意&#xff0c;结果保留 6 位小数。 数据范围 −10000≤n≤10000 输入样例&#xff1a; 1000.00…

面试题:链表相交

链表相交 给你两个单链表的头节点 headA 和 headB &#xff0c;请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点&#xff0c;返回 null 。 图示两个链表在节点 c1 开始相交&#xff1a; 思路 这个题目有2个思路&#xff0c;我先说容易想到的思路 对齐链表…

极速提升测试效率:揭秘Web自动化三大等待技巧!

三种等待方式 简介 在实际工作中等待机制可以保证代码的稳定性&#xff0c;保证代码不会受网速、电脑性能等条件的约束。 等待就是当运行代码时&#xff0c;如果页面的渲染速度跟不上代码的运行速度&#xff0c;就需要人为的去限制代码执行的速度。 在做 Web 自动化时&…

Jetpack 之Glance+Compose实现一个小组件

Glance&#xff0c;官方对其解释是使用 Jetpack Compose 样式的 API 构建远程 Surface 的布局&#xff0c;通俗的讲就是使用Compose风格的API来搭建小插件布局&#xff0c;其最新版本是2022年2月23日更新的1.0.0-alpha03。众所周知&#xff0c;Compose样式的API与原生差别不小&…

测试开发【Mock平台】13基础:拦截器服务实现(四) 简单规则匹配逻辑

【Mock平台】为系列测试开发教程&#xff0c;从0到1编码带你一步步使用Spring Boot 和 Antd React框架完成搭建一个测试工具平台&#xff0c;希望作为一个实战项目对各位的测试开发学习之路有帮助&#xff0c;关注公众号发送“mock”获取github项目源码地址&#xff0c;大奇一个…

力扣算法Algorithm竞赛模板库(codeforces-go):含了算法竞赛中常用的数据结构和算法实现,助力开发者更高效地解决问题

1.算法Algorithm竞赛模板库&#xff08;codeforces-go&#xff09; 算法竞赛模板库&#xff0c;为算法竞赛爱好者提供了一系列精心设计的算法模板。这个库包含了算法竞赛中常用的数据结构和算法实现&#xff0c;助力开发者更高效地解决问题 一个算法模板应当涵盖以下几点&…

【C++】【类和对象】初始化列表

1.形式和必用场景 初始化列表&#xff1a;以一个冒号开始&#xff0c;接着是一个以逗号分隔的数据成员列表&#xff0c;每个"成员变量"后面跟一个放在括号中的初始值或表达式。 #include<iostream> using namespace std; class Date { public:Date(int year,…

蓝牙BLE学习-GATT和ATT

1. GATT GATT-Generic Attribute profle-通用属性配置文件。GATT层是传输真正数据所在的层。包括了一个数据传输和存储架构以及其基本操作。GATT用来规范attribute中的数据内容&#xff0c;并运用group&#xff08;分组&#xff09;的概念对attribute进行分类管理。没有GATT&a…

幻兽帕鲁游戏联机的时候,显示“网络连接超时”怎么解决?

如果你在游戏联机的时候&#xff0c;显示“网络连接超时”&#xff0c;可以检查下&#xff1a; 1、前提是你已经按照教程部署成功 2、检查防火墙有没有忘记设置&#xff0c;协议是UDP&#xff08;只有TCP不行&#xff0c;一定要有UDP&#xff09;&#xff0c;端口是否填了8211&…

Vue Suspense

<Suspense> 是一项实验性功能。它不一定会最终成为稳定功能&#xff0c;并且在稳定之前相关 API 也可能会发生变化。 <Suspense> 是一个内置组件&#xff0c;用来在组件树中协调对异步依赖的处理。它让我们可以在组件树上层等待下层的多个嵌套异步依赖项解析完成&a…

cookie封装,使用更方便

cookie封装 当提到"cookie封装"&#xff0c;通常是指在开发中对浏览器cookie的处理进行封装和管理&#xff0c;以简化代码和提高可维护性。在Web开发中&#xff0c;cookie是一种用于存储少量数据的小文件&#xff0c;存储在用户的浏览器中。它们被广泛用于跟踪用户会…

循环结构(含练习题)

当循环次数或范围确定时&#xff0c;多用for循环&#xff0c;反之多用while循环 循环结构一般由四部分组成&#xff1a; 初始化语句&#xff0c;在循环开始最初执行&#xff0c;并且只执行一次条件判断、步进语句、循环体 for & foreach for循环&#xff0c;循环体可以执…

22-k8s中pod的调度-亲和性affinity

一、概述 在k8s当中&#xff0c;“亲和性”分为三种&#xff0c;节点亲和性、pod亲和性、pod反亲和性&#xff1b; 亲和性分类名称解释说明nodeAffinity节点亲和性通过【节点】标签匹配&#xff0c;用于控制pod调度到哪些node节点上&#xff0c;以及不能调度到哪些node节点上&…

MySQL学习记录——십이 事务

文章目录 1、了解事务2、事务提交3、事务隔离级别1、隔离性和隔离级别2、查看、设置隔离级别3、读未提交4、读提交5、可重复读6、串行化7、总结 4、事务一致性5、事务隔离性1、隐藏字段2、undo日志3、模拟MVCC4、Read View 6、读提交RC、可重复读RR的区别 1、了解事务 MySQL内…

【C语言必刷题】3.二分查找

&#x1f4da;博客主页&#xff1a;爱敲代码的小杨. ✨专栏&#xff1a;《Java SE语法》 | 《数据结构与算法》 | 《C生万物》 ❤️感谢大家点赞&#x1f44d;&#x1f3fb;收藏⭐评论✍&#x1f3fb;&#xff0c;您的三连就是我持续更新的动力❤️ &#x1f64f;小杨水平有…

成功靠运气还是能力?我写了一个运气模拟器,告诉给你答案

前端训练营&#xff1a;1v1私教&#xff0c;终身辅导计划&#xff0c;帮你拿到满意的 offer。 已帮助数百位同学拿到了中大厂 offer。欢迎来撩~~~~~~~~ 视频版可直接访问&#xff1a;https://www.bilibili.com/video/BV1ct421b7Q7/?vd_source391a8dc379e0da60c77490e3221f097a…

oauthlib,一个强大的 Python 身份校验库!

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站零基础入门的AI学习网站~。 目录 ​编辑 前言 什么是 OAuthLib&#xff1f; 安装 OAuthLib OAuthLib 的主要功能 OAuthLib 的用法 实现…

自己动手写编译器:使用 PDA 实现增强和属性语法的解析

在前面章节中我们了解了增强语法和属性语法&#xff0c;特别是看到了这两种语法的结合体&#xff0c;本节我们看看如何使用前面我们说过的自顶向下自动机来实现这两种语法结合体的解析&#xff0c;这里使用的方法也是成熟编译器常用的一种语法解析算法。 首先我们先给出上一节…

区块链金融科技:技术融合与挑战应对【文末送书-16】

文章目录 前言一.区块链与金融科技的融合&#xff1a;革新金融格局的技术之光1.1区块链技术简介1.2 区块链在金融科技中的应用 二.智能合约2.1 去中心化金融&#xff08;DeFi&#xff09;2.2区块链对金融科技的影响2.3数据安全性 三.区块链与金融科技【文末送书-16】3.1 粉丝福…

如何训练Ai把古诗《如梦令》描写的意境画出来?

常记溪亭日暮&#xff0c;沉醉不知归路。兴尽晚回舟&#xff0c;误入藕花深处。争渡&#xff0c;争渡&#xff0c;惊起一滩鸥鹭。 古诗《如梦令》以其优美的语言和丰富的意境给人留下深刻的印象。今天&#xff0c;我们将借助AI的力量&#xff0c;将这首诗的意境转化为视觉画面…