ACCEPT

ACCEPT

章节:Linux 程序员手册 (2)
更新:2010-09-10

到 易美翻译 翻译

名字

accept - 通过套接口接受一个连接

概要

#include Esys/types.h> /* 参看 “注意小节” */
#include Esys/socket.h>int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen);#define _GNU_SOURCE /* 参考 feature_test_macros(7) */
#include <sys/socket.h>int accept4(int sockfd, struct sockaddr *addr,socklen_t *addrlen, int flags);

描述

accept() 系统调用应用于可连接套接口类型 ( SOCK_STREAM, SOCK_SEQPACKET)。它取出在监听套接口 sockfd请求队列里的第一个连接,新建一个已连接的套接口,并且返回一个引用该套接口新的文件描述符。新建的套接口不处于监听状态。原始的套接口 sockfd 没有受到影响。

参数 sockfd 是一个由 socket(2) 创建的套接口,通过 bind绑定到一个本地地址,并且在调用 listen(2)之后正处于监听之中。

参数 addr 是指向一个 sockaddr结构的指针。这结构体被填充为一个端套接口,又被称为通信层。返回的地址结体 addr的额外的格式可以通过套接口地址族(参看 socket(2)和各自的协议手册页)来确定。当 addr 是 NULL 时,没有内容被填充,此时 addrlen不被使用,同时也可以是 NULL。

参数 addrlen 是一个“值-返回”型参数,调用者必须把它初始化为 addr指向的结构的大小(字节数),返回时,它指出端地址的实际大小。

如果提供的缓冲区太小,返回的地址将被截断,此时,addrlen 将返回一个比传入更大的值。

如果队列里没有未处理的连接,并且套接口没有标记为不阻塞,accept()会阻塞当前调用进程直到有一个连接出现。如果没有未处理的连接,同时套接口被标记为不阻塞,accept() 返回EAGAINEWOULDBLOCK 错误。

为了在一个套接口有连接时收到通知,你可以使用 select(2) 或 poll(2)。当有连接时,一个可读事件被递送。进一步,你可以设置当一个套接口可用时,发送一个SIGIO,参看 socket(7)来详细了解。

对于一些需要显示验证的协议,比如说 DECNet,accept()只是从队列里取出连接请求,并没有执行验证。验证将在下次对新建的文件描述符进行正常的读或写时进行,并且拒绝可以通过关闭那个新建的套接口来进行。目前在Linux 中只有 DECNet 有如此语义。

flags 是 0,那么 accept4() 与 accept() 功能一样。下面flags 的值可能通过位求或运算来得到不同的行为:

SOCK_NONBLOCK
在新打开的文件描述符设置 O_NONBLOCK 标记。在 fcntl(2) 中保存这个标记可以得到相同的效果。
SOCK_CLOEXEC
在新打开的文件描述符里设置 close-on-exec (FD_CLOEXEC) 标记。参看在open(2) 里关于 O_CLOEXEC标记的描述来了解这为什么有用。

返回值

成功时,这个系统调用返回一个非负整数的文件描述符来代表接受的套接口。错误时,返回 -1,并把 errno设置为合适的值。

错误处理

在 Linux 里, accept() (和 accept4()) 把本属于accept() 的但未处理的网络错误传递给新建的套接口。 这个行为不同于其它 BSD 的实现。 可靠的应用应该在调用 accept() 之后检测相应协议可能的网络错误,并且处理 EAGAIN 一样重试一次。对于 TCP/IP来说,这些错误有 ENETDOWNEPROTOENOPROTOOPTEHOSTDOWNENONETEHOSTUNREACHEOPNOTSUPPENETUNREACH

错误

