|  | Home | Libraries | People | FAQ | More | 
      This library uses the Networking
      Technical Specification, scheduled to become an official part of C++
      no sooner than the year 2023. Three implementations exist, with cosmetic differences
      but otherwise using the same function signatures and type declarations: Boost.Asio,
      stand-alone Asio, and networking-ts-impl. This table shows how a variable of
      type io_context is declared
      in each implementation by including the appropriate header and using a suitable
      namespace alias:
    
Table 1.2. Networking Implementations
| Name | Namespace and Header Example | 
|---|---|
| #include <boost/asio/io_context.hpp> namespace net = boost::asio; net::io_context ioc; | |
| #include <asio/io_context.hpp> namespace net = asio; net::io_context ioc; | |
| #include <experimental/io_context> namespace net = std::experimental::net; net::io_context ioc; | 
This document refers to the three implementations above interchangeably and collectively as Networking (or just networking). The Boost.Asio and Asio flavors of Networking provide additional features not currently proposed for C++, but likely to appear in a future specification, such as:
Boost.Beast depends specifically on the Boost.Asio flavor of Networking, although this may change in the future. While this library offers performant implementations of the HTTP and WebSocket network protocols, it depends on the networking interfaces to perform general tasks such as performing domain name resolution (DNS lookup), establishing outgoing connections, and accepting incoming connections. Callers are responsible for interacting with networking to initialize objects to the correct state where they are usable by this library.
      In this documentation, the example code, and the implementation, the net namespace is used to qualify Networking
      identifiers. For Boost.Beast, net
      will be an alias for the boost::asio namespace.
    
To further ease of use, this library provides an extensive collection of types and algorithms. This section of the documentation explains these types and algorithms, provides examples of usage, and also provides refreshers and tutorials for working with networking.
This documentation assumes familiarity with Boost.Asio, which is required to work with Beast. Sample code and identifiers used throughout are written as if the following declarations are in effect:
#include <boost/beast/core.hpp> #include <boost/asio.hpp> #include <boost/asio/ssl.hpp> #include <iostream> #include <thread>
// using namespace boost::beast; namespace net = boost::asio; namespace ssl = boost::asio::ssl; using tcp = net::ip::tcp; net::io_context ioc; net::any_io_executor work = net::require(ioc.get_executor(), net::execution::outstanding_work.tracked); std::thread t{[&](){ ioc.run(); }}; error_code ec; tcp::socket sock{ioc};