函数read、write、lseek

 

函数原型: 

#include<unistd.h>
ssize_t read(int fd, void *buf, size_t count);返回值:读到的字节数,若已到文件尾,返回0;若出错,返回-1

参数:

  • fd:函数open的返回值
  • buf:缓冲区,存储要读取的数据
  • count:缓冲区的最大字节数size(buf)

 

函数原型:

#include<unistd.h>
sszie_t write(int fd, const void *buf, size_t count);返回值:若成功,返回已写的字节数,若出错,返回-1

参数:

  • fd:函数open返回值
  • buf:要写到文件的数据
  • count:strlen(buf)

 

测试代码:

#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>int main(int argc, const char* argv[])
{int fd = open("english.txt", O_RDWR);printf(" fd = %d\n", fd);int fd1 = open("temp", O_WRONLY | O_CREAT, 0664);printf("fd1 = %d\n",fd1);char buf[4096];int len = read(fd, buf, sizeof(buf));while(len > 0) {int ret = write(fd1, buf, len);printf("ret = %d\n", ret);len = read(fd, buf, sizeof(buf));}close(fd);close(fd1);return 0;
}

输出结果:

 

函数原型:
 

#include<unistd.h>
off_t lssk(int fd, off_t offset, int whence);返回值:若成功, 返回新的文件的偏移量;若出错,返回-1

参数:

  • 若whence是SEEK_SET,则将该文件的偏移量设置为距文件的开始处offset个字节。
  • 若whence是SEEK_CUR,则将该文件的偏移量设置为当前值加offset,offset可正可负。
  • 若whence是SEEK_END,则将该文件的偏移量设置为文件长度加offset,offset可正可负。

使用:

  • 文件指针移动到头部:lseek(fd, 0, SEEK_SET);
  • 获取文件指针当前位置:int len = lseek(fd, 0, SEEK_CUR);
  • 获取文件长度:int len = lseek(fd, 0, SEEK_END);
  • 文件拓展:文件原大小100k,拓展为1100k。lseek(fd, 1000, SEEK_END); 最后一次写操作:write(fd, "a", 1);

 

测试代码:

#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <string.h>
#include <fcntl.h>int main(int argc, const char *argv[])
{int fd = open("english.txt", O_RDWR);if(fd == -1) {perror("open error");exit(1);}int len = lseek(fd, 1000, SEEK_END);printf("len = %d\n", len);write(fd, "a", 1);close(fd);return 0;
}


输出结果:

 

阻塞与非阻塞

阻塞和非阻塞是文件的属性还是read函数的属性? 答案:文件的属性

  • 普通文件:hello.c 不阻塞
  • 终端设备:/dev/tty、管道、套接字:,默认阻塞

 

1. 阻塞读终端

测试代码:

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>int main()
{char buf[10];int n;n = read(STDIN_FILENO, buf, 10);if(n < 0) {perror("read STDIN_FILENO");exit(1);}write(STDOUT_FILENO, buf, n);return 0;
}

输出结果:

分析:

 

测试代码:

#include <unistd.h> 
#include <fcntl.h>
#include <string.h>
#include <stdio.h>
#include <errno.h>
#include <stdlib.h>
#define MSG_TRY "try agin\n"int main()
{char buf[10];int fd, n;// /dev/tty --->当前打开的终端设备fd = open("/dev/tty", O_RDONLY | O_NONBLOCK);if(n < 0) {perror("open /dev/tty");exit(1);}tryagin:n = read(fd, buf, 10);if(n < 0) {//如果write为非阻塞,但是没有数据可读,此时全局变量errno被设置为EAGAINif(errno == EAGAIN) {sleep(3);write(STDOUT_FILENO, MSG_TRY, strlen(MSG_TRY));goto tryagin;}perror("read /dev/tty");exit(1);}write(STDOUT_FILENO, buf, n);close(fd);return 0;
}

输出结果:

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

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

相关文章

