Unix/Linux系統調用
accept()函數 Unix/Linux
access()函數 Unix/Linux
acct()函數 Unix/Linux
add_key()函數 Unix/Linux
adjtimex()函數 Unix/Linux
afs_syscall()函數 Unix/Linux
alarm()函數 Unix/Linux
alloc_hugepages()函數 Unix/Linux
arch_prctl()函數 Unix/Linux
bdflush()函數 Unix/Linux
bind()函數 Unix/Linux
break未實現 Unix/Linux
brk()函數 Unix/Linux
cacheflush()函數 Unix/Linux
chdir()函數 Unix/Linux
chmod()函數 Unix/Linux
chown()函數 Unix/Linux
chroot()函數 Unix/Linux
clone()函數 Unix/Linux
close()函數 Unix/Linux
connect()函數 Unix/Linux
create_module()函數 Unix/Linux
open()函數 Unix/Linux
dup2()函數 Unix/Linux
dup()函數 Unix/Linux
epoll_create()函數 Unix/Linux
epoll_ctl()函數 Unix/Linux
epoll_wait()函數 Unix/Linux
execve()函數 Unix/Linux
exit_group函數 Unix/Linux
_exit()函數 Unix/Linux
exit()函數 Unix/Linux
faccessat()函數 Unix/Linux
fattach()函數 Unix/Linux
fchdir()函數 Unix/Linux
fchmodat()函數 Unix/Linux
fchmod()函數 Unix/Linux
fchownat()函數 Unix/Linux
fchown()函數 Unix/Linux
fcntl()函數 Unix/Linux
fdatasync()函數 Unix/Linux
fdetach()函數 Unix/Linux
flock()函數 Unix/Linux
fork()函數 Unix/Linux
alloc_hugepages()函數 Unix/Linux
fstatat()函數 Unix/Linux
statfs()函數 Unix/Linux
stat()函數 Unix/Linux
statvfs()函數 Unix/Linux
fsync()函數 Unix/Linux
truncate()函數 Unix/Linux
futex()函數 Unix/Linux
futimesat()函數 Unix/Linux
getcontext()函數 Unix/Linux
getcwd()函數 Unix/Linux
getdents()函數 Unix/Linux
getdomainname()函數 Unix/Linux
getdtablesize()函數 Unix/Linux
getgid()函數 Unix/Linux
getuid()函數 Unix/Linux
getgroups()函數 Unix/Linux
getgroups()函數 Unix/Linux
gethostname()函數 Unix/Linux
getitimer()函數 Unix/Linux
get_kernel_syms()函數 Unix/Linux
unimplemented()函數 Unix/Linux
getpagesize()函數 Unix/Linux
getpeername()函數 Unix/Linux
setpgid()函數 Unix/Linux
getpgrp()函數 Unix/Linux
getpid()函數 Unix/Linux
getpmsg()函數 Unix/Linux
getppid()函數 Unix/Linux
getpriority()函數 Unix/Linux
getresuid()函數 Unix/Linux
getrlimit()函數 Unix/Linux
get_robust_list()函數 Unix/Linux
getrusage()函數 Unix/Linux
getsid()函數 Unix/Linux
getsockname()函數 Unix/Linux
getsockopt()函數 Unix/Linux
get_thread_area()函數 Unix/Linux
gettid()函數 Unix/Linux
gettimeofday()函數 Unix/Linux
getuid()函數 Unix/Linux
getunwind()函數 Unix/Linux
gtty()函數 Unix/Linux
idle()函數 Unix/Linux
outb()函數 Unix/Linux
inb_p()函數 Unix/Linux
inl()函數 Unix/Linux
inl_p()函數 Unix/Linux
inotify_add_watch()函數 Unix/Linux
inotify_init()函數 Unix/Linux
inotify_rm_watch()函數 Unix/Linux
outb()函數 Unix/Linux
insl()函數 Unix/Linux
insw()函數 Unix/Linux
intro()函數 Unix/Linux
inw()函數 Unix/Linux
inw_p()函數 Unix/Linux
io_cancel()函數 Unix/Linux
ioctl()函數 Unix/Linux
ioctl_list()函數 Unix/Linux
io_destroy()函數 Unix/Linux
io_getevents()函數 Unix/Linux
ioperm()函數 Unix/Linux
iopl()函數 Unix/Linux
ioprio_set()函數 Unix/Linux
io_setup()函數 Unix/Linux
io_submit()函數 Unix/Linux
ipc()函數 Unix/Linux
isastream()函數 Unix/Linux
kexec_load()函數 Unix/Linux
keyctl()函數 Unix/Linux
kill()函數 Unix/Linux
killpg()函數 Unix/Linux
lchown()函數 Unix/Linux
linkat()函數 Unix/Linux
link()函數 Unix/Linux
listen()函數 Unix/Linux
_llseek()函數 Unix/Linux
llseek()函數 Unix/Linux
lock()函數 Unix/Linux
lookup_dcookie()函數 Unix/Linux
lseek()函數 Unix/Linux
lstat()函數 Unix/Linux
madvise()函數 Unix/Linux
mincore()函數 Unix/Linux
mkdirat()函數 Unix/Linux
mkdir()函數 Unix/Linux
mknod()函數 Unix/Linux
mlockall()函數 Unix/Linux
mlock()函數 Unix/Linux
mmap2()函數 Unix/Linux
mmap()函數 Unix/Linux
modify_ldt()函數 Unix/Linux
mount()函數 Unix/Linux
move_pages()函數 Unix/Linux
mprotect()函數 Unix/Linux
mpx()函數 Unix/Linux
mq_getsetattr()函數 Unix/Linux
mremap()函數 Unix/Linux
msgctl()函數 Unix/Linux
msgget()函數 Unix/Linux
msgop()函數 Unix/Linux
msgsnd()函數 Unix/Linux
msync()函數 Unix/Linux
multiplexer()函數 Unix/Linux
munlockall()函數 Unix/Linux
munlock()函數 Unix/Linux
munmap()函數 Unix/Linux
nanosleep()函數 Unix/Linux
_newselect()函數 Unix/Linux
nfsservctl()函數 Unix/Linux
nice()函數 Unix/Linux
obsolete()函數 Unix/Linux
oldfstat()函數 Unix/Linux
oldlstat()函數 Unix/Linux
oldolduname()函數 Unix/Linux
oldstat()函數 Unix/Linux
olduname()函數 Unix/Linux
openat()函數 Unix/Linux
open()函數 Unix/Linux
outb()函數 Unix/Linux
outb_p()函數 Unix/Linux
outsb()函數 Unix/Linux
outsl()函數 Unix/Linux
outsw()函數 Unix/Linux
outw()函數 Unix/Linux
outw_p()函數 Unix/Linux
path_resolution()函數 Unix/Linux
pause()函數 Unix/Linux
perfmonctl()函數 Unix/Linux
personality()函數 Unix/Linux
pipe()函數 Unix/Linux
pivot_root()函數 Unix/Linux
poll()函數 Unix/Linux
posix_fadvise()函數 Unix/Linux
ppoll()函數 Unix/Linux
prctl()函數 Unix/Linux
pread()函數 Unix/Linux
prof()函數 Unix/Linux
pselect()函數 Unix/Linux
ptrace()函數 Unix/Linux
putmsg()函數 Unix/Linux
putpmsg()函數 Unix/Linux
pwrite()函數 Unix/Linux
query_module()函數 Unix/Linux
quotactl()函數 Unix/Linux
readahead()函數 Unix/Linux
readdir()函數 Unix/Linux
read()函數 Unix/Linux
readlinkat()函數 Unix/Linux
readlink()函數 Unix/Linux
readv()函數 Unix/Linux
reboot()函數 Unix/Linux
recvfrom()函數 Unix/Linux
recv()函數 Unix/Linux
recvmsg()函數 Unix/Linux
remap_file_pages()函數 Unix/Linux
renameat()函數 Unix/Linux
rename()函數 Unix/Linux
request_key()函數 Unix/Linux
rmdir()函數 Unix/Linux
sbrk()函數 Unix/Linux
sched_setaffinity()函數 Unix/Linux
sched_getparam()函數 Unix/Linux
sched_get_priority_max()函數 Unix/Linux
sched_get_priority_min()函數 Unix/Linux
sched_setscheduler()函數 Unix/Linux
sched_rr_get_interval()函數 Unix/Linux
sched_setparam()函數 Unix/Linux
sched_yield()函數 Unix/Linux
security()函數 Unix/Linux
select()函數 Unix/Linux
select_tut()函數 Unix/Linux
semctl()函數 Unix/Linux

