Linux之文件操作

目录

第1关:文件的创建

任务描述

相关知识

文件的创建

编程要求

答案:

第2关:文件打开与关闭

任务描述

相关知识

文件的打开

文件的关闭

编程要求

答案: 

 第3关:文件读写操作

任务描述

相关知识

文件的写操作

文件的读操作

编程要求

答案: 

 第4关:文件的删除

任务描述

相关知识

使用unlink函数删除文件

使用unlink函数删除文件

编程要求

答案: 


第1关:文件的创建

任务描述

在Linux系统中,如果要对一个文件进行操作,首先要求文件已经存在,如果文件不存在,则需要创建文件。

本关任务:学会使用C语言在Linux系统中创建文件操作。

相关知识

文件的创建操作是 I/O 操作的第一步。在Linux系统中creat系统调用可以实现对文件的创建。本关只介绍文件创建函数的使用方法。

在Linux系统中可以使用man命令来查询这些函数的使用方法。具体的查询命令为: man 2 函数名 其中,2表示查找系统调用函数,关于文件的创建、打开和关闭函数都是系统调用函数,因此使用2作为man命令的第一个参数。

案例演示1: 查询creat函数的使用方法可以使用以下命令: man 2 creat

[查询结果]

通过man命令可以查询常用的系统调用函数的使用方法。

文件的创建

创建文件的系统调用函数是creat,具体的说明如下:

需要的头文件如下:

#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>

函数格式如下: int creat (const char *pathname,mode_t mode); 参数说明:

pathname:需要创建文件的绝对路径名或相对路径名;
mode:用于指定所创建文件的权限;

常见的mode取值及其含义见下表所示:

mode含义
S_IRUSR文件所有者的读权限位
S_IWUSR文件所有者的写权限位
S_IXUSR文件所有者的执行权限位
S_IRGRP所有者同组用户的读权限位
S_IWGRP所有者同组用户的写权限位
S_IXGRP所有者同组用户的执行权限位
S_IROTH其他用户的读权限位
S_IWOTH其他用户的写权限位
S_IXOTH其他用户的执行权限位

函数返回值说明: 调用成功时,返回值为 文件的描述符(大于0的整数);调用失败时,返回值为-1并设置错误编号errno

案例演示1: 在当前目录下使用creat函数创建一个名为firstFile的文件,并设置文件的权限为644。详细代码如下所示:

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
int main()
{
    int ret = creat("firstFile", S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH);
    if (ret == -1)
    {
        printf("创建文件失败\n");
    }
    else
    {
        printf("创建文件成功\n");
    }
    
    return 0;
}

将以上代码保存为main.c文件中,编译执行。可以看到当前目录下存在firstFile文件,并且其权限为644

编程要求

本关的编程任务是补全右侧代码片段中BeginEnd中间的代码,具体要求如下:

在当前目录下创建一个名为testFile的文件,并设置其权限为651

答案:

 

#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdio.h>

int main()
{
    /********** BEGIN **********/

    creat("testFile", S_IRUSR|S_IWUSR |S_IRGRP|S_IXGRP|S_IXOTH);

    /********** END **********/

    return 0;
}

第2关:文件打开与关闭

 

任务描述

在Linux系统中,如果要对一个文件进行操作,操作前需要将这个文件打开。这样才能实现对该文件的操作。

本关任务:学会使用C语言在Linux系统中打开与关闭文件操作。

相关知识

文件的打开与关闭操作是 I/O 操作的第二步。在Linux系统中提供了以下两个系统调用函数用于打开和关闭文件操作,分别是openclose。本关将介绍文件的打开和关闭函数的使用方法。

使用man 2 函数名也可以查询这些函数的使用方法。

文件的打开

打开文件的系统调用函数是open,具体的说明如下:

需要的头文件如下:

#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>

函数格式如下:

int open(coust char *pathname, int flags);
int open(const char *pathname, int flags, made_t mode);

参数说明:

pathname:需要被打开或创建的文件绝对路径名或相对路径名;
flags:用于描述文件的打开方式;
mode:用于指定所创建文件的权限(与上一关中creat函数中mode取值一致);

第一个open函数用于打开已经存在的文件。而第二个open函数可以创建一个不存在的文件且打开,该函数将flags参数设置为O_CREAT | O_WRONLY | O_TRUNC时等同于上一关中的creat函数。

常见的flags取值及其含义见下表所示:

flags含义
O_RDONLY 以只读方式打开文件
O_WRONLY以只写方式打开文件
O_RDWY以只读写方式打开文件
O_CREAT若所打开文件不存在则创建此文件
O_TRUNC若以只写或读写方式打开一个已存在文件时,将该文件截至 0
O_APPEND向文件添加内容时将指针置于文件的末尾
O_SYNC只在数据被写外存或其他设备之后操作才返回

函数返回值说明: 调用成功时,返回值为 文件的描述符(大于0的整数);调用失败时,返回值为-1并设置错误编号errno

案例演示1: 在当前目录下使用open函数以只读方式打开一个已存在且名为firstFile的文件。详细代码如下所示:

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
int main()
{
    int ret = open("firstFile", O_RDONLY);
    if (ret == -1)
    {
        printf("打开文件失败\n");
    }
    else
    {
        printf("打开文件成功\n");
    }
    
    return 0;
}

将以上代码保存为openFile.c文件中,编译执行。

案例演示2: 在当前目录下使用open函数创建一个名为secondFile的文件,并设置文件的权限为644。详细代码如下所示:

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
int main()
{
    int ret = open("secondFile", O_CREAT | O_WRONLY | O_TRUNC, S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH);
    if (ret == -1)
    {
        printf("创建文件失败\n");
    }
    else
    {
        printf("创建文件成功\n");
    }
    
    return 0;
}

将以上代码保存为secondFile.c文件中,编译执行。可以看到当前目录下存在secondFile文件,并且其权限为644

文件的关闭

关闭文件的系统调用函数是close,具体的说明如下:

需要的头文件如下:

#include <unistd.h>

函数格式如下: int close(int fd);

参数说明:

fd:需关闭文件的描述符;

函数返回值说明: 调用成功时,返回值为 0;调用失败时,返回值为-1,并设置错误编号errno
案例演示1: 在当前目录下使用close函数关闭一个已经被打开的文件。详细代码如下所示:

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
int main()
{
    int fd = open("firstFile", O_RDONLY);
    if (fd == -1)
    {
        printf("打开文件失败\n");
    }
    else
    {
        printf("打开文件成功\n");
    }
    
    int ret = close(fd);
    if(ret == -1)
    {
        printf("关闭文件失败\n");
    }
    else
    {
        printf("关闭文件成功\n");
    }
    
    return 0;
}

将以上代码保存为closeFile.c文件中,编译执行。

 

编程要求

本关的编程任务是补全右侧代码片段中BeginEnd中间的代码,具体要求如下:

补全open_File函数,使其以方式打开一个文件,并返回文件描述符fd

补全close_File函数,使其关闭一个已经被打开的文件。

答案: 
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdio.h>

/************************
 * fileName: 需要被打开的文件路径
*************************/
int open_File(char *fileName)
{
	int fd = 0;   //存放文件描述符
	/********** BEGIN **********/
	fd=open(fileName,O_RDONLY);
	/********** END **********/

	return fd;
}

/************************
 * fd: 需要被关闭的文件描述符
*************************/
void close_File(int fd)
{
	/********** BEGIN **********/
	close(fd);
	
	/********** END **********/
}

 第3关:文件读写操作

 

任务描述

通过上一关的学习,我们学会了如何使用C语言来打开和关闭文件,本关将继续介绍对文件的读写操作。

本关任务:学会使用C语言在Linux系统中对文件进行读写操作。