Java这些高端技术只有你还不知道,薪资翻倍

正文 我的第一份工作是在一家外企&#xff0c;当时抱着“逃离”上海的想法去了二线城市的分公司&#xff0c;但是管理文化氛围跟总部几乎都是一样的&#xff0c;这份工作经历对我后面的工作不论是做事风格、习惯上还是思考问题的方式方法上都有很大的影响。后面陆续进入国企&a…

函数dup和dup2

函数原型&#xff1a; #include<unistd.h> int dup(int oldfd);返回值&#xff1a;若成功&#xff0c;返回新的文件描述符&#xff1b;若出错&#xff0c;返回-1 参数&#xff1a; oldfd&#xff1a;要复制的文件描述符dup调用成功&#xff1a;有两个文件描述符指向同…

Java进阶面试资料无偿分享!真香系列

8-22 投递简历 8-24 一面&#xff08;大概1h50min&#xff09; 0、currenthashmap怎么扩容的&#xff1f;fwn为什么固定hash -1&#xff0c;这样设计有什么好处&#xff1f;帮助扩容是发生在什么阶段?读线程和写线程都会帮助扩容吗&#xff1f;扩容的时候任务具体怎么协调的&…

Java通用流行框架大全,绝对干货

Java如何入门&#xff1f; 1、建立好开发环境 首先建立好开发环境非常重要&#xff0c;工欲善其事&#xff0c;必先利其器。做任何开发&#xff0c;首先就是要把这个环境准备好&#xff0c;之后就可以去做各种尝试&#xff0c;尝试过程中就能逐渐建立信心。初学者往往在环境配…

Java集合类中绝对占有一席之地的List,涨薪7K!

一、先来解读&#xff1a;23种设计模式要点 1.单例模式&#xff08;Singleton Pattern&#xff09; 2.工厂模式 3.抽象工厂模式&#xff08;Abstract Factory Pattern&#xff09; 4.模板方法模式&#xff08;Template Method Pattern&#xff09; 5.建造者模式&#xff08;Bu…

Java面试10大知识点总结宝典助你通关!已拿意向书!

Java基础 1.Java语言的三大特性 2.Java语言主要特性 3. JDK和JRE有什么区别 4.Java基本数据类型及其封装类 5.如果main方法被声明为private会怎样? 6.说明- -下public static void main(String argsQ])这段声明里每个关键字的作用 7.与equals的区别 8.Object有哪些公用方法 9.…

互斥锁、条件变量

一、互斥锁 1. 函数原型&#xff1a; pthread_mutex_init(pthread_mutex_t *restrict mutex, const pthread_mutexattr_t *restrict attr); pthread_mutex_destroy(pthread_mutex_t *mutex); 分析&#xff1a; pthread_mutex_t 类型&#xff0c;其本质是一个结构体&#xf…

Java面试你必须要知道的那些知识,深夜思考

如何提升自己的实力&#xff1f; Step 1&#xff1a;梳理自己的知识 对照下面这份学习大纲&#xff0c;梳理出自己的知识盲区&#xff0c;这份大纲里面的技术点完全对标P7岗的主流技术&#xff0c;因此这是一份很好的知识大纲笔记。 Step 2&#xff1a;查漏补缺&#xff0c;夯…

Java面试你必须要知道的那些知识,面试建议

二、面试题 面&#xff1a;考你几个红黑树的知识点&#x1f980; 红黑树的数据结构都用在哪些场景&#xff0c;有什么好处&#xff1f;红黑树的时间复杂度是多少&#xff1f;红黑树中插入新的节点时怎么保持平衡&#xff1f; 面&#xff1a;2-3树都是不没看&#xff0c;回去…

存储映射I/O(一)

一、存储映射I/O 存储映射I/O使一个磁盘文件与存储空间中的一个缓冲区映射&#xff0c;于是当从缓冲区中取数据&#xff0c;就相当于读文件中的相应字节。于此类似&#xff0c;将数据存入缓冲区&#xff0c;则相应的字节就自动写入文件&#xff0c;这样&#xff0c;就可在不不…

