#include <sys/uio.h>

ssize_t readv(int fd, const struct iovec *iov, int iovcnt);

unix高级环境编程中的定义:

【ssize_t readv(int filedes,const struct iovec iov[ ],int iovcnt) ;
ssize_t writev(int filedes,const struct iovec iov[ ],int iovcnt) ; 】

----------------------------------------------------------------------------

1 #include <stdio.h>
2 #include <sys/types.h>
3 #include <sys/stat.h>
4 #include <fcntl.h>
5 #include <sys/uio.h>
6 #include <unistd.h>
7
8 int main()
9 {
10 struct iovec iov[2];
11 char buf[12],str[12];
12 int fd = open("1.txt",O_RDONLY);
13 if(fd == -1)
14 return -1;
15 iov[0].iov_base = buf;
16 iov[0].iov_len = 12;
17 iov[1].iov_base = str;
18 iov[1].iov_len = 12;
19 int n = readv(fd, iov, 2);

buf[11] = 0;//添加这个

20 printf("n:%d\n", n);
21 //printf("buf:%s\n",buf);
22 //printf("str:%s\n",str);
23 puts(buf);
24 puts(str);
25 close(fd);
26 return 0;
27 }

----------------------------------------------------------------------------

运行结果很奇怪:第一个缓冲区溢出了

tarena@ubuntu:~/mon$ ./a.out
n:23
buf:aaaaaaaaaaaabbbbbbbbbb

str:bbbbbbbbbb

解决办法:

int main()
9 {
10 struct iovec iov[3];
11 char buf[13],str[13],str2[13];
12 int fd = open("1.txt",O_RDONLY);
13 if(fd == -1)
14 return -1;
15 iov[0].iov_base = buf;
16 iov[0].iov_len = 12;
17 iov[1].iov_base = str;
18 iov[1].iov_len = 12;
19 iov[2].iov_base = str2;
20 iov[2].iov_len = 12;
21 int n = readv(fd, iov, 3);
22 buf[12] = 0;
23 str[12] = 0;
24 printf("n:%d\n", n);
25 printf("buf:%s\n",buf);
26 printf("str:%s\n",str);
27 printf("str2:%s\n",str2);
28 close(fd);
29 return 0;
30 }

当你要读入12个的时候申请13个存储空间读入的长度iov_len = 12,并且手动在末尾添加字符串结束标志。

----------------------------------------------------------------------------

ssize_t writev(int fd, const struct iovec *iov, int iovcnt);

----------------------------------------------------------------------------

1 #include <stdio.h>
2 #include <sys/types.h>
3 #include <sys/stat.h>
4 #include <fcntl.h>
5 #include <sys/uio.h>
6 #include <unistd.h>
7 #include <string.h>
8 int main()
9 {
10 struct iovec iov[2];
11 char buf[12] = "hello,lyy",str[12] = "nihao,lyy";
12 int fd = open("2.txt",O_WRONLY | O_CREAT);
13 if(fd == -1)
14 return -1;
15 iov[0].iov_base = buf;
16 iov[0].iov_len = strlen(buf);
17 iov[1].iov_base = str;
18 iov[1].iov_len = strlen(str);
19 int n = writev(fd, iov, 2);
20 printf("n:%d\n", n);
21 close(fd);
22 return 0;
23 }

----------------------------------------------------------------------------

运行结果正确,但是为什么需要超级用户才能查看呢?

tarena@ubuntu:~/mon$ sudo cat 2.txt
hello,lyynihao,lyytarena@ubuntu:~/mon$

----------------------------------------------------------------------------

ssize_t preadv(int fd, const struct iovec *iov, int iovcnt, off_t offset);

