template<template< typename U, typename V, typename... Args > class ObjectType = std::map, template< typename U, typename... Args > class ArrayType = std::vector, class StringType = std::string, class BooleanType = bool, class NumberIntegerType = std::int64_t, class NumberUnsignedType = std::uint64_t, class NumberFloatType = double, template< typename U > class AllocatorType = std::allocator, template< typename T, typename SFINAE=void > class JSONSerializer = adl_serializer, class BinaryType = std::vector<std::uint8_t>>
template<typename ScalarType , typename std::enable_if< std::is_scalar< ScalarType >
::value, int >
::type = 0>
comparison: equal
comparison: equal
Compares two JSON values for equality according to the following rules:
- Two JSON values are equal if (1) they are from the same type and (2) their stored values are the same according to their respective
operator==
.
- Integer and floating-point numbers are automatically converted before comparison. Note that two NaN values are always treated as unequal.
- Two JSON null values are equal.
- Note
- Floating-point inside JSON values numbers are compared with
json::number_float_t::operator==
which is double::operator==
by default. To compare floating-point while respecting an epsilon, an alternative comparison function could be used, for instance template<typename T, typename = typename std::enable_if<std::is_floating_point<T>::value, T>
::type>
inline bool is_same(T a, T b, T epsilon = std::numeric_limits<T>::epsilon()) noexcept
{
return std::abs(a - b) <= epsilon;
}
constexpr value_t type() const noexcept
return the type of the JSON value (explicit)
Or you can self-defined operator equal function like this:
const auto lhs_type lhs.type();
const auto rhs_type rhs.type();
if (lhs_type == rhs_type) {
switch(lhs_type)
return std::abs(lhs - rhs) <= std::numeric_limits<float>::epsilon();
...
}
...
}
const value_type & const_reference
the type of an element const reference
@ number_float
number value (floating-point)
-
NaN values never compare equal to themselves or to other NaN values.
- Parameters
-
[in] | lhs | first JSON value to consider |
[in] | rhs | second JSON value to consider |
- Returns
- whether the values lhs and rhs are equal
@exceptionsafety No-throw guarantee: this function never throws exceptions.
@complexity Linear.
@liveexample{The example demonstrates comparing several JSON types.,operator__equal}
- Since
- version 1.0.0
Definition at line 24159 of file json.hpp.
24160 {
24162 }
basic_json(const value_t v)
create an empty value with a given type