为什么 nlohmann json 对象的 decltype 不同?

问题描述

如何从 nlohmann 对象中提取底层数据类型的信息? 既然值在 json 中存储为原始数据类型,为什么它不给出像下面的 ab 这样的输出

对于有序的 json,我看到 typedef 如下所示。

nlohmann::basic_json<nlohmann::ordered_map,std::vector,std::string,bool,std::int64_t,std::uint64_t,double>;

所以很清楚它存储的值的类型(?)。

int main()
{
  json js;
  js["key1"] = 1L;
  js["key2"]  = 0.111f;

  auto a = 1L;
  auto b = 0.111f;


  decltype(js["key1"]) x = js["key1"];
  decltype(js["key2"]) y = js["key2"];

  cout<<typeid(a).name()<<endl;
  cout<<typeid(b).name()<<endl;
  cout<<typeid(x).name()<<endl;
  cout<<typeid(y).name()<<endl;

}

输出

l
f
N8nlohmann10basic_jsonINS_11ordered_mapest6vectorNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEEblmdsaNS_14adl_serializerES2_IhSaIhEEEE
N8nlohmann10basic_jsonINS_11ordered_mapest6vectorNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEEblmdsaNS_14adl_serializerES2_IhSaIhEEEE

解决方法

operator[] 将返回用于保存值的nlohmann::basic_json & 类型。

您看到的输出是 nlohmann::basic_json 模板类的重整特化,该模板类已针对有序 JSON 进行了 typedef。

那就是

nlohmann::basic_json<nlohmann::ordered_map,std::vector,std::string,bool,std::int64_t,std::uint64_t,double>;

对应

N8nlohmann10basic_jsonINS_11ordered_mapESt6vectorNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEEblmdSaNS_14adl_serializerES2_IhSaIhEEEE

那么当您使用 operator[] 时会发生什么,例如js["key1"] 是它返回对 basic_json 类型特化的引用,因为这是存储在内部工作的方式。

但是,nlohmann 还提供了 stl 类型的隐式转换,因此下面的示例会将 nlohmann::basic_json 返回的 operator[] 类型隐式转换为(原始)数字类型

  auto a = 1L;
  auto b = 0.111f;

  long x = js["key1"];
  float y = js["key2"];

  cout<<typeid(a).name()<<endl;
  cout<<typeid(b).name()<<endl;
  cout<<typeid(x).name()<<endl;
  cout<<typeid(y).name()<<endl;

隐式转换不限于将其转换为原始类型。例如,以下将原始 long 转换为 int 并将 float 转换为 double 也可以使用

  js["key1"] = 1L;
  js["key2"]  = 0.111f;

  int x = js["key1"];
  double y = js["key2"];

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...