Niels Lohmann 29cd970b94
Consolidate documentation (#3071)
* 🔥 consolidate documentation
* ♻️ overwork std specializations
* 🚚 move images files to mkdocs
* ♻️ fix URLs
* 🔧 tweak MkDocs configuration
* 🔧 add namespaces
* 📝 document deprecations
* 📝 document documentation generation
* 🚸 improve search
* 🚸 add examples
* 🚧 start adding documentation for macros
* 📝 add note for https://github.com/nlohmann/json/issues/874#issuecomment-1001699139
* 📝 overwork example handling
* 📝 fix Markdown tables
2021-12-29 13:41:01 +01:00

1.7 KiB

nlohmann::basic_json::empty

bool empty() const noexcept;

Checks if a JSON value has no elements (i.e. whether its size() 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 and object_t satisfy the Container concept; that is, their empty() functions have constant complexity.

Possible implementation

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.

Examples

??? 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.