socket_select() - socket通信函数
socket_select()
(PHP 4 >= 4.1.0, PHP 5, PHP 7)
Runs the select()system call on the given arrays of sockets with a specified timeout
说明
socket_select(array &$read,array &$write,array &$except,int $tv_sec[,int $tv_usec= 0]): intsocket_select()accepts arrays of sockets and waits for them to change status. Those coming with BSD sockets background will recognize that those socket resource arrays are in fact the so-called file descriptor sets. Three independent arrays of socket resources are watched.
参数
$readThe sockets listed in the$readarray will be watched to see if characters become available for reading(more precisely, to see if a read will not block - in particular, a socket resource is also ready on end-of-file, in which case a socket_read() will return a zero length string).
$writeThe sockets listed in the$writearray will be watched to see if a write will not block.
$exceptThe sockets listed in the$exceptarray will be watched for exceptions.
$tv_secThe$tv_secand$tv_usectogether form thetimeoutparameter. Thetimeoutis an upper bound on the amount of time elapsed beforesocket_select()return.$tv_secmay be zero , causingsocket_select()to return immediately. This is useful for polling. If$tv_secisNULL
(no timeout),socket_select()can block indefinitely.
On exit, the arrays are modified to indicate which socket resource actually changed status.
You do not need to pass every array tosocket_select(). You can leave it out and use an empty array orNULL
instead. Also do not forget that those arrays are passedby referenceand will be modified aftersocket_select()returns.
Note:
Due a limitation in the current Zend Engine it is not possible to pass a constant modifier likeNULL
directly as a parameter to a function which expects this parameter to be passed by reference. Instead use a temporary variable or an expression with the leftmost member being a temporary variable:
UsingNULL
withsocket_select()
返回值
On successsocket_select()returns the number of socket resources contained in the modified arrays, which may be zero if the timeout expires before anything interesting happens. On errorFALSE
is returned. The error code can be retrieved with socket_last_error().
Note:
Be sure to use the===operator when checking for an error. Since thesocket_select()may return 0 the comparison with==would evaluate toTRUE
:
Understandingsocket_select()'s result
范例
socket_select()example
注释
Note:
Be aware that some socket implementations need to be handled very carefully. A few basic rules:
- You should always try to usesocket_select()without timeout. Your program should have nothing to do if there is no data available. Code that depends on timeouts is not usually portable and difficult to debug.
- No socket resource must be added to any set if you do not intend to check its result after thesocket_select()call, and respond appropriately. Aftersocket_select()returns, all socket resources in all arrays must be checked. Any socket resource that is available for writing must be written to, and any socket resource available for reading must be read from.
- If you read/write to a socket returns in the arrays be aware that they do not necessarily read/write the full amount of data you have requested. Be prepared to even only be able to read/write a single byte.
- It's common to most socket implementations that the only exception caught with the$exceptarray is out-of-bound data received on a socket.
参见
socket_read()
Reads a maximum of length bytes from a socketsocket_write()
Write to a socketsocket_last_error()
Returns the last error on the socketsocket_strerror()
Return a string describing a socket error
A simple PHP script using socket_select() to manage multiple connections. connect using "telnet localhost 9050". it broadcasts your messages that you send through telnet to other users connected to the server -- sort of like a chat script #!/usr/local/bin/php
鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com
图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!