【绝对干货】kafkastream广告

Java如何入门&#xff1f; 1、建立好开发环境 首先建立好开发环境非常重要&#xff0c;工欲善其事&#xff0c;必先利其器。做任何开发&#xff0c;首先就是要把这个环境准备好&#xff0c;之后就可以去做各种尝试&#xff0c;尝试过程中就能逐渐建立信心。初学者往往在环境配…

存储映射IO(二)

mmap父子进程间通信 1. 测试代码&#xff1a; #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <fcntl.h> #include <sys/mman.h> #include <sys/wait.h>int var 100;int main(void) {int *p;pid_t pid;int fd;…

【聊透SpringMVC】java技术经理岗位职责

缓存维护方案一 如果是一读&#xff08;线程B&#xff09;一写&#xff08;线程A&#xff09;操作&#xff0c;「先操作缓存&#xff0c;再操作数据库」。流程图如下所示&#xff1a; 1.线程A发起一个写操作&#xff0c;第一步del cache 2.线程A第二步写入新数据到DB 3.线程…

【聊透SpringMVC】自学java和三大框架要多久

饿了么一面&#xff08;Java&#xff09; hashmap源码问题 HashMap底层结构 put操作讲一下 HashMap、HashMap如何保证线程安全、ConcurrentHashMap JVM有哪些回收算法&#xff0c;对应的收集器有哪些&#xff1f; jvm g1的内存模型讲一下&#xff0c;G1和CMS收集器的区别&#…

【设计思想解读开源框架】mysql官方文档中文版下载免费

01 源码分析 源码阅读&#xff0c;最核心有三点&#xff1a;技术基础强烈的求知欲耐心。 1.1 设计模式&#xff08;45设计模式&#xff1a;介绍优缺点应用实例源代码解决问题&#xff09; 1.2 Spring复习大纲&#xff1a;依赖注入IocBeans注解数据访问AOPMVC等 1.3 Spring全家…

命令新参

命令形参&#xff1a; 命令行参数是使用main()函数参数来处理的&#xff0c;其中&#xff0c;argc是指传入参数的个数&#xff0c;argv[]是一个指针数组&#xff0c;指向传递给程序的每个参数。 应当指出的是&#xff0c; argv[0]存储程序的名称&#xff0c;argv[1]是一个指向…

【金三银四】启动mysql服务器

微服务架构 ①微服务概念&#xff1a; ②Spring Cloud微服务架构&#xff1a; 海量数据处理 ①&#xff1a;经典的海量数据处理面试题 高可用架构 ①基于 Hystrix 实现高可用&#xff1a; ②限流&#xff1a; ③熔断&#xff1a; 高并发架构 ①消息队列&#xff1a; ②搜索…

函数fork vfork

一、函数fork fork函数原型&#xff1a; #include <unistd.h> pid_t fork(void); 二、程序清单 1. 测试代码&#xff1a; #include <unistd.h> #include <stdlib.h> #include <sys/types.h> #include <sys/stat.h> #include <string.h>…

【金三银四】微软java后端社招

分布式系统特性与衡量标准 透明性&#xff1a;使用分布式系统的用户并不关心系统是怎么实现的&#xff0c;也不关心读到的数据来自哪个节点&#xff0c;对用户而言&#xff0c;分布式系统的最高境界是用户根本感知不到这是一个分布式系统 可扩展性&#xff1a;分布式系统的根…

【面试必会】java虚拟机原理

如何才可以进大厂&#xff1f; 答案其实也很简单&#xff0c;能力学历。不知道大家有没有发现&#xff0c;大厂的一些部门对于学历要求已经放低了&#xff0c;阿里的一些部门同样也招大专学历的程序员&#xff0c;当然肯定也是因为他的能力足够出色。 对于准备秋招的你来说&a…