如何解决为什么 nlohmann json 对象的 decltype 不同?
如何从 nlohmann 对象中提取底层数据类型的信息?
既然值在 json 中存储为原始数据类型,为什么它不给出像下面的 a
和 b
这样的输出?
对于有序的 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"];
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。