zoukankan      html  css  js  c++  java
  • 使用NlohmannJson写JSON保留插入顺序

    1. 正文

    nlohmann/json是一个C++的读写JSON的组件,号称使用现代C++范式写的。简单看了一下,这个组件确实包含了很多cpp11以上的特性,在vs2015及一下的版本甚至没办法正常编译。要正常使用需要vs2017及以上版本才行。

    在使用过程中,遇到了一个问题是没办法保持插入的顺序,每个插入的键值对会按照字符串的顺序排列的,因为其内部用到了std:map。查看了github的主页说明,是这么说的:

    By default, the library does not preserve the insertion order of object elements. This is standards-compliant, as the JSON standard defines objects as "an unordered collection of zero or more name/value pairs". If you do want to preserve the insertion order, you can specialize the object type with containers like tsl::ordered_map (integration) or nlohmann::fifo_map (integration).

    这段话的意思是JSON标准的定义是零个或多个键值对对的无序集合,如果要保证插入顺序,可以使用tsl::ordered_map(integration)或nlohmann::fifo_map(integration)等容器专门化对象类型。nlohmann::fifo_map同样在github上找到,“专门化对象类型”的意思是nlohmann/json组件内部用到了很多std容器,只需要将其替换成可以保存插入顺序的容器就可以了,也就是nlohmann::fifo_map。

    重新找了一些英文资料,最终找到的解决方案如下:

    #include "json.hpp"
    #include "fifo_map.hpp"
    #include <iostream>
    
    using namespace nlohmann;
    
    // A workaround to give to use fifo_map as map, we are just ignoring the 'less' compare
    template<class K, class V, class dummy_compare, class A>
    using my_workaround_fifo_map = fifo_map<K, V, fifo_map_compare<K>, A>;
    using my_json = basic_json<my_workaround_fifo_map>;
    
    int main()
    {
    	my_json j;
    	j["f"] = 5;
    	j["a"] = 2;
    	my_json j2 = {
    	  {"pi", 3.141},
    	  {"happy", true},
    	  {"name", "Niels"},
    	  {"nothing", nullptr},
    	  {"answer", {
    	    {"everything", 42}
    	  }},
    	  {"list", {1, 0, 2}},
    	  {"object", {
    	    {"currency", "USD"},
    	    {"value", 42.99}
    	  }}
    	};
    
    	std::cout << j.dump(4) << std::endl;
    	std::cout << j2.dump(4) << std::endl;
    
    	return 0;
    }
    

    运行结果如下所示,可以看到输出的JSON不再是字符串顺序而是插入顺序:

    cesium实例位置

    2. 参考

    [1] nlohmann/json主页介绍
    [2] nlohmann/json关于保留插入顺序的讨论

  • 相关阅读:
    BZOJ 3144 [Hnoi2013]切糕
    一场比赛:20170707
    BZOJ 2815 [ZJOI2012]灾难
    BZOJ 1088 [SCOI2005]扫雷Mine
    BZOJ 1052 [HAOI2007]覆盖问题
    BZOJ 3505 [Cqoi2014]数三角形
    BZOJ 2957 楼房重建
    BZOJ 2654 tree
    丁酉年六月十一ACM模拟赛
    BZOJ 3438 小M的作物 & BZOJ 1877 [SDOI2009]晨跑
  • 原文地址:https://www.cnblogs.com/charlee44/p/12152678.html
Copyright © 2011-2022 走看看