EAGAINEWOULDBLOCK
套接口被标记为非阻塞并且没有连接等待接受。POSIX.1-2001允许在此时返回这两种错误,但没有要求两个常量必须具有相同的值,所以可移植的程序应该同时检查两者。
EBADF
描述符无效。
ECONNABORTED
一个连接已经中止了。
EFAULT
参数 addr 不在可写的用户地址空间里。
EINTR
在一个有效的连接到达之前,本系统调用被信号中断,参看 signal(7)。
EINVAL
套接口不在监听连接,或 addrlen 无效(如是负数)。
EINVAL
(accept4()) 在 flags 中有无效的值。
EMFILE
达到单个进程打开的文件描述上限。
ENFILE
达到系统允许打开文件个数的全局上限。
ENOBUFS, ENOMEM
没有足够的自由内存。这通常是指套接口内存分配被限制,而不是指系统内存不足。
ENOTSOCK
描述符是一个文件,不是一个套接字。
EOPNOTSUPP
引用的套接口不是 SOCK_STREAM 类型的。
EPROTO
协议错误。

此外,Linux 下的 accept() 可能因如下原因失败:

EPERM
防火墙规则禁止连接。

还有,新建套接口和协议相关的网络错误也可能被返回。多种 Linux 内核还会返回诸如ENOSRESOCKTNOSUPPORTEPROTONOSUPPORTETIMEDOUT的错误。ERESTARTSYS 的值也可能需要关注。

版本

accept4() 系统调用从 Linux 2.6.28 开始支持,glibc 在版本 2.10 开始支持。

遵循于

accept():POSIX.1-2001, SVr4, 4.4BSD, ( accept() 首次出现在4.2BSD)。

accept4() 是非标准 Linux 扩展。

在 Linux 系统里,accept() 返回的新建的套接口 不会 继承监听套接口的诸如O_NONBLOCKO_ASYNC 这样的文件状态。这个行为与正规的 BSD套接口实现不一致。可移植的程序不应该假设文件状态是继承或不继承的,总是显示地设置 accept()返回的套接口需要的标记位。

注意

POSIX.1-2001 不要求包含 <sys/types.h>,并且这个头文件在 Linux中也不要求。然而一些历史(BSD)实现要求这个头文件,可移植的应用程序应该包含这个文件。

SIGIO 递送之后,在 select(2) 或 poll(2) 返回但连接却因为一个异步网络错误而删除之后,或在其它线程调用accept() 之前,不需要总是等待。如果这些事发生了,调用将被阻塞到一个新连接到来,为了让accept() 绝不阻塞,传入的 sockfd 需要设置 O_NONBLOCK 标记(参看socket(7))。

socklen_t 类型

accept() 的第三个参数最初被声明为 int* (在 libc4 和 libc5,以及一些诸如4.x BSD、SunOS4、SGI)。POSIX.1g 草案想把它改为 size_t *,这与SunOS 5是一样的,接着 POSIX 草案提出了 socklen_t *,并且在 Single UnixSpecification 和 glibc2 也是如此。Linus Torvalds 曾说:

“任何合理的库都必须保证 socklen_t 与 int 有相同的长度。否则的话都会与 BSD 套接口不同。POSIX 最初把它定义 为 size_t ,而我(同时也希望其他人,但显然不是太多)对他们表示强烈的不赞同。把它定义为 size_t将是完全地不兼容,尤其在 64 位系统里,size_t 很少跟 int 有相同的宽度。它 必须 与 int有相同的宽度,因为 BSD 接口是这样的。无论如何,制定 POSIX 的人还是创造出 socklen_t了。他们最初不应该去碰这个东西,但是一旦他们碰了,变会因为一些深奥的原因提供一个命名的类型(可能有些人因为之前愚笨的行为而丢脸时,就会静悄悄地他们的行为换个名字)。”

示例

参考 bind(2)。

参看

bind(2), connect(2), listen(2), select(2), socket(2), socket(7)


英文原版:http://man7.org/linux/man-pages/dir_all_alphabetic.html

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

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

相关文章

使用正则把数字前面的符号替换_正则表达式(一) 基本表达式

定义 正则表达式(Regular Expression)用某种模式去匹配一类字符串的公式&#xff0c;主要用来描述字符串匹配的工具。 匹配文本或字符存在不止一个部分满足给定的正则表达式&#xff0c;这是每一个这样的部分都被称为一个匹配。 匹配分为以下三种类型&#xff1a; 形容词性的匹…

