如何理解Linux文件IO?

一、文件IO的概述
1、什么是文件?
Linux下一切皆文件。普通文件、目录文件、管道文件、套接字文件、链接文件、字符设备文件、块设备文件。
2、什么是IO?
input  output:输入输出
3、什么是文件IO?
对文件的输入输出,把数据写入文件/从文件中读取数据
系统IO:系统调用的IO接口。(open、close、read、write、lseek、mmap、munmap)
标准IO:基于标准C库的IO接口
二、系统IO函数的应用
Linux下的man手册的使用:man  man
第一节:查可执行程序:man 1 ls
第二节:查系统调用的函数:man 2 open
第三节:查库调用的函数:man 3 printf

- open  打开文件
#include <sys/types.h> #include <sys/stat.h> #include <fcntl.h>

int open(const char *pathname, int flags);  int open(const char *pathname, int flags, mode_t mode); 返回值类型:int
返回值:
打开文件成功,返回一个新的文件描述符,>=0(相当于人的身份证号)
打开文件失败,返回-1
形参:
pathname:要打开的文件的路径名
flags:打卡文件的方式
O_RDONLY  只读
O_WRONLY 只写
O_RDWR     可读可写
以上三种方式互斥
O_APPEND:以追加方式打开文件。
O_CREAT:如果要打开的文件不存在,系统就创建该文件并打开。
O_TRUNC:如果要打开的文件中已有数据,那就打开文件并清除已有的数据。
mode:用于指定新建文件的权限,用八进制表示。

- close 关闭文件函数
 #include <unistd.h>   int close(int fd); 返回值类型:int
返回值:
关闭文件成功,返回0
关闭文件失败,返回-1
形参
fd:要关闭的文件的文件描述符

练习:编写代码,实现在共享目录中,打开1.txt文件,并打印出文件描述符,再关闭文件。

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

int main()
{
    //打开文件
    int fd1;
    fd1 = open("./1.txt",O_RDWR);
    if(fd1 == -1)
    {
        printf("open 1.txt failed!\n");
        return -1;
    }

    printf("fd1 = %d\n",fd1);


    close(fd1);
    return 0;
}

/*
fd1 = 3;
文件描述符是从3开始的,为什么会这样?不是说文件描述符>=0?
其实系统会默认打开三个标准流控,0,1,2就会被占用
0 ---> 标准输入   stdin
1 ---> 标准输出   stdout
2 ---> 标准错误   stderr
所以当我们自己用open函数打开文件时,文件描述符是从3开始的
*/


- lseek   偏移文件指针

 #include <sys/types.h>

 #include <unistd.h>
 
 off_t lseek(int fd, off_t offset, int whence); 返回值类型:off_t (整形)


返回值:
         偏移成功,返回偏移字节数
         偏移失败,返回-1
形参一:fd  文件描述符
形参二:偏移量
形参三:偏移位置
         SEEK_SET   从头位置开始偏移
         SEEK_CUR  从当前位置开始偏移
         SEEK_END  从末尾位置开始偏移
练习2:编写代码,实现在1.txt文件中写入"hello world",再从该文件中读取5个字节数据,并打印出来。

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

int main(void)
{
    //1.打开文件
    int fd = open("./1.txt", O_RDWR|O_CREAT);
   
    if (fd == -1)
    {
        printf("open  1.txt failed!\n");
        return -1;
    }

    //2.写入数据
    char wr_buf[15] = "hello world";
    write(fd, wr_buf, 11);    

    //3.读取数据
    char rd_buf[15] = {0};

    lseek(fd, 0, SEEK_SET);
    read(fd, rd_buf,5);
    
    printf("%s\n", rd_buf);
    
    //4.关闭文件
    close(fd);
   
    return 0;
}

作业:实现一个简单文件拷贝功能,将文件1的数据拷贝到文件2,如果文件2不存在则创建,如果文件2中已有数据则清除。

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

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

相关文章

Radware DDoS防护迎来重大升级,重拳出击在线游戏行业难题

