# basic_json::to_ubjson ```cpp // (1) static std::vector to_ubjson(const basic_json& j, const bool use_size = false, const bool use_type = false); // (2) static void to_ubjson(const basic_json& j, detail::output_adapter o, const bool use_size = false, const bool use_type = false); static void to_ubjson(const basic_json& j, detail::output_adapter o, const bool use_size = false, const bool use_type = false); ``` Serializes a given JSON value `j` to a byte vector using the UBJSON (Universal Binary JSON) serialization format. UBJSON aims to be more compact than JSON itself, yet more efficient to parse. 1. Returns a byte vector containing the UBJSON serialization. 2. Writes the UBJSON serialization to an output adapter. ## Parameters `j` (in) : JSON value to serialize `o` (in) : output adapter to write serialization to `use_size` (in) : whether to add size annotations to container types; optional, `#!cpp false` by default. `use_type` (in) : whether to add type annotations to container types (must be combined with `#!cpp use_size = true`); optional, `#!cpp false` by default. ## Return value 1. UBJSON serialization as byte vector 2. / ## Exception safety Strong guarantee: if an exception is thrown, there are no changes in the JSON value. ## Complexity Linear in the size of the JSON value `j`. ## Example ??? example The example shows the serialization of a JSON value to a byte vector in UBJSON format. ```cpp --8<-- "examples/to_ubjson.cpp" ``` Output: ```json --8<-- "examples/to_ubjson.output" ``` ## Version history - Added in version 3.1.0.