• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1<html>
2<head>
3<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
4<title>Stream-Oriented File Descriptors</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="../posix.html" title="POSIX-Specific Functionality">
9<link rel="prev" href="local.html" title="UNIX Domain Sockets">
10<link rel="next" href="fork.html" title="Fork">
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="local.html"><img src="../../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../posix.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="fork.html"><img src="../../../../../doc/src/images/next.png" alt="Next"></a>
24</div>
25<div class="section">
26<div class="titlepage"><div><div><h4 class="title">
27<a name="boost_asio.overview.posix.stream_descriptor"></a><a class="link" href="stream_descriptor.html" title="Stream-Oriented File Descriptors">Stream-Oriented
28        File Descriptors</a>
29</h4></div></div></div>
30<p>
31          Boost.Asio includes classes added to permit synchronous and asynchronous
32          read and write operations to be performed on POSIX file descriptors, such
33          as pipes, standard input and output, and various devices.
34        </p>
35<p>
36          These classes also provide limited support for regular files. This support
37          assumes that the underlying read and write operations provided by the operating
38          system never fail with <code class="computeroutput">EAGAIN</code> or <code class="computeroutput">EWOULDBLOCK</code>.
39          (This assumption normally holds for buffered file I/O.) Synchronous and
40          asynchronous read and write operations on file descriptors will succeed
41          but the I/O will always be performed immediately. Wait operations, and
42          operations involving <code class="computeroutput">boost::asio::null_buffers</code>, are not portably
43          supported.
44        </p>
45<p>
46          For example, to perform read and write operations on standard input and
47          output, the following objects may be created:
48        </p>
49<pre class="programlisting">posix::stream_descriptor in(my_io_context, ::dup(STDIN_FILENO));
50posix::stream_descriptor out(my_io_context, ::dup(STDOUT_FILENO));
51</pre>
52<p>
53          These are then used as synchronous or asynchronous read and write streams.
54          This means the objects can be used with any of the <a class="link" href="../../reference/read.html" title="read">read()</a>,
55          <a class="link" href="../../reference/async_read.html" title="async_read">async_read()</a>, <a class="link" href="../../reference/write.html" title="write">write()</a>, <a class="link" href="../../reference/async_write.html" title="async_write">async_write()</a>,
56          <a class="link" href="../../reference/read_until.html" title="read_until">read_until()</a> or
57          <a class="link" href="../../reference/async_read_until.html" title="async_read_until">async_read_until()</a>
58          free functions.
59        </p>
60<h6>
61<a name="boost_asio.overview.posix.stream_descriptor.h0"></a>
62          <span class="phrase"><a name="boost_asio.overview.posix.stream_descriptor.see_also"></a></span><a class="link" href="stream_descriptor.html#boost_asio.overview.posix.stream_descriptor.see_also">See Also</a>
63        </h6>
64<p>
65          <a class="link" href="../../reference/posix__stream_descriptor.html" title="posix::stream_descriptor">posix::stream_descriptor</a>,
66          <a class="link" href="../../examples/cpp03_examples.html#boost_asio.examples.cpp03_examples.chat">Chat example (C++03)</a>,
67          <a class="link" href="../../examples/cpp11_examples.html#boost_asio.examples.cpp11_examples.chat">Chat example (C++11)</a>.
68        </p>
69<h6>
70<a name="boost_asio.overview.posix.stream_descriptor.h1"></a>
71          <span class="phrase"><a name="boost_asio.overview.posix.stream_descriptor.notes"></a></span><a class="link" href="stream_descriptor.html#boost_asio.overview.posix.stream_descriptor.notes">Notes</a>
72        </h6>
73<p>
74          POSIX stream descriptors are only available at compile time if supported
75          by the target operating system. A program may test for the macro <code class="computeroutput">BOOST_ASIO_HAS_POSIX_STREAM_DESCRIPTOR</code>
76          to determine whether they are supported.
77        </p>
78</div>
79<table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr>
80<td align="left"></td>
81<td align="right"><div class="copyright-footer">Copyright © 2003-2020 Christopher M.
82      Kohlhoff<p>
83        Distributed under the Boost Software License, Version 1.0. (See accompanying
84        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>)
85      </p>
86</div></td>
87</tr></table>
88<hr>
89<div class="spirit-nav">
90<a accesskey="p" href="local.html"><img src="../../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../posix.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="fork.html"><img src="../../../../../doc/src/images/next.png" alt="Next"></a>
91</div>
92</body>
93</html>
94