解构给默认值_ES6学习 --函数参数默认值与解构赋值默认值

1. ES6的解构ES6中引入了解构赋值的操作&#xff0c;其作用是&#xff1a;将值从数组Array或属性从对象Object提取到不同的变量中即分为两种情况&#xff1a;从数组Array中解构&#xff0c;以及从对象Object中解构①.从数组中解构const [a, b] [1, 2]//a 1, b 2当然这些是基…

jsp思维导图_2019年经济法基础思维导图

参加2019年初级考试的考生们明天可以打印准考证啦时间&#xff1a;2019.4.26-5.5日(传送门&#xff1a;http://kjbm8.mof.gov.cn/ksbm/usercxzkz.jsp)为了帮助大家快速梳理教材考点&#xff0c;下面蓝星职业教育为大家整理了初级会计职称考试各章节思维导图&#xff0c;希望给大…

海量数据持久层解决方案_爱数AnyBackup重磅发布海量非结构化数据超可用解决方案...

海量非结构化数据有三大备份恢复问题一直没有得到有效解决&#xff1a;备份慢、恢复慢、备份数据不可查询。这三大问题已经对行业数字化转型造成了重大阻碍。今天&#xff0c;AnyBackup Family 7线上发布会——重磅发布海量非结构化数据超可用解决方案。AnyBackup以创新超可用技…

【PHP】伪静态 - 1. 使用正则表达式实现

在我们实际开发中&#xff0c;有需要&#xff0c;不希望使用真静态&#xff0c;但是希望利于SEO, 可以考虑使用伪静态。 http://localhost/news.php?typemusic&id100 我们希望这个地址可以用下面的访问url来替换 http://localhost/new-music-id100.html 上面的问题可以使用…

wpf 使子ui元素可视区域不超过父元素_对游戏UI设计的一点思考

UI决定了一个游戏的初体验&#xff0c;甚至决定了玩家的初始留存&#xff0c;甚至可以说决定了一个游戏的品质&#xff0c;虽然看起来是表象的&#xff0c;却是直指游戏核心的。简单讲&#xff0c;玩家认可一款游戏永远都是造型场景好&#xff0c;剧情好&#xff0c;画质棒&…

linux新的API signalfd、timerfd、eventfd使用说明

三种新的fd加入linux内核的的版本&#xff1a; signalfd&#xff1a;2.6.22 timerfd&#xff1a;2.6.25 eventfd&#xff1a;2.6.22 三种fd的意义&#xff1a; signalfd&#xff1a;传统的处理信号的方式是注册信号处理函数&#xff1b;由于信号是异步发生的&#xff0c;要…

grpc入门到精通_Spring Cloud 从入门到精通(一)Nacos 服务中心初探

点击上方蓝色“Java精选”&#xff0c;选择“设为星标”技术文章第一时间送达&#xff01;什么是Nacos&#xff1f;Nacos是阿里巴巴开源的项目&#xff0c;是一个更易于帮助构建云原生应用的动态服务发现、配置管理和服务管理平台。Nacos英文全称是Dynamic Naming and Configur…

百度新年贪吃蛇效果

闲来无事&#xff0c;在网上闲逛的时候开到有人说百度蛇年的贪吃蛇logo小游戏不错&#xff0c;于是乎就自己仿照写了一个。&#xff08;注&#xff1a;所有素材都来自百度&#xff09; 效果图 用到的图片 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional…

贝叶斯公式设b_数据分析经典模型——朴素贝叶斯

编辑导语&#xff1a;做过数据分析的人&#xff0c;想必对贝叶斯模型都不会陌生。贝叶斯预测模型是运用贝叶斯统计进行的一种预测&#xff0c;不同于一般的统计方法&#xff0c;其不仅利用模型信息和数据信息&#xff0c;而且充分利用先验信息。通过实证分析的方法&#xff0c;…

QGraphicsProxyWidget paintEvent(from 1+1 =2)

