Php/docs/function.msg-send
msg_send
(PHP 4 >= 4.3.0, PHP 5, PHP 7)
msg_send — Send a message to a message queue
说明
msg_send
( SysvMessageQueue $queue
, int $message_type
, string|int|float|bool $message
[, bool $serialize = true
[, bool $blocking = true
[, int &$error_code = null
]]] ) : bool
msg_send() sends a message of type
message_type (which MUST be greater than 0) to
the message queue specified by queue.
参数
queueThe message queue.
message_typeThe type of the message (MUST be greater than 0)
messageThe body of the message.
Note:
If
serializeset tofalseis supplied, MUST be of type: string, int, float or bool. In other case a warning will be issued.serializeThe optional
serializecontrols how themessageis sent.serializedefaults totruewhich means that themessageis serialized using the same mechanism as the session module before being sent to the queue. This allows complex arrays and objects to be sent to other PHP scripts, or if you are using the WDDX serializer, to any WDDX compatible client.blockingIf the message is too large to fit in the queue, your script will wait until another process reads messages from the queue and frees enough space for your message to be sent. This is called blocking; you can prevent blocking by setting the optional
blockingparameter tofalse, in which case msg_send() will immediately returnfalseif the message is too big for the queue, and set the optionalerror_codetoMSG_EAGAIN, indicating that you should try to send your message again a little later on.error_codeIf the function fails, the optional errorcode will be set to the value of the system errno variable.
返回值
成功时返回 true, 或者在失败时返回 false。
Upon successful completion the message queue data structure is updated as
follows: msg_lspid is set to the process-ID of the
calling process, msg_qnum is incremented by 1 and
msg_stime is set to the current time.
更新日志
| 版本 | 说明 |
|---|---|
| 8.0.0 | queue expects a SysvMessageQueue
instance now; previously, a resource was expected. |
参见
- msg_remove_queue() - Destroy a message queue
- msg_receive() - Receive a message from a message queue
- msg_stat_queue() - Returns information from the message queue data structure
- msg_set_queue() - Set information in the message queue data structure