高级I/O函数

pipe函数

pipe函数用于创建一个管道,实现进程间的通信。

#include <unistd.h>

int pipe(int pipefd[2]);

通过pipe函数创建的文件描写叙述符fd[0]和fd[1]分别构成管道的两端,往fd[1]写入的数据能够从fd[0]读出,不能反过来。管道内部传输的数据时字节流,和TCP字节流概念同样,但有差别,管道本身拥有一个容量限制,它规定假设应用程序不将数据从管道读走的话,该管道最多能被写入多少字节的数据。管道容量阿东小默认是65536字节,能够用fcntl函数来改动管道容量。

此外,socket基础API中有一个socketpair函数,可以方便创建双向管道。

#include<sys/types.h>         /* See NOTES*/

#include<sys/socket.h>

intsocketpair(int domain, int type, int protocol, int sv[2]);

这里domain仅仅能使用UNIX本地域协议族AF_UNIX,由于我们仅能在本地使用这个双向管道。

dup函数和dup2函数

#include <unistd.h>

int dup(int oldfd);

int dup2(int oldfd, int newfd);

dup函数创建一个新的文件描写叙述符,该新的文件描写叙述符和原有的文件描写叙述符file_descriptor指向同样的文件、管道或网络连接。而且dup返回的文件描写叙述符总是取系统当前可用的最小整数值。Dup2和dup类型,只是它将返回第一个不小于newfd的整数值。dup和dup2系统调用失败时返回-1并设置errno。

通过dup和dup2创建的文件描写叙述符并不继承原文件描写叙述符的属性。

readv函数和writev函数

readv函数将数据从文件描写叙述符督导分散的内存块中,即分散读。Writev函数则将多块分散的内存数据一并写入文件描写叙述符中,即集中写。定义例如以下:

#include <sys/uio.h>

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

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

fd是文件描写叙述符,iov是iovec结构数组,该结构体描写叙述一块内存区,iovcnt參数是数组的长度。

sendfile函数

sendfile函数在两个文件描写叙述符之间直接传递数据(全然在内核中操作),从而避免了内核缓冲区和用户缓冲区之间的数据拷贝,效率高,这被称为零拷贝。

#include <sys/sendfile.h>

ssize_t sendfile(int out_fd, int in_fd,off_t *offset, size_t count);

in_fd參数是带读出内容的文件描写叙述符,out_fd參数是带写入内容的文件描写叙述符,offset參数指定从读入文件流的哪个位置開始读,count指定文件描写叙述符in_fd和out_fd之间传输的字节数。

mmap函数和munmap函数

mmap函数用于申请一段内存空间。我们能够将这段内存作为进程通信的共享内存,也能够将文件直接映射到当中。Munmap函数则释放由mmap创建的这段内存空间。定义例如以下:

#include <sys/mman.h>

void *mmap(void *addr, size_t length, intprot, int flags, int fd, off_t offset);

int munmap(void *addr, size_t length);

当中,start參数同意用于使用某个特定的地址作为这段内存的起始地址。假设被设置成NULL,则系统自己主动分配一个地址。Length參数指定内存段的长度。Port參数用来设置内存段的訪问权限,flag參数控制内存段被改动后程序的行为。Fd參数是被映射文件相应的文件描写叙述符。Mmap函数成功时返回指向目标内存区域的指针,失败则返回MAP_FAILED,并设置errno。

splice函数

#include <fcntl.h>

ssize_t splice(int fd_in, loff_t *off_in,int fd_out, loff_t *off_out, size_t len, unsigned int flags);

用来控制两个文件描写叙述符之间的数据移动,也是零拷贝操作。Flag參数控制数据流怎样移动。

tee函数

tee函数在两个管道文件描写叙述符之间复制数据,也是零拷贝操作。它不消耗数据,因此源文件描写叙述符上的数据仍然能够用于兴许的读操作。Tee函数的原型例如以下:

#define _GNU_SOURCE        /* See feature_test_macros(7) */

#include <fcntl.h>

ssize_t tee(int fd_in, int fd_out, size_tlen, unsigned int flags);

fcntl函数

fcntl函数提供了对文件描写叙述符的各种控制操作。另外一个常见的控制文件描写叙述符属性和行为的系统调用时ioctl,并且ioctl比fcntl可以运行很多其它的控制。

