
Last chance! 50% off unlimited learning
Sale ends in
Send data over a connection (Socket, Context or Stream).
send(con, data, mode = c("serial", "raw"), block = NULL)
Integer exit code (zero on success).
a Socket, Context or Stream.
an object (a vector, if mode = 'raw').
[default 'serial'] for sending serialised R objects, or 'raw' for sending vectors of any type (converted to a raw byte vector for sending). For Streams, 'raw' is the only option and this argument is ignored. Use 'serial' for perfect reproducibility within R, although 'raw' must be used when interfacing with external applications that do not understand R serialisation. Alternatively, for performance, specify an integer position in the vector of choices i.e. 1L for 'serial' or 2L for 'raw'.
[default NULL] which applies the connection default (see section 'Blocking' below). Specify logical TRUE to block until successful or FALSE to return immediately even if unsuccessful (e.g. if no connection is available), or else an integer value specifying the maximum time to block in milliseconds, after which the operation will time out.
For Sockets: the default behaviour is non-blocking with block = FALSE
.
This will return immediately with an error if the message could not be
queued for sending. Certain protocol / transport combinations may limit
the number of messages that can be queued if they have yet to be received.
For Contexts and Streams: the default behaviour is blocking with
block = TRUE
. This will wait until the send has completed. Set a
timeout in this case to ensure that the function returns under all scenarios.
As the underlying implementation uses an asynchronous send with a wait,
it is recommended to set a positive integer value for block
rather
than FALSE.
pub <- socket("pub", dial = "inproc://nanonext")
send(pub, data.frame(a = 1, b = 2))
send(pub, c(10.1, 20.2, 30.3), mode = "raw", block = 100)
close(pub)
req <- socket("req", listen = "inproc://nanonext")
rep <- socket("rep", dial = "inproc://nanonext")
ctx <- context(req)
send(ctx, data.frame(a = 1, b = 2), block = 100)
msg <- recv_aio(rep, timeout = 100)
send(ctx, c(1.1, 2.2, 3.3), mode = "raw", block = 100)
close(req)
close(rep)
Run the code above in your browser using DataLab