标题不好取&#xff0c;起源于CSDN中看到有网友提问&#xff1a;如果将一个QWidget同时显示在 QGraphicsView 和其他和view同级的普通的Widget中。 QGraphicsProxyWidget QGraphicsProxyWidget 是为将 QWidget 嵌入到 QGraphicsScene 中而引入的代理。 将 event 在二者之间进行…

Asterisk使用数据库配置方法

安装&#xff1a; 1、安装 unixODBC unixODBC-devel libtool-ltdl libtool-ltdl-devel &#xff0c;为了使asterisk支持数据库存储&#xff08;必须先安装&#xff09; 2、安装 mysql 并设置好 C_INCLUDE_PATH 和 LD_LIBRARY_PATH 3、从 http://www.asterisk.org/downloads 下载…

linux文件系统_Linux的文件系统简介

inux操作系统的本质可以说就是文件系统的集合&#xff0c;文件系统既包含文件的数据也包含文件系统的结构。在Linux文件系统中&#xff0c;EXT2文件系统、虚拟文件系统、/proc文件系统是三个具有代表性的文件系统。/proc文件系统是一个伪文件系统&#xff0c;它只存在内存当中&…

matlab如何测两点的角度_根据2点经纬度,计算方位角,以及计算2条线的夹角

以真北为0度起点&#xff0c;由东向南向西顺时针旋转360度&#xff0c;主要是用于控制象限。根据2点经纬度&#xff0c;计算方位角[csharp]////// 给定2点&#xff0c;获得经纬度/// /// 起点经纬度&#xff0c;都是以度为单位/// 终点经纬度&#xff0c;都是以度为单位/// pri…

VMWare 环境下devstack创建虚拟机报错及修改nova-api返回数据得条目

1、在生产环境中&#xff0c; 由于某个tenant下创建了有1300条得security-group通过查询nova得数据库可以看出确实有1300条得存在&#xff0c;但是通过curl调用的时候发现返回得数目只有1000条 可以通过修改nova.conf文件得osapi_max_limit 项修改返回得条目限制&#xff0c;默…

使用数据库保存Asterisk sip账号信息(odbc方式)

在默认情况下&#xff0c;Asterisk的配置文件都保存在/etc/asterisk目录中&#xff0c;以ini文件的格式保存。我们也可以使用数据库来保存大多数Asterisk配置信息。 Asterisk使用数据库保存配置信息有两种方法&#xff1a;静态和动态&#xff0c;对于不经常修改的配置数据&…

删除按钮_汪涵拜师学艺第七篇:往来单位查询删除按钮和新增判断的设计!

老师好&#xff01;大家好&#xff01;我叫汪涵&#xff1a;今天给大家分享往来单位查询删除按钮和新增判断的设计&#xff01;在开始具体内容之前&#xff0c;请让我先分享我们的价值观&#xff1a;用自律和勤奋来改变命运&#xff0c;不走捷径&#xff0c;有爱心&#xff0c;…

python requests https_解决python的requests模块访问私有SSL证书产生的报错问题

如题访问部分私有SSL证书网站时报如下错误requests.exceptions.SSLError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed (_ssl.c:581)测试环境kali linux 1.1.0Python 2.7.8python-openssl 0.13-2deb7u1requests 2.3.0测试代码#/usr/bin/python#codingutf-8imp…

Ubuntu 12.04(32位)安装Oracle 11g(32位)全过程以及几乎所有问题的解决办法

这两天在Ubuntu上安装Oracle把人折腾毁了&#xff0c;即使照着网上的教程来&#xff0c;还是出了很多问题。好在最后终于搞定了。写出来总结一下&#xff0c;免得以后忘了。 标题注明32位是因为网上教程几乎全是以64位安装为例的&#xff0c;32位系统下照着做是绝对会安装失败的…

dio设置自定义post请求_Flutter Dio简单二次封装和自定义Header

话不多说自己看代码封装的比较简单&#xff0c;比较适合入门学习Dio。import package:dio/dio.dart;import Api.dart;/** 封装 restful 请求** GET、POST、DELETE、PATCH* 主要作用为统一处理相关事务&#xff1a;* - 统一处理请求前缀&#xff1b;* - 统一打印请求信息&#x…