1 #include <stdio.h>
2 #include <sys/types.h>
3 #include <sys/stat.h>
4 #include <fcntl.h>
5 #include <sys/uio.h>
6 #include <unistd.h>
7 int main()
8 {
9 int fd = open("4.txt",O_RDWR|O_CREAT);
10 if(fd == -1) return -1;
11 struct iovec iov[3];
12 char str1[12],str2[12],str3[12];
13 iov[0].iov_base = str1;
14 iov[0].iov_len = 3;
15 iov[1].iov_base = str2;
16 iov[1].iov_len = 4;
17 iov[2].iov_base = str3;
18 iov[2].iov_len = 5;
19 preadv(fd, iov, 3, 4);
20 str1[iov[0].iov_len] = 0;
21 str2[iov[1].iov_len] = 0;
22 str3[iov[2].iov_len] = 0;
23 printf("str1:%s\nstr2:%s\nstr3:%s\n",str1,str2,str3);
24 close(fd);
25 return 0;
26 }

ssize_t pwritev(int fd, const struct iovec *iov, int iovcnt, off_t offset);

1 #include <stdio.h>
2 #include <sys/types.h>
3 #include <sys/stat.h>
4 #include <fcntl.h>
5 #include <sys/uio.h>
6 #include <unistd.h>
7 #include <string.h>
8 int main()
9 {
10 int fd = open("4.txt",O_RDWR|O_CREAT);
11 if(fd == -1) return -1;
12 struct iovec iov[3];
13 char str1[12] = "hello,lyy",str2[12] = "nihao,lyy",str3[36] = "nice to meet you";
14 iov[0].iov_base = str1;
15 iov[0].iov_len = strlen(str1);
16 iov[1].iov_base = str2;
17 iov[1].iov_len = strlen(str2);
18 iov[2].iov_base = str3;
19 iov[2].iov_len = strlen(str3);
20 pwritev(fd, iov, 3, 3);
21 close(fd);
22 return 0;
23 }

--------------------------------------------------------------------------------------------------------

这两个举例不太好举

ssize_t preadv2(int fd, const struct iovec *iov, int iovcnt, off_t offset, int flags);

flags:RWF_SYNC  RWF_DSYNC

ssize_t pwritev2(int fd, const struct iovec *iov, int iovcnt, off_t offset, int flags);

flags:RWF_NOWAI

---------------------------------------------

RWF_HIPRI只用于下列条件

其中this feature is usable only on a file descriptor opened using the O_DIRECT flag.

---------------------------------------------------------------------------------------------------------

#include <unistd.h>

ssize_t pread(int fd, void *buf, size_t count, off_t offset);

从第offset个开始读

1 #include <stdio.h>
2 #include <string.h>
3 #include <unistd.h>
4 #include <sys/types.h>
5 #include <sys/stat.h>
6 #include <fcntl.h>
7
8 int main()
9 {
10 char buf[12];
11 int fd = open("3.txt",O_RDONLY);
12 int n = pread(fd, buf, 12,3);
13 buf[n] = 0;
14 printf("n = %d buf:%s\n",n,buf);
15 close(fd);
16 return 0;
17 }

返回值比实际读到的多一个,手动buf[n]置为0

-------------------------------------------------------------------------------------

ssize_t pwrite(int fd, const void *buf, size_t count, off_t offset);

从第offset个开始写,从0开始;(略)

