Imported Upstream version 1.64.0
[platform/upstream/boost.git] / doc / html / boost_asio / reference / basic_datagram_socket.html
1 <html>
2 <head>
3 <meta http-equiv="Content-Type" content="text/html; charset=US-ASCII">
4 <title>basic_datagram_socket</title>
5 <link rel="stylesheet" href="../../../../doc/src/boostbook.css" type="text/css">
6 <meta name="generator" content="DocBook XSL Stylesheets V1.79.1">
7 <link rel="home" href="../../boost_asio.html" title="Boost.Asio">
8 <link rel="up" href="../reference.html" title="Reference">
9 <link rel="prev" href="async_write_at/overload4.html" title="async_write_at (4 of 4 overloads)">
10 <link rel="next" href="basic_datagram_socket/assign.html" title="basic_datagram_socket::assign">
11 </head>
12 <body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF">
13 <table cellpadding="2" width="100%"><tr>
14 <td valign="top"><img alt="Boost C++ Libraries" width="277" height="86" src="../../../../boost.png"></td>
15 <td align="center"><a href="../../../../index.html">Home</a></td>
16 <td align="center"><a href="../../../../libs/libraries.htm">Libraries</a></td>
17 <td align="center"><a href="http://www.boost.org/users/people.html">People</a></td>
18 <td align="center"><a href="http://www.boost.org/users/faq.html">FAQ</a></td>
19 <td align="center"><a href="../../../../more/index.htm">More</a></td>
20 </tr></table>
21 <hr>
22 <div class="spirit-nav">
23 <a accesskey="p" href="async_write_at/overload4.html"><img src="../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../reference.html"><img src="../../../../doc/src/images/up.png" alt="Up"></a><a accesskey="h" href="../../boost_asio.html"><img src="../../../../doc/src/images/home.png" alt="Home"></a><a accesskey="n" href="basic_datagram_socket/assign.html"><img src="../../../../doc/src/images/next.png" alt="Next"></a>
24 </div>
25 <div class="section">
26 <div class="titlepage"><div><div><h3 class="title">
27 <a name="boost_asio.reference.basic_datagram_socket"></a><a class="link" href="basic_datagram_socket.html" title="basic_datagram_socket">basic_datagram_socket</a>
28 </h3></div></div></div>
29 <p>
30         Provides datagram-oriented socket functionality.
31       </p>
32 <pre class="programlisting"><span class="keyword">template</span><span class="special">&lt;</span>
33     <span class="keyword">typename</span> <a class="link" href="Protocol.html" title="Protocol requirements">Protocol</a><span class="special">,</span>
34     <span class="keyword">typename</span> <a class="link" href="DatagramSocketService.html" title="Datagram socket service requirements">DatagramSocketService</a> <span class="special">=</span> <span class="identifier">datagram_socket_service</span><span class="special">&lt;</span><span class="identifier">Protocol</span><span class="special">&gt;&gt;</span>
35 <span class="keyword">class</span> <span class="identifier">basic_datagram_socket</span> <span class="special">:</span>
36   <span class="keyword">public</span> <span class="identifier">basic_socket</span><span class="special">&lt;</span> <span class="identifier">Protocol</span><span class="special">,</span> <span class="identifier">DatagramSocketService</span> <span class="special">&gt;</span>
37 </pre>
38 <h5>
39 <a name="boost_asio.reference.basic_datagram_socket.h0"></a>
40         <span class="phrase"><a name="boost_asio.reference.basic_datagram_socket.types"></a></span><a class="link" href="basic_datagram_socket.html#boost_asio.reference.basic_datagram_socket.types">Types</a>
41       </h5>
42 <div class="informaltable"><table class="table">
43 <colgroup>
44 <col>
45 <col>
46 </colgroup>
47 <thead><tr>
48 <th>
49                 <p>
50                   Name
51                 </p>
52               </th>
53 <th>
54                 <p>
55                   Description
56                 </p>
57               </th>
58 </tr></thead>
59 <tbody>
60 <tr>
61 <td>
62                 <p>
63                   <a class="link" href="basic_datagram_socket/broadcast.html" title="basic_datagram_socket::broadcast"><span class="bold"><strong>broadcast</strong></span></a>
64                 </p>
65               </td>
66 <td>
67                 <p>
68                   Socket option to permit sending of broadcast messages.
69                 </p>
70               </td>
71 </tr>
72 <tr>
73 <td>
74                 <p>
75                   <a class="link" href="basic_datagram_socket/bytes_readable.html" title="basic_datagram_socket::bytes_readable"><span class="bold"><strong>bytes_readable</strong></span></a>
76                 </p>
77               </td>
78 <td>
79                 <p>
80                   IO control command to get the amount of data that can be read without
81                   blocking.
82                 </p>
83               </td>
84 </tr>
85 <tr>
86 <td>
87                 <p>
88                   <a class="link" href="basic_datagram_socket/debug.html" title="basic_datagram_socket::debug"><span class="bold"><strong>debug</strong></span></a>
89                 </p>
90               </td>
91 <td>
92                 <p>
93                   Socket option to enable socket-level debugging.
94                 </p>
95               </td>
96 </tr>
97 <tr>
98 <td>
99                 <p>
100                   <a class="link" href="basic_datagram_socket/do_not_route.html" title="basic_datagram_socket::do_not_route"><span class="bold"><strong>do_not_route</strong></span></a>
101                 </p>
102               </td>
103 <td>
104                 <p>
105                   Socket option to prevent routing, use local interfaces only.
106                 </p>
107               </td>
108 </tr>
109 <tr>
110 <td>
111                 <p>
112                   <a class="link" href="basic_datagram_socket/enable_connection_aborted.html" title="basic_datagram_socket::enable_connection_aborted"><span class="bold"><strong>enable_connection_aborted</strong></span></a>
113                 </p>
114               </td>
115 <td>
116                 <p>
117                   Socket option to report aborted connections on accept.
118                 </p>
119               </td>
120 </tr>
121 <tr>
122 <td>
123                 <p>
124                   <a class="link" href="basic_datagram_socket/endpoint_type.html" title="basic_datagram_socket::endpoint_type"><span class="bold"><strong>endpoint_type</strong></span></a>
125                 </p>
126               </td>
127 <td>
128                 <p>
129                   The endpoint type.
130                 </p>
131               </td>
132 </tr>
133 <tr>
134 <td>
135                 <p>
136                   <a class="link" href="basic_datagram_socket/implementation_type.html" title="basic_datagram_socket::implementation_type"><span class="bold"><strong>implementation_type</strong></span></a>
137                 </p>
138               </td>
139 <td>
140                 <p>
141                   The underlying implementation type of I/O object.
142                 </p>
143               </td>
144 </tr>
145 <tr>
146 <td>
147                 <p>
148                   <a class="link" href="basic_datagram_socket/keep_alive.html" title="basic_datagram_socket::keep_alive"><span class="bold"><strong>keep_alive</strong></span></a>
149                 </p>
150               </td>
151 <td>
152                 <p>
153                   Socket option to send keep-alives.
154                 </p>
155               </td>
156 </tr>
157 <tr>
158 <td>
159                 <p>
160                   <a class="link" href="basic_datagram_socket/linger.html" title="basic_datagram_socket::linger"><span class="bold"><strong>linger</strong></span></a>
161                 </p>
162               </td>
163 <td>
164                 <p>
165                   Socket option to specify whether the socket lingers on close if
166                   unsent data is present.
167                 </p>
168               </td>
169 </tr>
170 <tr>
171 <td>
172                 <p>
173                   <a class="link" href="basic_datagram_socket/lowest_layer_type.html" title="basic_datagram_socket::lowest_layer_type"><span class="bold"><strong>lowest_layer_type</strong></span></a>
174                 </p>
175               </td>
176 <td>
177                 <p>
178                   A basic_socket is always the lowest layer.
179                 </p>
180               </td>
181 </tr>
182 <tr>
183 <td>
184                 <p>
185                   <a class="link" href="basic_datagram_socket/message_flags.html" title="basic_datagram_socket::message_flags"><span class="bold"><strong>message_flags</strong></span></a>
186                 </p>
187               </td>
188 <td>
189                 <p>
190                   Bitmask type for flags that can be passed to send and receive operations.
191                 </p>
192               </td>
193 </tr>
194 <tr>
195 <td>
196                 <p>
197                   <a class="link" href="basic_datagram_socket/native_handle_type.html" title="basic_datagram_socket::native_handle_type"><span class="bold"><strong>native_handle_type</strong></span></a>
198                 </p>
199               </td>
200 <td>
201                 <p>
202                   The native representation of a socket.
203                 </p>
204               </td>
205 </tr>
206 <tr>
207 <td>
208                 <p>
209                   <a class="link" href="basic_datagram_socket/native_type.html" title="basic_datagram_socket::native_type"><span class="bold"><strong>native_type</strong></span></a>
210                 </p>
211               </td>
212 <td>
213                 <p>
214                   (Deprecated: Use native_handle_type.) The native representation
215                   of a socket.
216                 </p>
217               </td>
218 </tr>
219 <tr>
220 <td>
221                 <p>
222                   <a class="link" href="basic_datagram_socket/non_blocking_io.html" title="basic_datagram_socket::non_blocking_io"><span class="bold"><strong>non_blocking_io</strong></span></a>
223                 </p>
224               </td>
225 <td>
226                 <p>
227                   (Deprecated: Use non_blocking().) IO control command to set the
228                   blocking mode of the socket.
229                 </p>
230               </td>
231 </tr>
232 <tr>
233 <td>
234                 <p>
235                   <a class="link" href="basic_datagram_socket/protocol_type.html" title="basic_datagram_socket::protocol_type"><span class="bold"><strong>protocol_type</strong></span></a>
236                 </p>
237               </td>
238 <td>
239                 <p>
240                   The protocol type.
241                 </p>
242               </td>
243 </tr>
244 <tr>
245 <td>
246                 <p>
247                   <a class="link" href="basic_datagram_socket/receive_buffer_size.html" title="basic_datagram_socket::receive_buffer_size"><span class="bold"><strong>receive_buffer_size</strong></span></a>
248                 </p>
249               </td>
250 <td>
251                 <p>
252                   Socket option for the receive buffer size of a socket.
253                 </p>
254               </td>
255 </tr>
256 <tr>
257 <td>
258                 <p>
259                   <a class="link" href="basic_datagram_socket/receive_low_watermark.html" title="basic_datagram_socket::receive_low_watermark"><span class="bold"><strong>receive_low_watermark</strong></span></a>
260                 </p>
261               </td>
262 <td>
263                 <p>
264                   Socket option for the receive low watermark.
265                 </p>
266               </td>
267 </tr>
268 <tr>
269 <td>
270                 <p>
271                   <a class="link" href="basic_datagram_socket/reuse_address.html" title="basic_datagram_socket::reuse_address"><span class="bold"><strong>reuse_address</strong></span></a>
272                 </p>
273               </td>
274 <td>
275                 <p>
276                   Socket option to allow the socket to be bound to an address that
277                   is already in use.
278                 </p>
279               </td>
280 </tr>
281 <tr>
282 <td>
283                 <p>
284                   <a class="link" href="basic_datagram_socket/send_buffer_size.html" title="basic_datagram_socket::send_buffer_size"><span class="bold"><strong>send_buffer_size</strong></span></a>
285                 </p>
286               </td>
287 <td>
288                 <p>
289                   Socket option for the send buffer size of a socket.
290                 </p>
291               </td>
292 </tr>
293 <tr>
294 <td>
295                 <p>
296                   <a class="link" href="basic_datagram_socket/send_low_watermark.html" title="basic_datagram_socket::send_low_watermark"><span class="bold"><strong>send_low_watermark</strong></span></a>
297                 </p>
298               </td>
299 <td>
300                 <p>
301                   Socket option for the send low watermark.
302                 </p>
303               </td>
304 </tr>
305 <tr>
306 <td>
307                 <p>
308                   <a class="link" href="basic_datagram_socket/service_type.html" title="basic_datagram_socket::service_type"><span class="bold"><strong>service_type</strong></span></a>
309                 </p>
310               </td>
311 <td>
312                 <p>
313                   The type of the service that will be used to provide I/O operations.
314                 </p>
315               </td>
316 </tr>
317 <tr>
318 <td>
319                 <p>
320                   <a class="link" href="basic_datagram_socket/shutdown_type.html" title="basic_datagram_socket::shutdown_type"><span class="bold"><strong>shutdown_type</strong></span></a>
321                 </p>
322               </td>
323 <td>
324                 <p>
325                   Different ways a socket may be shutdown.
326                 </p>
327               </td>
328 </tr>
329 </tbody>
330 </table></div>
331 <h5>
332 <a name="boost_asio.reference.basic_datagram_socket.h1"></a>
333         <span class="phrase"><a name="boost_asio.reference.basic_datagram_socket.member_functions"></a></span><a class="link" href="basic_datagram_socket.html#boost_asio.reference.basic_datagram_socket.member_functions">Member
334         Functions</a>
335       </h5>
336 <div class="informaltable"><table class="table">
337 <colgroup>
338 <col>
339 <col>
340 </colgroup>
341 <thead><tr>
342 <th>
343                 <p>
344                   Name
345                 </p>
346               </th>
347 <th>
348                 <p>
349                   Description
350                 </p>
351               </th>
352 </tr></thead>
353 <tbody>
354 <tr>
355 <td>
356                 <p>
357                   <a class="link" href="basic_datagram_socket/assign.html" title="basic_datagram_socket::assign"><span class="bold"><strong>assign</strong></span></a>
358                 </p>
359               </td>
360 <td>
361                 <p>
362                   Assign an existing native socket to the socket.
363                 </p>
364               </td>
365 </tr>
366 <tr>
367 <td>
368                 <p>
369                   <a class="link" href="basic_datagram_socket/async_connect.html" title="basic_datagram_socket::async_connect"><span class="bold"><strong>async_connect</strong></span></a>
370                 </p>
371               </td>
372 <td>
373                 <p>
374                   Start an asynchronous connect.
375                 </p>
376               </td>
377 </tr>
378 <tr>
379 <td>
380                 <p>
381                   <a class="link" href="basic_datagram_socket/async_receive.html" title="basic_datagram_socket::async_receive"><span class="bold"><strong>async_receive</strong></span></a>
382                 </p>
383               </td>
384 <td>
385                 <p>
386                   Start an asynchronous receive on a connected socket.
387                 </p>
388               </td>
389 </tr>
390 <tr>
391 <td>
392                 <p>
393                   <a class="link" href="basic_datagram_socket/async_receive_from.html" title="basic_datagram_socket::async_receive_from"><span class="bold"><strong>async_receive_from</strong></span></a>
394                 </p>
395               </td>
396 <td>
397                 <p>
398                   Start an asynchronous receive.
399                 </p>
400               </td>
401 </tr>
402 <tr>
403 <td>
404                 <p>
405                   <a class="link" href="basic_datagram_socket/async_send.html" title="basic_datagram_socket::async_send"><span class="bold"><strong>async_send</strong></span></a>
406                 </p>
407               </td>
408 <td>
409                 <p>
410                   Start an asynchronous send on a connected socket.
411                 </p>
412               </td>
413 </tr>
414 <tr>
415 <td>
416                 <p>
417                   <a class="link" href="basic_datagram_socket/async_send_to.html" title="basic_datagram_socket::async_send_to"><span class="bold"><strong>async_send_to</strong></span></a>
418                 </p>
419               </td>
420 <td>
421                 <p>
422                   Start an asynchronous send.
423                 </p>
424               </td>
425 </tr>
426 <tr>
427 <td>
428                 <p>
429                   <a class="link" href="basic_datagram_socket/at_mark.html" title="basic_datagram_socket::at_mark"><span class="bold"><strong>at_mark</strong></span></a>
430                 </p>
431               </td>
432 <td>
433                 <p>
434                   Determine whether the socket is at the out-of-band data mark.
435                 </p>
436               </td>
437 </tr>
438 <tr>
439 <td>
440                 <p>
441                   <a class="link" href="basic_datagram_socket/available.html" title="basic_datagram_socket::available"><span class="bold"><strong>available</strong></span></a>
442                 </p>
443               </td>
444 <td>
445                 <p>
446                   Determine the number of bytes available for reading.
447                 </p>
448               </td>
449 </tr>
450 <tr>
451 <td>
452                 <p>
453                   <a class="link" href="basic_datagram_socket/basic_datagram_socket.html" title="basic_datagram_socket::basic_datagram_socket"><span class="bold"><strong>basic_datagram_socket</strong></span></a>
454                 </p>
455               </td>
456 <td>
457                 <p>
458                   Construct a basic_datagram_socket without opening it.
459                 </p>
460                 <p>
461                   Construct and open a basic_datagram_socket.
462                 </p>
463                 <p>
464                   Construct a basic_datagram_socket, opening it and binding it to
465                   the given local endpoint.
466                 </p>
467                 <p>
468                   Construct a basic_datagram_socket on an existing native socket.
469                 </p>
470                 <p>
471                   Move-construct a basic_datagram_socket from another.
472                 </p>
473                 <p>
474                   Move-construct a basic_datagram_socket from a socket of another
475                   protocol type.
476                 </p>
477               </td>
478 </tr>
479 <tr>
480 <td>
481                 <p>
482                   <a class="link" href="basic_datagram_socket/bind.html" title="basic_datagram_socket::bind"><span class="bold"><strong>bind</strong></span></a>
483                 </p>
484               </td>
485 <td>
486                 <p>
487                   Bind the socket to the given local endpoint.
488                 </p>
489               </td>
490 </tr>
491 <tr>
492 <td>
493                 <p>
494                   <a class="link" href="basic_datagram_socket/cancel.html" title="basic_datagram_socket::cancel"><span class="bold"><strong>cancel</strong></span></a>
495                 </p>
496               </td>
497 <td>
498                 <p>
499                   Cancel all asynchronous operations associated with the socket.
500                 </p>
501               </td>
502 </tr>
503 <tr>
504 <td>
505                 <p>
506                   <a class="link" href="basic_datagram_socket/close.html" title="basic_datagram_socket::close"><span class="bold"><strong>close</strong></span></a>
507                 </p>
508               </td>
509 <td>
510                 <p>
511                   Close the socket.
512                 </p>
513               </td>
514 </tr>
515 <tr>
516 <td>
517                 <p>
518                   <a class="link" href="basic_datagram_socket/connect.html" title="basic_datagram_socket::connect"><span class="bold"><strong>connect</strong></span></a>
519                 </p>
520               </td>
521 <td>
522                 <p>
523                   Connect the socket to the specified endpoint.
524                 </p>
525               </td>
526 </tr>
527 <tr>
528 <td>
529                 <p>
530                   <a class="link" href="basic_datagram_socket/get_io_service.html" title="basic_datagram_socket::get_io_service"><span class="bold"><strong>get_io_service</strong></span></a>
531                 </p>
532               </td>
533 <td>
534                 <p>
535                   Get the io_service associated with the object.
536                 </p>
537               </td>
538 </tr>
539 <tr>
540 <td>
541                 <p>
542                   <a class="link" href="basic_datagram_socket/get_option.html" title="basic_datagram_socket::get_option"><span class="bold"><strong>get_option</strong></span></a>
543                 </p>
544               </td>
545 <td>
546                 <p>
547                   Get an option from the socket.
548                 </p>
549               </td>
550 </tr>
551 <tr>
552 <td>
553                 <p>
554                   <a class="link" href="basic_datagram_socket/io_control.html" title="basic_datagram_socket::io_control"><span class="bold"><strong>io_control</strong></span></a>
555                 </p>
556               </td>
557 <td>
558                 <p>
559                   Perform an IO control command on the socket.
560                 </p>
561               </td>
562 </tr>
563 <tr>
564 <td>
565                 <p>
566                   <a class="link" href="basic_datagram_socket/is_open.html" title="basic_datagram_socket::is_open"><span class="bold"><strong>is_open</strong></span></a>
567                 </p>
568               </td>
569 <td>
570                 <p>
571                   Determine whether the socket is open.
572                 </p>
573               </td>
574 </tr>
575 <tr>
576 <td>
577                 <p>
578                   <a class="link" href="basic_datagram_socket/local_endpoint.html" title="basic_datagram_socket::local_endpoint"><span class="bold"><strong>local_endpoint</strong></span></a>
579                 </p>
580               </td>
581 <td>
582                 <p>
583                   Get the local endpoint of the socket.
584                 </p>
585               </td>
586 </tr>
587 <tr>
588 <td>
589                 <p>
590                   <a class="link" href="basic_datagram_socket/lowest_layer.html" title="basic_datagram_socket::lowest_layer"><span class="bold"><strong>lowest_layer</strong></span></a>
591                 </p>
592               </td>
593 <td>
594                 <p>
595                   Get a reference to the lowest layer.
596                 </p>
597                 <p>
598                   Get a const reference to the lowest layer.
599                 </p>
600               </td>
601 </tr>
602 <tr>
603 <td>
604                 <p>
605                   <a class="link" href="basic_datagram_socket/native.html" title="basic_datagram_socket::native"><span class="bold"><strong>native</strong></span></a>
606                 </p>
607               </td>
608 <td>
609                 <p>
610                   (Deprecated: Use native_handle().) Get the native socket representation.
611                 </p>
612               </td>
613 </tr>
614 <tr>
615 <td>
616                 <p>
617                   <a class="link" href="basic_datagram_socket/native_handle.html" title="basic_datagram_socket::native_handle"><span class="bold"><strong>native_handle</strong></span></a>
618                 </p>
619               </td>
620 <td>
621                 <p>
622                   Get the native socket representation.
623                 </p>
624               </td>
625 </tr>
626 <tr>
627 <td>
628                 <p>
629                   <a class="link" href="basic_datagram_socket/native_non_blocking.html" title="basic_datagram_socket::native_non_blocking"><span class="bold"><strong>native_non_blocking</strong></span></a>
630                 </p>
631               </td>
632 <td>
633                 <p>
634                   Gets the non-blocking mode of the native socket implementation.
635                 </p>
636                 <p>
637                   Sets the non-blocking mode of the native socket implementation.
638                 </p>
639               </td>
640 </tr>
641 <tr>
642 <td>
643                 <p>
644                   <a class="link" href="basic_datagram_socket/non_blocking.html" title="basic_datagram_socket::non_blocking"><span class="bold"><strong>non_blocking</strong></span></a>
645                 </p>
646               </td>
647 <td>
648                 <p>
649                   Gets the non-blocking mode of the socket.
650                 </p>
651                 <p>
652                   Sets the non-blocking mode of the socket.
653                 </p>
654               </td>
655 </tr>
656 <tr>
657 <td>
658                 <p>
659                   <a class="link" href="basic_datagram_socket/open.html" title="basic_datagram_socket::open"><span class="bold"><strong>open</strong></span></a>
660                 </p>
661               </td>
662 <td>
663                 <p>
664                   Open the socket using the specified protocol.
665                 </p>
666               </td>
667 </tr>
668 <tr>
669 <td>
670                 <p>
671                   <a class="link" href="basic_datagram_socket/operator_eq_.html" title="basic_datagram_socket::operator="><span class="bold"><strong>operator=</strong></span></a>
672                 </p>
673               </td>
674 <td>
675                 <p>
676                   Move-assign a basic_datagram_socket from another.
677                 </p>
678                 <p>
679                   Move-assign a basic_datagram_socket from a socket of another protocol
680                   type.
681                 </p>
682               </td>
683 </tr>
684 <tr>
685 <td>
686                 <p>
687                   <a class="link" href="basic_datagram_socket/receive.html" title="basic_datagram_socket::receive"><span class="bold"><strong>receive</strong></span></a>
688                 </p>
689               </td>
690 <td>
691                 <p>
692                   Receive some data on a connected socket.
693                 </p>
694               </td>
695 </tr>
696 <tr>
697 <td>
698                 <p>
699                   <a class="link" href="basic_datagram_socket/receive_from.html" title="basic_datagram_socket::receive_from"><span class="bold"><strong>receive_from</strong></span></a>
700                 </p>
701               </td>
702 <td>
703                 <p>
704                   Receive a datagram with the endpoint of the sender.
705                 </p>
706               </td>
707 </tr>
708 <tr>
709 <td>
710                 <p>
711                   <a class="link" href="basic_datagram_socket/remote_endpoint.html" title="basic_datagram_socket::remote_endpoint"><span class="bold"><strong>remote_endpoint</strong></span></a>
712                 </p>
713               </td>
714 <td>
715                 <p>
716                   Get the remote endpoint of the socket.
717                 </p>
718               </td>
719 </tr>
720 <tr>
721 <td>
722                 <p>
723                   <a class="link" href="basic_datagram_socket/send.html" title="basic_datagram_socket::send"><span class="bold"><strong>send</strong></span></a>
724                 </p>
725               </td>
726 <td>
727                 <p>
728                   Send some data on a connected socket.
729                 </p>
730               </td>
731 </tr>
732 <tr>
733 <td>
734                 <p>
735                   <a class="link" href="basic_datagram_socket/send_to.html" title="basic_datagram_socket::send_to"><span class="bold"><strong>send_to</strong></span></a>
736                 </p>
737               </td>
738 <td>
739                 <p>
740                   Send a datagram to the specified endpoint.
741                 </p>
742               </td>
743 </tr>
744 <tr>
745 <td>
746                 <p>
747                   <a class="link" href="basic_datagram_socket/set_option.html" title="basic_datagram_socket::set_option"><span class="bold"><strong>set_option</strong></span></a>
748                 </p>
749               </td>
750 <td>
751                 <p>
752                   Set an option on the socket.
753                 </p>
754               </td>
755 </tr>
756 <tr>
757 <td>
758                 <p>
759                   <a class="link" href="basic_datagram_socket/shutdown.html" title="basic_datagram_socket::shutdown"><span class="bold"><strong>shutdown</strong></span></a>
760                 </p>
761               </td>
762 <td>
763                 <p>
764                   Disable sends or receives on the socket.
765                 </p>
766               </td>
767 </tr>
768 </tbody>
769 </table></div>
770 <h5>
771 <a name="boost_asio.reference.basic_datagram_socket.h2"></a>
772         <span class="phrase"><a name="boost_asio.reference.basic_datagram_socket.protected_member_functions"></a></span><a class="link" href="basic_datagram_socket.html#boost_asio.reference.basic_datagram_socket.protected_member_functions">Protected
773         Member Functions</a>
774       </h5>
775 <div class="informaltable"><table class="table">
776 <colgroup>
777 <col>
778 <col>
779 </colgroup>
780 <thead><tr>
781 <th>
782                 <p>
783                   Name
784                 </p>
785               </th>
786 <th>
787                 <p>
788                   Description
789                 </p>
790               </th>
791 </tr></thead>
792 <tbody>
793 <tr>
794 <td>
795                 <p>
796                   <a class="link" href="basic_datagram_socket/get_implementation.html" title="basic_datagram_socket::get_implementation"><span class="bold"><strong>get_implementation</strong></span></a>
797                 </p>
798               </td>
799 <td>
800                 <p>
801                   Get the underlying implementation of the I/O object.
802                 </p>
803               </td>
804 </tr>
805 <tr>
806 <td>
807                 <p>
808                   <a class="link" href="basic_datagram_socket/get_service.html" title="basic_datagram_socket::get_service"><span class="bold"><strong>get_service</strong></span></a>
809                 </p>
810               </td>
811 <td>
812                 <p>
813                   Get the service associated with the I/O object.
814                 </p>
815               </td>
816 </tr>
817 </tbody>
818 </table></div>
819 <h5>
820 <a name="boost_asio.reference.basic_datagram_socket.h3"></a>
821         <span class="phrase"><a name="boost_asio.reference.basic_datagram_socket.data_members"></a></span><a class="link" href="basic_datagram_socket.html#boost_asio.reference.basic_datagram_socket.data_members">Data Members</a>
822       </h5>
823 <div class="informaltable"><table class="table">
824 <colgroup>
825 <col>
826 <col>
827 </colgroup>
828 <thead><tr>
829 <th>
830                 <p>
831                   Name
832                 </p>
833               </th>
834 <th>
835                 <p>
836                   Description
837                 </p>
838               </th>
839 </tr></thead>
840 <tbody>
841 <tr>
842 <td>
843                 <p>
844                   <a class="link" href="basic_datagram_socket/max_connections.html" title="basic_datagram_socket::max_connections"><span class="bold"><strong>max_connections</strong></span></a>
845                 </p>
846               </td>
847 <td>
848                 <p>
849                   The maximum length of the queue of pending incoming connections.
850                 </p>
851               </td>
852 </tr>
853 <tr>
854 <td>
855                 <p>
856                   <a class="link" href="basic_datagram_socket/message_do_not_route.html" title="basic_datagram_socket::message_do_not_route"><span class="bold"><strong>message_do_not_route</strong></span></a>
857                 </p>
858               </td>
859 <td>
860                 <p>
861                   Specify that the data should not be subject to routing.
862                 </p>
863               </td>
864 </tr>
865 <tr>
866 <td>
867                 <p>
868                   <a class="link" href="basic_datagram_socket/message_end_of_record.html" title="basic_datagram_socket::message_end_of_record"><span class="bold"><strong>message_end_of_record</strong></span></a>
869                 </p>
870               </td>
871 <td>
872                 <p>
873                   Specifies that the data marks the end of a record.
874                 </p>
875               </td>
876 </tr>
877 <tr>
878 <td>
879                 <p>
880                   <a class="link" href="basic_datagram_socket/message_out_of_band.html" title="basic_datagram_socket::message_out_of_band"><span class="bold"><strong>message_out_of_band</strong></span></a>
881                 </p>
882               </td>
883 <td>
884                 <p>
885                   Process out-of-band data.
886                 </p>
887               </td>
888 </tr>
889 <tr>
890 <td>
891                 <p>
892                   <a class="link" href="basic_datagram_socket/message_peek.html" title="basic_datagram_socket::message_peek"><span class="bold"><strong>message_peek</strong></span></a>
893                 </p>
894               </td>
895 <td>
896                 <p>
897                   Peek at incoming data without removing it from the input queue.
898                 </p>
899               </td>
900 </tr>
901 </tbody>
902 </table></div>
903 <h5>
904 <a name="boost_asio.reference.basic_datagram_socket.h4"></a>
905         <span class="phrase"><a name="boost_asio.reference.basic_datagram_socket.protected_data_members"></a></span><a class="link" href="basic_datagram_socket.html#boost_asio.reference.basic_datagram_socket.protected_data_members">Protected
906         Data Members</a>
907       </h5>
908 <div class="informaltable"><table class="table">
909 <colgroup>
910 <col>
911 <col>
912 </colgroup>
913 <thead><tr>
914 <th>
915                 <p>
916                   Name
917                 </p>
918               </th>
919 <th>
920                 <p>
921                   Description
922                 </p>
923               </th>
924 </tr></thead>
925 <tbody>
926 <tr>
927 <td>
928                 <p>
929                   <a class="link" href="basic_datagram_socket/implementation.html" title="basic_datagram_socket::implementation"><span class="bold"><strong>implementation</strong></span></a>
930                 </p>
931               </td>
932 <td>
933                 <p>
934                   (Deprecated: Use get_implementation().) The underlying implementation
935                   of the I/O object.
936                 </p>
937               </td>
938 </tr>
939 <tr>
940 <td>
941                 <p>
942                   <a class="link" href="basic_datagram_socket/service.html" title="basic_datagram_socket::service"><span class="bold"><strong>service</strong></span></a>
943                 </p>
944               </td>
945 <td>
946                 <p>
947                   (Deprecated: Use get_service().) The service associated with the
948                   I/O object.
949                 </p>
950               </td>
951 </tr>
952 </tbody>
953 </table></div>
954 <p>
955         The <a class="link" href="basic_datagram_socket.html" title="basic_datagram_socket"><code class="computeroutput"><span class="identifier">basic_datagram_socket</span></code></a> class template
956         provides asynchronous and blocking datagram-oriented socket functionality.
957       </p>
958 <h5>
959 <a name="boost_asio.reference.basic_datagram_socket.h5"></a>
960         <span class="phrase"><a name="boost_asio.reference.basic_datagram_socket.thread_safety"></a></span><a class="link" href="basic_datagram_socket.html#boost_asio.reference.basic_datagram_socket.thread_safety">Thread
961         Safety</a>
962       </h5>
963 <p>
964         <span class="emphasis"><em>Distinct</em></span> <span class="emphasis"><em>objects:</em></span> Safe.
965       </p>
966 <p>
967         <span class="emphasis"><em>Shared</em></span> <span class="emphasis"><em>objects:</em></span> Unsafe.
968       </p>
969 <h5>
970 <a name="boost_asio.reference.basic_datagram_socket.h6"></a>
971         <span class="phrase"><a name="boost_asio.reference.basic_datagram_socket.requirements"></a></span><a class="link" href="basic_datagram_socket.html#boost_asio.reference.basic_datagram_socket.requirements">Requirements</a>
972       </h5>
973 <p>
974         <span class="emphasis"><em>Header: </em></span><code class="literal">boost/asio/basic_datagram_socket.hpp</code>
975       </p>
976 <p>
977         <span class="emphasis"><em>Convenience header: </em></span><code class="literal">boost/asio.hpp</code>
978       </p>
979 </div>
980 <table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr>
981 <td align="left"></td>
982 <td align="right"><div class="copyright-footer">Copyright &#169; 2003-2017 Christopher M. Kohlhoff<p>
983         Distributed under the Boost Software License, Version 1.0. (See accompanying
984         file LICENSE_1_0.txt or copy at <a href="http://www.boost.org/LICENSE_1_0.txt" target="_top">http://www.boost.org/LICENSE_1_0.txt</a>)
985       </p>
986 </div></td>
987 </tr></table>
988 <hr>
989 <div class="spirit-nav">
990 <a accesskey="p" href="async_write_at/overload4.html"><img src="../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../reference.html"><img src="../../../../doc/src/images/up.png" alt="Up"></a><a accesskey="h" href="../../boost_asio.html"><img src="../../../../doc/src/images/home.png" alt="Home"></a><a accesskey="n" href="basic_datagram_socket/assign.html"><img src="../../../../doc/src/images/next.png" alt="Next"></a>
991 </div>
992 </body>
993 </html>