相关知识

文件的读写是 I/O 操作的核心内容。上一关中已经介绍了如何打开和关闭一个文件,但是要实现文件的 I/O 操作就必须对其进行读写,文件的读写操作所用的系统调用分别是readwrite。本关将介绍文件的读写函数的使用方法。

使用man 2 函数名也可以查询这些函数的使用方法。

文件的写操作

写入文件的系统调用函数是write,具体的说明如下:

需要的头文件如下:

#include <unistd.h>

函数格式如下: ssize_t write(int fd, void *buf, size_t count);

参数说明:

fd:表示将对之进行写操作的文件打开时返回的文件描述符;
buf:指向存放将写入文件的数据的缓冲区的指针;
count:表示本次操作所要写入文件的数据的字节数;

函数返回值说明: 调用成功时,返回值为所写入的字节数;调用失败时,返回值为-1并设置错误编号errno

案例演示1: 在当前目录下往firstFile文件中写入一个字符串。详细代码如下所示:

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <string.h>
int main()
{
    int fd = open("firstFile", O_WRONLY);
    if (fd == -1)
    {
        printf("打开文件失败\n");
    }
    else
    {
        printf("打开文件成功\n");
    }
    
    char *data = "this is firstFile\n";
    ssize_t size = write(fd, data, strlen(data));
    if(size == -1)
    {
        printf("写入文件失败\n");
    }
    else
    {
        printf("写入文件成功:写入%ld个字符\n", size);
    }
    
    if(close(fd) == -1)
    {
        printf("关闭文件失败\n");
    }
    else
    {
        printf("关闭文件成功\n");
    }
    
    return 0;
}

将以上代码保存为writeFile.c文件中,编译执行。可以看到字符串被写入到firstFile文件中。

文件的读操作

读取文件的系统调用函数是read,具体的说明如下:

需要的头文件如下:

#include <unistd.h>

函数格式如下: ssize_t read(int fd, void *buf, size_t count);

参数说明:

fd:表示将对之进行写操作的文件打开时返回的文件描述符;
buf:指向存放所读数据的缓冲区的指针;
count:读操作希望读取的字节数;

函数返回值说明: 调用成功时,返回值为本次读操作实际读取的字节数;调用失败时,返回值为-1并设置错误编号errno

案例演示1: 读取当前目录下firstFile文件中的前4个字符。详细代码如下所示:

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <string.h>
int main()
{
    int fd = open("firstFile", O_RDONLY);
    if (fd == -1)
    {
        printf("打开文件失败\n");
    }
    else
    {
        printf("打开文件成功\n");
    }
    
    char data[5] = "";
    ssize_t size = read(fd, data, sizeof(char)*4);
    if(size == -1)
    {
        printf("读取文件失败\n");
    }
    else
    {
        printf("读取文件成功:数据:%s\n", data);
    }
    
    if(close(fd) == -1)
    {
        printf("关闭文件失败\n");
    }
    else
    {
        printf("关闭文件成功\n");
    }
    
    return 0;
}

将以上代码保存为readFile.c文件中,编译执行。可以看到从firstFile文件中读取出了前4个字符。

编程要求

本关的编程任务是补全右侧代码片段中BeginEnd中间的代码,具体要求如下:

补全write_File函数,完成向文件写入字符串功能。并返回实际写入字符个数。

补全readLine函数,完成从文件中读取一行的功能(不包括换行符),并返回实际读取的字符个数(文件的换行符号为\n)。

答案: 
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdio.h>

/************************
 * fd: 被打开文件的描述符
 * buf: 被写入字符串指针
*************************/
int write_File(int fd, char *buf)
{
	int writeSize = 0; //返回实际写入的字符个数

	/********** BEGIN **********/
	writeSize=write(fd,buf,strlen(buf));
	
	/********** END **********/

	return writeSize;
}

/************************
 * fd: 被打开文件的描述符
 * buf: 存放读取的字符串指针(假设buf足够大)
*************************/
int readLine(int fd, char *buf)
{
	int readSize = 0;  //返回实际读取的字符个数
	
	//提示:使用while循环每次只读取一个字符,判断该字符是否为换行符或者是否已经读取到文件末尾(读取到文件末尾返回值为0)
	/********** BEGIN **********/
    char c;
    while(read(fd,&c,1)&&c!='\n')
    {
        buf[readSize++]=c;
    }
	
	/********** END **********/
	
	return readSize;
}

 第4关:文件的删除

任务描述

通过前三关的学习,我们学会了如何使用C语言来创建、打开/关闭和读写文件,本关将介绍如何删除一个已经存在的文件。

本关任务:学会使用C语言在Linux系统中删除文件操作。

相关知识

当不需要一个文件时,我们通常直接选中文件按下delete键对其删除,本关将介绍如何在Linux系统中使用C语言删除一个已经存在的文件。

在Linux系统中使用unlinkremove系统调用可以实现对文件的删除操作。

使用man 2 函数名或者man 3 函数名也可以查询这些函数的使用方法。

使用unlink函数删除文件

删除文件的系统调用函数是unlink,具体的说明如下:

需要的头文件如下:

#include <unistd.h>

函数格式如下:

int unlink(const char *pathname);

参数说明:
 

​​​​​​​pathname:需要删除的文件绝对路径名或相对路径名;
 

函数返回值说明: 调用成功时,返回值为0;调用失败时,返回值为-1并设置错误编号errno

​​​​​​​​​​​​​​

案例演示1:

删除当前目录下的firstFile文件。详细代码如下所示:

 

#include <unistd.h>
#include <stdio.h>
int main()
{
    int ret = unlink("firstFile");
    if (ret == -1)
    {
        printf("删除文件失败\n");
    }
    else
    {
        printf("删除文件成功\n");
    }
    
    return 0;
}

将以上代码保存为deleteFile1.c文件中,编译执行。可以看到当前目录下存在firstFile文件被删除了。

使用unlink函数删除文件

remove是删除文件的另一个函数,该函数是C语言的库函数,其本质是通过调用系统调用unlink来完成文件的删除操作,具体的说明如下:

需要的头文件如下:

#include <stdio.h>

函数格式如下:

int remove(const char *pathname);

参数说明:

pathname:需要删除的文件绝对路径名或相对路径名;

函数返回值说明: 调用成功时,返回值为0;调用失败时,返回值为-1并设置错误编号errno

案例演示1: 删除当前目录下的secondFile文件。详细代码如下所示:

#include <stdio.h>
int main()
{
    int ret = remove("secondFile");
    if (ret == -1)
    {
        printf("删除文件失败\n");
    }
    else
    {
        printf("删除文件成功\n");
    }
    
    return 0;
}

将以上代码保存为deleteFile2.c文件中,编译执行。可以看到当前目录下存在secondFile文件被删除了。

编程要求

本关的编程任务是补全右侧代码片段中BeginEnd中间的代码,具体要求如下:

删除当前目录下的testFile文件。

答案: 
#include <stdio.h>

