blob: 59a0dfc69d043bac3c180ea11804b3dac949d41e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
## nng_aio_free
Free asynchronous I/O handle.
### Synopsis
```c
#include <nng/nng.h>
void nng_aio_free(nng_aio *aio);
void nng_aio_reap(nng_aio *aio);
```
### Description
The `nng_aio_free` function frees an allocated asynchronous I/O handle.
If any operation is in progress, the operation is canceled, and the caller is blocked until the operation is completely canceled, to ensure that it is safe to deallocate the handle and any associated resources.
(This is done by implicitly calling xref:nng_aio_stop.adoc[`nng_aio_stop`].)
The `nng_aio_reap` function is the same as `nng_aio_free`, but does its work in a background thread.
This can be useful to discard the _aio_ object from within the callback for the _aio_.
IMPORTANT: Once either of these functions are called, the _aio_ object is invalid and must not be used again.
### See Also
xref:nng_aio_alloc.adoc[nng_aio_alloc],
xref:nng_aio_stop.adoc[nng_aio_stop],
|