accept()函數 Unix/Linux

名稱

accept - 接受連接套接字上

內容簡介

#include <sys/types.h>
#include <sys/socket.h>

int accept(int sockfd**, struct sockaddr *addr, socklen_t *addrlen);**

描述說明

accept()系統調用用於基於連接的套接字類型(SOCK_STREAM,SOCK_SEQPACKET)。提取完成連接隊列中的第一個連接請求,創建一個新的連接套接字,並返回一個新的文件描述符,指該套接字。新創建的套接字處於監聽狀態。原始套接字 sockfd 不受此調用。

參數 sockfd 是一個套接字綁定到本地地址 bind(2) socket(2),已創建偵聽連接後 listen(2)。 

參數addr是一個指向結構sockaddr。被填充在此結構的對等套接字的地址,作爲已知的通信層。地址返回 addr 的確切格式由套接字的地址族(參見socket(2)及相應協議的手冊頁)。

addrlen 參數是一個值結果參數:最初它應該包含大小addr所指向的結構,在函數返回時將包含實際的長度(以字節爲單位)返回的地址。當沒有填寫addr是NULL。

如果沒有掛起的連接隊列,並沒有被標記爲非阻塞套接字,accept() 將阻塞,直到建立連接。如果套接字被標記無阻塞,沒有未完成連接隊列上,accept() 失敗,並出現錯誤EAGAIN。

