ZMQ_SEND(3) | 0MQ Manual | ZMQ_SEND(3) |
NAME
zmq_send - send a message part on a socket
SYNOPSIS
int zmq_send (void *socket, const void *buf, size_t len, int flags);
DESCRIPTION
The zmq_send() function shall queue a message created from the buffer referenced by the buf and len arguments. The flags argument is a combination of the flags defined below:
ZMQ_DONTWAIT
ZMQ_SNDMORE
Note
A successful invocation of zmq_send() does not indicate that the message has been transmitted to the network, only that it has been queued on the socket and 0MQ has assumed responsibility for the message.
Multi-part messages
A 0MQ message is composed of 1 or more message parts. 0MQ ensures atomic delivery of messages: peers shall receive either all message parts of a message or none at all. The total number of message parts is unlimited except by available memory.
An application that sends multi-part messages must use the ZMQ_SNDMORE flag when sending each message part except the final one.
RETURN VALUE
The zmq_send() function shall return number of bytes in the message if successful. Otherwise it shall return -1 and set errno to one of the values defined below.
ERRORS
EAGAIN
ENOTSUP
EINVAL
EFSM
ETERM
ENOTSOCK
EINTR
EHOSTUNREACH
EXAMPLE
Sending a multi-part message.
/* Send a multi-part message consisting of three parts to socket */ rc = zmq_send (socket, "ABC", 3, ZMQ_SNDMORE); assert (rc == 3); rc = zmq_send (socket, "DEFGH", 5, ZMQ_SNDMORE); assert (rc == 5); /* Final part; no more parts to follow */ rc = zmq_send (socket, "JK", 2, 0); assert (rc == 2);
SEE ALSO
AUTHORS
This page was written by the 0MQ community. To make a change please read the 0MQ Contribution Policy at http://www.zeromq.org/docs:contributing.
10/23/2023 | 0MQ 4.3.5 |