Man page - nng_recv_aio(3)
Packages contains this manual
- nng_inproc(7)
- nng_msg_header(3)
- nng_push_open(3)
- nng_ipc_options(5)
- nng_bus_open(3)
- nng_tls_options(5)
- nng_aio_result(3)
- nng_pipe_socket(3)
- nng_msg(5)
- nng_stat_child(3)
- nng_pipe_get(3)
- nng_dialer_close(3)
- nng_tcp_register(3)
- nng_url_clone(3)
- nng_msg_free(3)
- nng_dialer_set(3)
- nng_sockaddr_zt(5)
- nng_pull(7)
- nng_stat_unit(3)
- nng_wss_register(3)
- nng_socket_proto_id(3)
- nng_ws_register(3)
- nng_pull_open(3)
- nng_stat_type(3)
- nng_stat_next(3)
- nng_listener_close(3)
- nng_setopt(3)
- nng_msg_insert(3)
- nng_aio_cancel(3)
- nng_listener_set(3)
- nng_msg_realloc(3)
- nng_log(3)
- nng_duration(5)
- nng_options(5)
- nng_strfree(3)
- nng_device(3)
- nng_msg_header_insert(3)
- nng_stat_find_listener(3)
- nng_stat_bool(3)
- nng_aio_set_timeout(3)
- nng_iov(5)
- nng_listener_setopt(3)
- nng_pipe_dialer(3)
- nng_msg_append(3)
- nng_aio_finish(3)
- nng_ws(7)
- nng_stream_listener(5)
- nng_aio_set_output(3)
- nng_ctx_get(3)
- nng_stat_find(3)
- nng_dialer_create(3)
- nng_dialer_getopt(3)
- nng_msg_header_len(3)
- nng_sendmsg(3)
- nng_listener_start(3)
- nng_socket(5)
- nng_str_sockaddr(3)
- nng_dialer_id(3)
- nng_msg_alloc(3)
- nng_recv_aio(3)
- nng_stats_free(3)
- nng_listener_getopt(3)
- nng_recvmsg(3)
- nng_ctx_getopt(3)
- nng_ctx_close(3)
- nng_alloc(3)
- nng_stat_string(3)
- nng(7)
- nng_listener_id(3)
- nng_msg_get_pipe(3)
- nng_aio_get_output(3)
- nng_pipe_getopt(3)
- nng_tcp(7)
- nng_pipe_notify(3)
- libnng(3)
- nng_stats_get(3)
- nng_surveyor_open(3)
- nng_aio_defer(3)
- nng_aio_count(3)
- nng_msg_chop(3)
- nng_sockaddr_abstract(5)
- nng_pipe_id(3)
- nng_msg_header_trim(3)
- nng_stream_dialer(5)
- nng_url_parse(3)
- nng_send(3)
- nng_tls_config(5)
- nng_strerror(3)
- nng_req(7)
- nng_dialer_setopt(3)
- nng_ctx(5)
- nng_respondent(7)
- nng_aio_begin(3)
- nng_dialer_get(3)
- nng_pipe_close(3)
- nng_aio_wait(3)
- nng_tcp_options(5)
- nng_ctx_id(3)
- nng_version(3)
- nng_dial(3)
- nng_stat_timestamp(3)
- nng_ipc_register(3)
- nng_stat_find_socket(3)
- nng_aio_set_iov(3)
- nng_rep(7)
- nng_msg_header_chop(3)
- nng_stat_find_dialer(3)
- nng_listener_get(3)
- nng_url(5)
- nng_zt_register(3)
- nng_zerotier(7)
- nng_req_open(3)
- nng_log_set_facility(3)
- nng_sub(7)
- nng_inproc_register(3)
- nng_listener_create(3)
- nng_aio_set_input(3)
- nng_stat_value(3)
- nng_aio_alloc(3)
- nng_ctx_open(3)
- nng_msg_len(3)
- nng_sockaddr_in(5)
- nng_ipc(7)
- nng_aio_get_input(3)
- nng_tls(7)
- nng_socket_raw(3)
- nng_sockaddr_inproc(5)
- nng_dialer_start(3)
- nng_surveyor(7)
- nng_close(3)
- nng_pub_open(3)
- nng_stream(5)
- nng_msg_set_pipe(3)
- nng_aio(5)
- nng_aio_stop(3)
- nng_pipe(5)
- nng_aio_free(3)
- nng_free(3)
- nng_sockaddr_ipc(5)
- nng_log_set_logger(3)
- nng_url_free(3)
- nng_listen(3)
- nng_aio_set_msg(3)
- nng_respondent_open(3)
- nng_rep_open(3)
- nng_getopt(3)
- nng_msg_body(3)
- nng_listener(5)
- nng_log_set_level(3)
- nng_pipe_listener(3)
- nng_aio_get_msg(3)
- nng_push(7)
- nng_socket_get(3)
- nng_ctx_set(3)
- nng_sub_open(3)
- nng_ctx_setopt(3)
- nng_socket(7)
- nng_stat(5)
- nng_tls_register(3)
- nng_sockaddr_in6(5)
- nng_aio_abort(3)
- nng_msg_dup(3)
- nng_socket_set(3)
- nng_send_aio(3)
- nng_recv(3)
- nng_pair(7)
- nng_sockaddr(5)
- nng_ctx_recv(3)
- nng_pair_open(3)
- nng_msg_clear(3)
- nng_sleep_aio(3)
- nng_stat_desc(3)
- nng_dialer(5)
- nng_strdup(3)
- nng_ctx_send(3)
- nng_msg_header_append(3)
- nng_msg_header_clear(3)
- nng_socket_proto_name(3)
- nng_socket_id(3)
- nng_log_get_level(3)
- nng_tls_engine(5)
- nng_pub(7)
- nng_stat_name(3)
- nng_msg_trim(3)
- nng_bus(7)
apt-get install libnng-dev
Manual
NNG_RECV_AIO
NAMESYNOPSIS
DESCRIPTION
RETURN VALUES
ERRORS
SEE ALSO
NAME
nng_recv_aio - receive message asynchronously
SYNOPSIS
#include <nng/nng.h>
void nng_recv_aio(nng_socket s, nng_aio *aio);
DESCRIPTION
The nng_recv_aio() receives a message using the socket s asynchronously.
When a message is successfully received by the socket, it is stored in the aio by an internal call equivalent to nng_aio_set_msg(), then the completion callback on the aio is executed. In this case, nng_aio_result() will return zero. The callback function is responsible for retrieving the message and disposing of it appropriately.
Important
Failing to accept and dispose of messages in this case can lead to memory leaks.
If for some reason the asynchronous receive cannot be completed successfully (including by being canceled or timing out), then the callback will still be executed, but nng_aio_result() will be non-zero.
Note
The semantics of what receiving a message means varies from protocol to protocol, so examination of the protocol documentation is encouraged. (For example, with a pub socket the data is broadcast, so that any peers who have a suitable subscription will be able to receive it using nng_recv() or a similar function.) Furthermore, some protocols may not support receiving (such as pub ) or may require other conditions. (For example, req sockets cannot normally receive data, which are replies to requests, until they have first sent a request.)
RETURN VALUES
None. (The operation completes asynchronously.)
ERRORS
NNG_ECANCELED
The operation was aborted.
NNG_ECLOSED
The socket s is not open.
NNG_ENOMEM
Insufficient memory is available.
NNG_ENOTSUP
The protocol for socket s does not support receiving.
NNG_ESTATE
The socket s cannot receive data in this state.
NNG_ETIMEDOUT
The receive timeout expired.
SEE ALSO
nng_aio_get_msg(3), nng_aio_set_msg(3), nng_msg_alloc(3), nng_strerror(3), nng_aio(5), nng_msg(5), nng_socket(5), nng(7)