爲了通知傳入連接在套接字上,那麼可以使用select(2)或 orpoll(2)。當嘗試一個新的連接,然後可以調用accept() 獲取套接字,連接一個可讀事件將被傳遞。另外,您還可以設置套接字提供SIGIO活動發生在一個socket時,詳情參見socket(7)。

需要一個明確的確認,如 DECNET 對於某些協議,accept() 可以被看作是僅僅從隊列中取出下一個連接請求,不意味着確認。確認可以正常的讀或寫上新的文件描述符,暗示和排斥反應,可通過關閉新的套接字暗示。目前只有DECNet有這樣的Linux上的語義。

注意

可能並不總是等待一個連接後 SIGIO 交付 select(2) 或 poll(2) 因爲連接可能已被刪除,被稱爲異步網絡錯誤或另一個線程 accept() 返回一個可讀性事件。如果發生這種情況,那麼調用將阻塞等待下一個連接到達。

爲了確保 accept() 從未阻塞,通過套接字sockfd中需要有O_NONBLOCK標誌設置(參見socket(7))。

返回值

如果成功,accept()返回一個非負的整數,這是一個接受套接字描述符。上的錯誤,則返回-1,errno設置爲合適。

錯誤處理

Linux 的 accept() 傳遞已經掛起的網絡錯誤,在新的socket accept() 錯誤代碼。此行爲不同於其他的BSD套接字實現。對於可靠運行的應用程序應該檢測網絡錯誤定義的協議後accept() ,並把它們像EAGAIN重試。在這些情況下,TCP/ IP是ENETDOWN ENOPROTOOPT EPROTO,EHOSTDOWN,ENONET,EHOSTUNREACH,EOPNOTSUPP,和ENETUNREACH的。 

錯誤

accept()可能失敗如下:

標籤

描述

EAGAINorEWOULDBLOCK

The socket is marked non-blocking and no connections are present to be accepted.

EBADF

The descriptor is invalid.

ECONNABORTED

A connection has been aborted.

EINTR

The system call was interrupted by a signal that was caught before a valid connection arrived.

EINVAL

Socket is not listening for connections, or addrlen is invalid (e.g., is negative).

EMFILE

The per-process limit of open file descriptors has been reached.

ENFILE

The system limit on the total number of open files has been reached.

ENOTSOCK

The descriptor references a file, not a socket.

EOPNOTSUPP

The referenced socket is not of typeSOCK_STREAM.

accept() 可能會失敗,如下:

標籤

描述

EFAULT

The addr argument is not in a writable part of the user address space.

ENOBUFS, ENOMEM

Not enough free memory. This often means that the memory allocation is limited by the socket bufferlimits, not by the system memory.

EPROTO

Protocol error.

Linux accept() 可能會失敗,如下:

標籤

描述

EPERM

Firewall rules forbid connection.

此外,新的套接字的協議所定義的網絡錯誤可能被返回。各種 Linux 內核可以返回其他錯誤,如ENOSR ESOCKTNOSUPPORT,EPROTONOSUPPORT ETIMEDOUT。在跟蹤過程中,可能會出現值ERESTARTSYS。

遵循於

SVr4, 4.4BSD (accept() first appeared in 4.2BSD).

注意

最初是作爲一個'‘int *’'聲明 accept()的第三個參數(libc4和libc5和許多其他系統,如4.x的BSD,SunOS 4上,SGI);下一個POSIX.1g標準草案希望改變它變成了'size_t*',那是什麼它是在SunOS5。後來POSIX匯票「socklen_t*」,這樣做對單一Unix規範和glibc2。

另請參閱

  • bind (2)

  • connect (2)

  • listen (2)

  • select (2)

  • socket (2)