int main()
{
	/********** BEGIN **********/
    unlink("testFile");
	/********** END **********/

	return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Meta Llama 3 残差结构

Meta Llama 3 残差结构 flyfish 在Transformer架构中&#xff0c;残差结构&#xff08;Residual Connections&#xff09;是一个关键组件&#xff0c;它在模型的性能和训练稳定性上起到了重要作用。残差结构最早由He et al.在ResNet中提出&#xff0c;并被广泛应用于各种深度…

项目-双人五子棋对战:匹配模块的实现(3)

完整代码见: 邹锦辉个人所有代码: 测试仓库 - Gitee.com 模块详细讲解 功能需求 匹配就类似于大家平常玩的王者荣耀这样的匹配功能, 当玩家点击匹配之后, 就会进入到一个匹配队列, 当匹配到足够数量的玩家后, 就会进入确认页. 在这里, 我们主要实现的是1 - 1匹配功能, 首先先…

【Git】分支管理 -- 详解

一、理解分支 分支就是科幻电影里面的平行宇宙&#xff0c;当你正在电脑前努力学习 C 的时候&#xff0c;另一个你正在另一个平行宇宙里努力学习 JAVA。 如果两个平行宇宙互不干扰&#xff0c;那对现在的你也没啥影响。不过&#xff0c;在某个时间点&#xff0c;两个平行宇宙…

ApsaraMQ Copilot for RocketMQ:消息数据集成链路的健康管家

作者&#xff1a;文婷 引言 如何正确使用消息队列保证业务集成链路的稳定性&#xff0c;是消息队列用户首要关心的问题。ApsaraMQ Copilot for RocketMQ 从集成业务稳定性、成本、性能等方面帮助用户更高效地使用产品。 背景 消息队列产品通过异步消息的传递&#xff0c;来…

使用Qt对word文档进行读写

目录 开发环境原理使用的QT库搭建开发环境准备word模板测试用例结果Gitee地址 开发环境 vs2022 Qt 5.9.1 msvc2017_x64&#xff0c;在文章最后提供了源码。 原理 Qt对于word文档的操作都是在书签位置进行插入文本、图片或表格的操作。 使用的QT库 除了基本的gui、core、…

Bond网卡

一、Bond网卡 1.1 Bond网卡概述 Bond网卡是指使用 Linux 系统中的 Bonding 技术创建的虚拟网络接口。 Bonding 技术允许将多个物理网卡&#xff08;也称为接口或端口&#xff09;绑定在一起&#xff0c;形成一个虚拟的网络接口&#xff0c;以增加网络带宽、提高网络容错性和…

【ARM Cache 及 MMU 系列文章 6 -- Cache 寄存器 CTR | CLIDR | CCSIDR | CSSELR 使用详解 1】

文章目录 Cache 常用寄存器Cache CSSELR 寄存器Cache CSSELR 使用场景Cache CSSELR 操作示例 Cache CLIDR 寄存器LoUU 介绍LoUU 使用 LoUIS 介绍CLIDR 使用 Cache CCSIDR 寄存器 Cache 常用寄存器 ARM Cache 常用到寄存器有以下几个&#xff1a; CSSELR, Cache Size Selectio…

VS2022,lib调用dll工程的一个函数

lib工程本身是一个静态库工程&#xff0c;没有链接器设置。然而&#xff0c;我们依然可以在lib工程中调用DLL工程中的函数&#xff0c;只需要确保头文件正确导入&#xff0c;并在最终使用lib的可执行文件项目中正确链接DLL的.lib文件。下面是一个详细的步骤说明&#xff1a; 假…

Windows 宿主机访问 VirtualBox 虚拟机中创建的 docker 容器中的 mysql8.0 的数据

一、场景需求 在开发环境中&#xff0c;一般使用 windows 系统进行开发&#xff0c;但需要在 linux 系统中创建运行 mysql8.0 的 docker 容器中进行测试&#xff08;win10特定版本或win11才能安装 docker&#xff09;&#xff0c;为了方便还需要在 windows 系统中通过 SQLyog …

python ---requests

python包管理工具 pip 若发现报错&#xff0c;则可以通过 -i 命令指定软件源 requests库安装 通过 pip &#xff0c;如上 或通过 pycharm 搜索 requests &#xff0c;并安装即可 下载成功的证明 requests库使用 模拟 http 重要参数如下 如何模拟发包 支持模拟各种 http meth…

前端_防抖节流

目录 一、防抖&#xff08;debounce&#xff09; 1.使用场景 2.js代码实现 3.lodash工具库使用 二、节流&#xff08;throttle&#xff09; 1.使用场景 2.js代码实现 3.lodash工具库使用 前端做项目&#xff0c;为了防止用户因为网络不好数据响应慢&#xff0c;导致进行…

ARM的工作模式

ARM的几种工作模式 User : 非特权模式&#xff0c;大部分任务执行在这种模式 FIQ : 当一个高优先级&#xff08;fast) 中断产生时将会进入这种模式IRQ : 当一个低优先级&#xff08;normal) 中断产生时将会进入这种模式 Supervisor&#xff08;SVC&#xff09; : 当复位或软中断…

利用短视频平台,轻松引流获客:自动私信评论策略全解析

在数字化时代&#xff0c;短视频已成为互联网流量的新蓝海&#xff0c;其独特的视觉吸引力和高度的用户粘性为各行各业提供了前所未有的营销机遇。无论是初创企业还是成熟品牌&#xff0c;都能通过短视频平台有效触达目标客户&#xff0c;实现高效引流与获客。本文将深入探讨如…

高通开发系列 - 借助libhybris库实现Linux系统中使用Andorid库(2)

By: fulinux E-mail: fulinuxsina.com Blog: https://blog.csdn.net/fulinus 喜欢的盆友欢迎点赞和订阅&#xff01; 你的喜欢就是我写作的动力&#xff01; 返回&#xff1a;专栏总目录 目录 参考上一篇文章&#xff1a;高通开发系列 - 借助libhybris库实现Linux系统中使用And…

高并发短视频系统设计:架构、存储与性能优化全解

1. 系统概况与需求分析 1.1 短视频系统简介 当前短视频行业的快速发展&#xff0c;加上用户对高清、流畅观看体验的需求不断提升&#xff0c;对系统的并发处理能力、视频处理速度、存储效率等多方面都提出了极高的要求。那么&#xff0c;我们首先需要了解一个完整的短视频系统…

美国年轻人热衷床上“摆烂”,沃尔玛发掘床上用品新商机!

美国年轻人近年来热衷于床上“摆烂”生活方式&#xff0c;这反映了他们对舒适放松的追求和现代生活的压力。沃尔玛作为零售业巨头&#xff0c;敏锐地捕捉到这一市场变化&#xff0c;发现了床上用品的新商机。 美国年轻人忙碌中渴望宁静空间。床成为他们放松、逃离现实压力的理想…

十二、配置注解执行SQL

简化一下流程&#xff0c;主要可以分为下面几步&#xff1a; 1.解析配置&#xff0c;写入配置项 2.执行SQL 3.封装结果 通过注解配置SQL主要体现在解析部分&#xff0c;这部分要分别做解析XML还是配置注解的接口&#xff0c;拿到sql以后&#xff0c;select的处理和insert/upda…

【C++】手动模拟String底层与深浅拷贝

在string类&#xff1a;版本、组件、构造、操作及应用和 C中string的一些超常用函数 (附习题)这两篇文章中我们已经了解到了string&#xff0c;现在让我们再来手动实现模拟一下吧~ 模拟实现string是为了更好的理解string函数的使用和深浅拷贝方面的知识~ 总体整理了两张思维导…

深度学习——TensorBoard的使用

官方文档torch.utils.tensorboard — PyTorch 2.3 documentation TensorBoard简介 TensorBoard是一个可视化工具&#xff0c;它可以用来展示网络图、张量的指标变化、张量的分布情况等。特别是在训练网络的时候&#xff0c;我们可以设置不同的参数&#xff08;比如&#xff1…

本轮牛市新趋势,跟随The First捕捉牛市Alpha

与以往牛市“百花齐放”的繁荣景象相比&#xff0c;本轮牛市颇具独特走势&#xff0c;呈现出了资金集中度高、财富聚集效应小的特点&#xff0c;绝大部分加密资产甚至跑不赢BTC的涨幅幅度。而以往大放色彩的公链币价值币的走势&#xff0c;甚至比不过牛尾才爆发的MEME币。这使得…