Linux高性能server编程——高级I/O函数的更多相关文章

  1. Linux 高性能server编程——高级I/O函数

    重定向dup和dup2函数 #include <unistd.h> int dup(int file_descriptor); int dup2(int file_descriptor_o ...

  2. Linux 高性能服务器编程——高级I/O函数

    重定向dup和dup2函数 #include <unistd.h> int dup(int file_descriptor); int dup2(int file_descriptor_o ...

  3. Linux高性能server编程——Linux网络基础API及应用

     Linux网络编程基础API 具体介绍了socket地址意义极其API,在介绍数据读写API部分引入一个有关带外数据发送和接收的程序,最后还介绍了其它一些辅助API. socket地址API 主 ...

  4. Linux高性能server编程——信号及应用

     信号 信号是由用户.系统或者进程发送给目标进程的信息.以通知目标进程某个状态的改变或系统异常. Linux信号可由例如以下条件产生: 对于前台进程.用户能够通过输入特殊的终端字符来给它发送信号. ...

  5. Linux高性能server编程——定时器

    版权声明:本文为博主原创文章.未经博主允许不得转载. https://blog.csdn.net/walkerkalr/article/details/36869913  定时器 服务器程序通常管 ...

  6. Linux高性能server编程——多线程编程(下)

    多线程编程 条件变量 假设说相互排斥锁是用于同步线程对共享数据的訪问的话.那么条件变量则是用于线程之间同步共享数据的值. 条件变量提供了一种线程间的通信机制:当某个共享数据达到某个值得时候,唤醒等待这 ...

  7. Linux高性能server编程——I/O复用

     IO复用 I/O复用使得程序能同一时候监听多个文件描写叙述符.通常网络程序在下列情况下须要使用I/O复用技术: client程序要同一时候处理多个socket client程序要同一时候处理用户 ...

  8. Linux高性能server编程——系统检測工具

    系统检測工具 tcpdump tcpdump是一款经典的抓包工具,tcpdump给使用者提供了大量的选项,泳衣过滤数据报或者定制输出格式. lsof lsof是一个列出当前系统打开的文件描写叙述符的工 ...

  9. linux高性能服务器编程

    <Linux高性能服务器编程>:当当网.亚马逊 目录: 第一章:tcp/ip协议族 第二章:ip协议族 第三章:tcp协议详解 第四章:tcp/ip通信案例:访问Internet 第五章: ...

随机推荐

  1. lua的前景??

    除了专业的游戏公司,貌似很少人在用lua来做开发啊,国内的lua社区越来越不行了. lua还在不断的发展,但每次新版本c接口都改动很大,项目想要升级有点困难啊. lua还有前途吗?

  2. 【从0開始Tornado建站】群聊

    群聊的前台主要代码: {%block content%} <!--<p class='text-success h3'>測试版本号,每天凌晨4:00清水,enjoy it~~:-)& ...

  3. C++ 函数映射使用讲解

    想想我们在遇到多语句分支时是不是首先想到的是 switc case 和 if else if ... 这2种方式在编码方面确实简单少,但是当分支达到一定数量后,特别是分支内部有嵌套大段代码或者再嵌套分 ...

  4. 感觉挺有意思的SQL题目

    1.有如下数据,要求查询每个班最低分和最高分,并将最高分与最低分显示为同一列 ID Student CourseName Score1 张三 English 802 张三 Math 703 张三 Ch ...

  5. Axure使用

    (一)  Axure rp的界面 1-主菜单工具栏 大部分类似office软件,不做详细解释,鼠标移到按钮上都有对应的提示. 2-主操作界面 绘制产品原型的操作区域,所有的用到的元件都拖到该区域. 3 ...

  6. Struts2详解

     struts2框架是SSH框架集中的框架之一,是一个基于MVC设计模式的Web应用框架,它本质上相当于一个servlet,在MVC设计模式中,Struts2作为控制器层(Controller)来建立 ...

  7. Jetty 8.1 安装 运行 部署

    链接地址:http://blog.csdn.net/lego2816/article/details/42650545 Java + MySQL 从Jfinal开始,第一步先走完整个流程,主要是发布部 ...

  8. C++对C语言的非面向对象特性扩充(2)

    上一篇随笔写了关于C++在注释,输入输出,局部变量说明的扩充,以及const修饰符与C中的#define的比较,也得到了几位学习C++朋友们的帮助讲解,十分感谢,我也希望欢迎有更多学习C++的朋友一起 ...

  9. 一个分组查询 每组前 10 的sql 语句

    USE tmpgo CREATE TABLE Employee( ID int identity(1,1), EmpName varchar(20), EmpSalary varchar(10), E ...

  10. poj 1715 Hexadecimal Numbers 排列组合

    /** 大意: 给定16进制数的16个字母,,求第k大的数,,要求数的长度最大为8.,并且每个数互不相同. 思路: 从高到低挨个枚举,每一位能组成的排列数 ,拿最高位来说,能做成的排列数为15*A(1 ...