man(2) readv writev的更多相关文章

  1. readv writev示例程序

    当 readv() 时候,需要程序自己提供space,接收数据. #include <stdio.h> #include <stdlib.h> #include <str ...

  2. 套接字I/O函数write/read writev/readv send/recv sendto/recvfrom sendmsg/recvmsg

    函数原型 read/write系原型 #include <unistd.h> ssize_t read(int fd, void *buf, size_t count); #include ...

  3. RMAN备份失败: ORA-19502 & ORA-27072: File I/O error

    早上检查一ORACLE数据库的RMAN备份的邮件时,发现出现了ORA-27072: File I/O error等错误,具体信息如下所示: channel ORA_DISK_1: starting p ...

  4. Linux Socket编程

    “一切皆Socket!” 话虽些许夸张,但是事实也是,现在的网络编程几乎都是用的socket. ——有感于实际编程和开源项目研究. 我们深谙信息交流的价值,那网络中进程之间如何通信,如我们每天打开浏览 ...

  5. Socket通信原理探讨(C++为例)

    一.网络中进程之间如何通信? 本地的进程间通信(IPC)有很多种方式,但可以总结为下面4类: 1.消息传递(管道.FIFO.消息队列) 2.同步(互斥量.条件变量.读写锁.文件和写记录锁.信号量) 3 ...

  6. Linux Socket编程(不限Linux)【转】

    转自:http://www.cnblogs.com/skynet/archive/2010/12/12/1903949.html “一切皆Socket!” 话虽些许夸张,但是事实也是,现在的网络编程几 ...

  7. 字符设备驱动之Led驱动学习记录

    一.概述 Linux内核就是由各种驱动组成的,内核源码中大约有85%的各种渠道程序的代码.一般来说,编写Linux设备驱动大致流程如下: 1.查看原理图,数据手册,了解设备的操作方法. 2.在内核中找 ...

  8. [12]APUE:高级 I/O

    一.分散聚离(向量) I/O [a] readv / writev #include <sys/uio.h> ssize_t readv(int fd, const struct iove ...

  9. SOCKet 编程 简介

    “一切皆Socket!” 话虽些许夸张,但是事实也是,现在的网络编程几乎都是用的socket. ——有感于实际编程和开源项目研究. 我们深谙信息交流的价值,那网络中进程之间如何通信,如我们每天打开浏览 ...

随机推荐

  1. Java中高级面试题(1)

    List和Set比较,各自的子类比较 对比一:Arraylist与LinkedList的比较 1.ArrayList是实现了基于动态数组的数据结构,因为地址连续,一旦数据存储好了,查询操作效率会比较高 ...

  2. 从源码编译UE4,加快Setup.bat下载文件的环节

    之前很傻,每次运行这个setup.bat都要等很久很久才能把4g多的东西下载完成,知道有一天突然发现了世外桃源…… 从命令行运行setup.bat -help,可以看到参数的说明(没错,参数可选,之前 ...

  3. window下启动redis服务

    ---恢复内容开始--- 在windows环境下启动redis服务,前提是你安装好了,启动如下: 一,进入redis的安装目录下,在地址栏输入“cmd”,回车 二,然后会进入cmd界面,直接运行命令r ...

  4. java虚拟机规范-运行时数据区

    前言 java虚拟机是java跨平台的基石,本文的描述以jdk7.0为准,其他版本可能会有一些微调. 引用 java虚拟机规范 数据类型 java总共有两种数据类型:基本类型和引用类型.java虚拟机 ...

  5. MySQL主从复制之半同步模式

    MySQL主从复制之半同步模式 MySQL半同步介绍: 一般情况下MySQL默认复制模式为异步,何为异步?简单的说就是主服务器上的I/O threads 将binlog写入二进制日志中就返回给客户端一 ...

  6. code_action

    w https://raw.githubusercontent.com/laravel/laravel/master/config/database.php <?php return [ /* ...

  7. 职位-CTO:CTO

    ylbtech-职位-CTO:CTO 首席技术官是技术资源的行政管理者,英文为Chief Technical Officer或Chief Technology Officer,简称CTO.其职责是制订 ...

  8. dojo 官方翻译 dojo/_base/array 版本1.10

    官方地址:http://dojotoolkit.org/reference-guide/1.10/dojo/_base/array.html#dojo-base-array array模块dojo进行 ...

  9. 003-CHROME开发者工具的小技巧

    首先调试先进入到调试模式,快键键F12 1.代码格式化 有很多css/js的代码都会被 minify 掉,你可以点击代码窗口左下角的那个 { }  标签,chrome会帮你给格式化掉. 2.强制DOM ...

  10. log4j.properties 输出指定类日志

    比如,我只要众多日志中,红色框的日志,则可以指定类:com.dangdang.ddframe.rdb.sharding.parser.SQLParserFactory 修改配置文件: 再次输出结果为: