# basic_json::get ```cpp // (1) template ValueType get() const noexcept( noexcept(JSONSerializer::from_json( std::declval(), std::declval()))); // (2) template BasicJsonType get() const; // (3) template PointerType get_ptr(); template constexpr const PointerType get_ptr() const noexcept; ``` 1. Explicit type conversion between the JSON value and a compatible value which is [CopyConstructible](https://en.cppreference.com/w/cpp/named_req/CopyConstructible) and [DefaultConstructible](https://en.cppreference.com/w/cpp/named_req/DefaultConstructible). The value is converted by calling the `json_serializer` `from_json()` method. The function is equivalent to executing ```cpp ValueType ret; JSONSerializer::from_json(*this, ret); return ret; ``` This overloads is chosen if: - `ValueType` is not `basic_json`, - `json_serializer` has a `from_json()` method of the form `void from_json(const basic_json&, ValueType&)`, and - `json_serializer` does not have a `from_json()` method of the form `ValueType from_json(const basic_json&)` If the type is **not** [CopyConstructible](https://en.cppreference.com/w/cpp/named_req/CopyConstructible) and **not** [DefaultConstructible](https://en.cppreference.com/w/cpp/named_req/DefaultConstructible), the value is converted by calling the `json_serializer` `from_json()` method. The function is then equivalent to executing ```cpp return JSONSerializer::from_json(*this); ``` This overloads is chosen if: - `ValueType` is not `basic_json` and - `json_serializer` has a `from_json()` method of the form `ValueType from_json(const basic_json&)` If `json_serializer` has both overloads of `from_json()`, the latter one is chosen. 2. Overload for `basic_json` specializations. The function is equivalent to executing ```cpp return *this; ``` 3. Explicit pointer access to the internally stored JSON value. No copies are made. ## Template parameters `ValueType` : the value type to return `BasicJsonType` : a specialization of `basic_json` `PointerType` : pointer type; must be a pointer to [`array_t`](array_t.md), [`object_t`](object_t.md), [`string_t`](string_t.md), [`boolean_t`](boolean_t.md), [`number_integer_t`](number_integer_t.md), or [`number_unsigned_t`](number_unsigned_t.md), [`number_float_t`](number_float_t.md), or [`binary_t`](binary_t.md). Other types will not compile. ## Return value 1. copy of the JSON value, converted to `ValueType` 2. a copy of `#!cpp *this`, converted into `BasicJsonType` 3. pointer to the internally stored JSON value if the requested pointer type fits to the JSON value; `#!cpp nullptr` otherwise ## Exceptions Depends on what `json_serializer` `from_json()` method throws ## Notes !!! warning Writing data to the pointee (overload 3) of the result yields an undefined state. ## Example ??? example The example below shows several conversions from JSON values to other types. There a few things to note: (1) Floating-point numbers can be converted to integers, (2) A JSON array can be converted to a standard `std::vector`, (3) A JSON object can be converted to C++ associative containers such as `std::unordered_map`. ```cpp --8<-- "examples/get__ValueType_const.cpp" ``` Output: ```json --8<-- "examples/get__ValueType_const.output" ``` ??? example The example below shows how pointers to internal values of a JSON value can be requested. Note that no type conversions are made and a `#cpp nullptr` is returned if the value and the requested pointer type does not match. ```cpp --8<-- "examples/get__PointerType.cpp" ``` Output: ```json --8<-- "examples/get__PointerType.output" ``` ## Version history 1. Since version 2.1.0. 2. Since version 2.1.0. Extended to work with other specializations of `basic_json` in version 3.2.0. 3. Since version 1.0.0.