* ✏️ fix typos Signed-off-by: Niels Lohmann <mail@nlohmann.me> * ✏️ address review comments Signed-off-by: Niels Lohmann <mail@nlohmann.me> * ✏️ address review comments Signed-off-by: Niels Lohmann <mail@nlohmann.me> --------- Signed-off-by: Niels Lohmann <mail@nlohmann.me>
7.1 KiB
nlohmann::basic_json::insert
// (1)
iterator insert(const_iterator pos, const basic_json& val);
iterator insert(const_iterator pos, basic_json&& val);
// (2)
iterator insert(const_iterator pos, size_type cnt, const basic_json& val);
// (3)
iterator insert(const_iterator pos, const_iterator first, const_iterator last);
// (4)
iterator insert(const_iterator pos, initializer_list_t ilist);
// (5)
void insert(const_iterator first, const_iterator last);
- Inserts element
valinto an array before iteratorpos. - Inserts
cntcopies ofvalinto an array before iteratorpos. - Inserts elements from range
[first, last)into an array before iteratorpos. - Inserts elements from initializer list
ilistinto an array before iteratorpos. - Inserts elements from range
[first, last)into an object.
Iterator invalidation
For all cases where an element is added to an array, a reallocation can happen, in which case all iterators
(including the end() iterator) and all references to the elements are invalidated. Otherwise, only the
end() iterator is invalidated. Also, any iterator or reference after the insertion point will point to the
same index, which is now a different value.
For ordered_json, also adding an element to an object can yield a reallocation which again
invalidates all iterators and all references. Also, any iterator or reference after the insertion point will point to
the same index, which is now a different value.
Parameters
pos(in)- iterator before which the content will be inserted; may be the
end()iterator val(in)- value to insert
cnt(in)- number of copies of
valto insert first(in)- the start of the range of elements to insert
last(in)- the end of the range of elements to insert
ilist(in)- initializer list to insert the values from
Return value
- iterator pointing to the inserted
val. - iterator pointing to the first element inserted, or
posif#!cpp cnt==0 - iterator pointing to the first element inserted, or
posif#!cpp first==last - iterator pointing to the first element inserted, or
posifilistis empty - (none)
Exception safety
Strong exception safety: if an exception occurs, the original value stays intact.
Exceptions
- The function can throw the following exceptions:
- Throws
type_error.309if called on JSON values other than arrays; example:"cannot use insert() with string" - Throws
invalid_iterator.202if called on an iterator which does not belong to the current JSON value; example:"iterator does not fit current value"
- Throws
- The function can throw the following exceptions:
- Throws
type_error.309if called on JSON values other than arrays; example:"cannot use insert() with string" - Throws
invalid_iterator.202if called on an iterator which does not belong to the current JSON value; example:"iterator does not fit current value"
- Throws
- The function can throw the following exceptions:
- Throws
type_error.309if called on JSON values other than arrays; example:"cannot use insert() with string" - Throws
invalid_iterator.202if called on an iterator which does not belong to the current JSON value; example:"iterator does not fit current value" - Throws
invalid_iterator.210iffirstandlastdo not belong to the same JSON value; example:"iterators do not fit" - Throws
invalid_iterator.211iffirstorlastare iterators into container for which insert is called; example:"passed iterators may not belong to container"
- Throws
- The function can throw the following exceptions:
- Throws
type_error.309if called on JSON values other than arrays; example:"cannot use insert() with string" - Throws
invalid_iterator.202if called on an iterator which does not belong to the current JSON value; example:"iterator does not fit current value"
- Throws
- The function can throw the following exceptions:
- Throws
type_error.309if called on JSON values other than objects; example:"cannot use insert() with string" - Throws
invalid_iterator.202if called on an iterator which does not belong to the current JSON value; example:"iterator does not fit current value" - Throws
invalid_iterator.210iffirstandlastdo not belong to the same JSON value; example:"iterators do not fit"
- Throws
Complexity
- Constant plus linear in the distance between
posand end of the container. - Linear in
cntplus linear in the distance betweenposand end of the container. - Linear in
#!cpp std::distance(first, last)plus linear in the distance betweenposand end of the container. - Linear in
ilist.size()plus linear in the distance betweenposand end of the container. - Logarithmic:
O(N*log(size() + N)), whereNis the number of elements to insert.
Examples
??? example "Example (1): insert element into array"
The example shows how `insert()` is used.
```cpp
--8<-- "examples/insert.cpp"
```
Output:
```json
--8<-- "examples/insert.output"
```
??? example "Example (2): insert copies of element into array"
The example shows how `insert()` is used.
```cpp
--8<-- "examples/insert__count.cpp"
```
Output:
```json
--8<-- "examples/insert__count.output"
```
??? example "Example (3): insert a range of elements into an array"
The example shows how `insert()` is used.
```cpp
--8<-- "examples/insert__range.cpp"
```
Output:
```json
--8<-- "examples/insert__range.output"
```
??? example "Example (4): insert elements from an initializer list into an array"
The example shows how `insert()` is used.
```cpp
--8<-- "examples/insert__ilist.cpp"
```
Output:
```json
--8<-- "examples/insert__ilist.output"
```
??? example "Example (5): insert a range of elements into an object"
The example shows how `insert()` is used.
```cpp
--8<-- "examples/insert__range_object.cpp"
```
Output:
```json
--8<-- "examples/insert__range_object.output"
```
Version history
- Added in version 1.0.0.
- Added in version 1.0.0.
- Added in version 1.0.0.
- Added in version 1.0.0.
- Added in version 3.0.0.