template <typename T>
static basic_json make_array(size_ n, const T& val)
template <typename T>
static basic_json make_array(size_ n, const T& val,
const allocator_type& alloc = allocator_type())
template <std::size_t N>
static basic_json make_array(std::size_t size1 ... size_t sizeN)
template <std::size_t N,typename T>
static basic_json make_array(std::size_t size1 ... size_t sizeN, const T& val)
template <std::size_t N,typename T>
static basic_json make_array(std::size_t size1 ... size_t sizeN, const T& val,
const allocator_type& alloc)
Makes a multidimensional array with the number of dimensions specified as a template parameter. The size of each dimension is passed as a parameter, and optionally an inital value. If no initial value, the default is an empty json object. The elements may be accessed using familiar C++ native array syntax.
json a = json::make_array(10,0); // angle brackets can be omitted when N = 1
a[1] = 1;
a[2] = 2;
std::cout << pretty_print(a) << '\n';
Output:
[0,1,2,0,0,0,0,0,0,0]
json a = json::make_array<2>(3,4,0);
a[0][0] = "Tenor";
a[0][1] = "ATM vol";
a[0][2] = "25-d-MS";
a[0][3] = "25-d-RR";
a[1][0] = "1Y";
a[1][1] = 0.20;
a[1][2] = 0.009;
a[1][3] = -0.006;
a[2][0] = "2Y";
a[2][1] = 0.18;
a[2][2] = 0.009;
a[2][3] = -0.005;
std::cout << pretty_print(a) << '\n';
Output:
[
["Tenor","ATM vol","25-d-MS","25-d-RR"],
["1Y",0.2,0.009,-0.006],
["2Y",0.18,0.009,-0.005]
]
json a = json::make_array<3>(4,3,2,0);
a[0][2][0] = 2;
a[0][2][1] = 3;
std::cout << pretty_print(a) << '\n';
Output:
[
[
[0,0],
[0,0],
[2,3]
],
[
[0,0],
[0,0],
[0,0]
],
[
[0,0],
[0,0],
[0,0]
],
[
[0,0],
[0,0],
[0,0]
]
]