| # basic_json::empty |
| |
| ```cpp |
| bool empty() const noexcept; |
| ``` |
| |
| Checks if a JSON value has no elements (i.e. whether its [`size()`](size.md) is `0`). |
| |
| ## Return value |
| |
| The return value depends on the different types and is defined as follows: |
| |
| Value type | return value |
| ----------- | ------------- |
| null | `#!cpp true` |
| boolean | `#!cpp false` |
| string | `#!cpp false` |
| number | `#!cpp false` |
| binary | `#!cpp false` |
| object | result of function `object_t::empty()` |
| array | result of function `array_t::empty()` |
| |
| ## Exception safety |
| |
| No-throw guarantee: this function never throws exceptions. |
| |
| ## Complexity |
| |
| Constant, as long as [`array_t`](array_t.md) and [`object_t`](object_t.md) satisfy the |
| [Container](https://en.cppreference.com/w/cpp/named_req/Container) concept; that is, their `empty()` functions have |
| constant complexity. |
| |
| ## Possible implementation |
| |
| ```cpp |
| bool empty() const noexcept |
| { |
| return size() == 0; |
| } |
| ``` |
| |
| ## Notes |
| |
| This function does not return whether a string stored as JSON value is empty -- it returns whether the JSON container |
| itself is empty which is `#!cpp false` in the case of a string. |
| |
| ## Example |
| |
| ??? example |
| |
| The following code uses `empty()` to check if a JSON object contains any elements. |
| |
| ```cpp |
| --8<-- "examples/empty.cpp" |
| ``` |
| |
| Output: |
| |
| ```json |
| --8<-- "examples/empty.output" |
| ``` |
| |
| ## Version history |
| |
| - Added in version 1.0.0. |
| - Extended to return `#!cpp false` for binary types in version 3.8.0. |