日前&#xff0c;全球领先的网络安全和应用交付解决方案提供商Radware推出了多维DDoS检测和防护措施&#xff0c;以满足在线游戏行业独特复杂的需求。Radware开发了一系列新的算法来保护在线游戏免遭复杂攻击。 Radware首席运营官Gabi Malka表示&#xff1a;“在线游戏是价值数…

【海贼王的数据航海】排序——概念|直接插入排序|希尔排序

目录 1 -> 排序的概念及其运用 1.1 -> 排序的概念 1.2 -> 常见的排序算法 2 -> 插入排序 2.1 -> 基本思想 2.2 -> 直接插入排序 2.2.1 -> 代码实现 2.3 -> 希尔排序(缩小增量排序) 2.3.1 -> 代码实现 1 -> 排序的概念及其运用 1.1 -&g…

Centos7安装Clickhouse单节点部署

&#x1f388; 作者&#xff1a;互联网-小啊宇 &#x1f388; 简介&#xff1a; CSDN 运维领域创作者、阿里云专家博主。目前从事 Kubernetes运维相关工作&#xff0c;擅长Linux系统运维、开源监控软件维护、Kubernetes容器技术、CI/CD持续集成、自动化运维、开源软件部署维护…

SQLite数据库使用指南以及相关API编程

SQLite介绍 SQLite是一种基于C语言开发的轻量级、快速、自包含、高可靠性和全功能的SQL数据库引擎。它是全球范围内使用最为广泛的数据库引擎&#xff0c;被嵌入到所有移动设备和大部分计算机中&#xff0c;并且伴随着无数日常使用的应用程序一起提供。SQLite的文件格式具有稳…

免费阅读篇 | 芒果YOLOv8改进110:注意力机制GAM:用于保留信息以增强渠道空间互动

&#x1f4a1;&#x1f680;&#x1f680;&#x1f680;本博客 改进源代码改进 适用于 YOLOv8 按步骤操作运行改进后的代码即可 该专栏完整目录链接&#xff1a; 芒果YOLOv8深度改进教程 该篇博客为免费阅读内容&#xff0c;直接改进即可&#x1f680;&#x1f680;&#x1f…

论文阅读——Rein

Stronger, Fewer, & Superior: Harnessing Vision Foundation Models for Domain Generalized Semantic Segmentation 一、引言 是一个对Domain Generalized Semantic Segmentation (DGSS)任务的视觉大模型的微调方法&#xff0c;即Rein。 Rein 专为 DGSS 任务量身定制&a…

Linux操作系统裸机开发-环境搭建

一、配置SSH服务 1、下载安装ssh服务输入以下命令 sudo apt-get install nfs-kernel-server portmap2、建立一个供SSH服务使用的文件夹如以下命令 mkdir linux 3、完成前两步之后需要将其文件路径放到/etc/exports文件里输入以下命令&#xff1a; sudo vi /etc/esports 4.打…

04-java基础--流程控制语句

一、switch语句 二、循环的三种结构 流程控制语句分为三种结构&#xff1a; 顺序结构&#xff08;按代码的书写顺序执行&#xff0c;从上到下依次执行&#xff09;分支结构&#xff08;if语句、if–else语句、switch语句&#xff09;循环结构&#xff08;while、for循环、do–…

超越 GPT4,科大讯飞,再出王炸!

哈喽&#xff0c;大家好&#xff01; 去年&#xff0c;科大讯飞星火大模型上线&#xff0c;给大家推荐了一波&#xff0c;演示了其强大的功能&#xff0c;不少小伙伴都立马申请体验了一把&#xff0c;也有私信说非常强大&#xff0c;工作效率提高不少&#xff0c;支持国产大模…

PCL 高斯投影反算:高斯投影坐标转大地坐标(C++详细过程版)

目录 一、算法原理二、代码实现三、结果展示四、测试数据PCL 高斯投影反算:高斯投影坐标转大地坐标(C++详细过程版)由CSDN点云侠原创。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的爬虫。 一、算法原理

系统重构后,对项目定制开发的兼容性问题

公司自实施产品线战略以来&#xff0c;基本推翻了全部旧有业务模块。后续以标准产品二次开发的模式进行项目开发。但在涉及到一些旧有系统二期、三期升级改造过程中。不可避免的需要解决旧有系统的客户定制化开发兼容性问题。也就是旧有系统定制开发的模块不能丢弃。重新开发从…

解决游戏程序一运行就退出的问题

正文&#xff1a; 在游戏开发过程中&#xff0c;我们可能会遇到程序一运行就立即退出的情况。这种情况通常是由于程序中的某些逻辑错误或初始化问题导致的。 下面我们将分析可能的原因&#xff0c;并提供一些解决方案。 目录 正文&#xff1a; 原因分析&#xff1a; 解决方案…

LDR6328Q,快充界的黑马

Type-C接口&#xff0c;这一新型的USB接口形式&#xff0c;凭借其正反插的便捷性、传输速度的高效性&#xff0c;以及支持多种功率传输的灵活性&#xff0c;迅速在市场中崭露头角。如今&#xff0c;越来越多的厂商青睐于在小家电产品上运用Type-C接口&#xff0c;这一改变无疑极…

YOLOv9训练不中断,从断点处训练的方法

1. 训练过程中意外中断&#xff0c;未完成训练预期的epoch数量 不小心多开了一个程序&#xff0c;导致程序从98次中断了&#xff0c;想要继续从98开始训练&#xff1a; 将train_dual.py文件中的patser中参数resume&#xff0c;将其设置为defaultTrue: parser.add_argument(--…

JavaSE-----认识异常【详解】

目录 一.异常的概念与体系结构&#xff1a; 1.1异常的概念&#xff1a; 1.2一些常见的异常&#xff1a; 1.3异常的体系结构&#xff1a; 1.4异常的分类&#xff1a; 二.异常的处理机制&#xff1a; 2.1 抛出异常&#xff1a; 2.2异常的捕获&#xff1a; 2.3try-catch-&…

相机sd卡照片删除后数据恢复,相机sd卡中的照片被删除后如何恢复数据

当我们使用相机拍摄照片时&#xff0c;有时会不小心删除了一些重要的照片。这可能是因为误操作、SD卡故障或者其他原因。无论是珍贵的照片、还是重要的工作文件&#xff0c;被删除后&#xff0c;我们往往会感到焦虑和失望。相机sd卡中的照片被删除后如何恢复数据&#xff1f;幸…

【Leetcode每日一题】 位运算 - 两整数之和(难度⭐)(37)

1. 题目解析 题目链接&#xff1a;371. 两整数之和 这个问题的理解其实相当简单&#xff0c;只需看一下示例&#xff0c;基本就能明白其含义了。 2.算法原理 算法的核心思路其实可以类比为我们小时候学习的加法运算。只不过这次&#xff0c;我们不是在纸上用铅笔算&#xff…

主干网络篇 | YOLOv8更换主干网络之ShuffleNetV2(包括完整代码+添加步骤+网络结构图)

前言&#xff1a;Hello大家好&#xff0c;我是小哥谈。ShuffleNetV2是一种轻量级的神经网络架构&#xff0c;用于图像分类和目标检测任务。它是ShuffleNet的改进版本&#xff0c;旨在提高模型的性能和效率。ShuffleNetV2相比于之前的版本&#xff0c;在保持模型轻量化的同时&am…

THM学习笔记—Simple CTF

nmap扫描&#xff0c;发现2222端口很奇怪啊&#xff0c;重新换一种方式扫描2222端口 发现是ssh 先用ftp试试&#xff0c;尝试匿名登录 下载所有文件 发现只有一个ForMitch.txt&#xff0c;告诉我们其账号密码为弱密码&#xff0c;我们猜测Mitch为其用户名&#xff0c;尝试暴力…

力扣112、113、101--树

112. 路径总和 题目描述&#xff1a; 给你二叉树的根节点 root 和一个表示目标和的整数 targetSum 。 判断该树中是否存在 根节点到叶子节点 的路径&#xff0c;这条路径上所有节点值相加等于目标和 targetSum 。 如果存在&#xff0c;返回 true &#xff1b;否则&#xff0c…