有没有办法将YAML :: Node对象中的所有值的副本转换为新对象(即克隆)?还有一种方法可以通过节点中的值(即.equals()函数而不是.is()函数)测试两个YAML :: Node对象之间的相等性吗?
考虑以下示例:
YAML::Node a;
a["x"][1]["y"][2]["z"][3] = 1;
std::cout << "A_____\n" << a << "\n\n\n\n";
std::cout << "Test 1\n";
YAML::Node z = a["x"][1]["y"][2]["z"];
z[3] = 2;
std::cout << "Z_____\n" << z << "\n";
std::cout << "A_____\n" << a << "\n\n\n\n";
std::cout << "Test 2\n";
YAML::Node b = a;
b["x"][1]["y"][2]["z"][3] = 3;
std::cout << "B_____\n" << b << "\n";
std::cout << "Z_____\n" << z << "\n";
std::cout << "A_____\n" << a << "\n\n\n\n";
std::cout << "Test 3\n";
YAML::Node c;
c["x"][1]["y"][2]["z"][3] = 3;
std::cout << "C_____\n" << c << "\n";
std::cout << "A_____\n" << a << "\n";
std::cout << "a == c: " << bool(a==c) << "\n";
std::cout << "z == a[\"x\"][1][\"y\"][2][\"z\"]: "
<< bool(z == a["x"][1]["y"][2]["z"]) << "\n\n";
运行时输出以下内容:
A_____
x:
1:
y:
2:
z:
3: 1
Test 1
Z_____
3: 2
A_____
x:
1:
y:
2:
z:
3: 2
Test 2
B_____
x:
1:
y:
2:
z:
3: 3
Z_____
3: 3
A_____
x:
1:
y:
2:
z:
3: 3
Test 3
C_____
x:
1:
y:
2:
z:
3: 3
A_____
x:
1:
y:
2:
z:
3: 3
a == c: 0
z == a["x"][1]["y"][2]["z"]: 1
在测试1中,修改z
也会修改a["x"][1]["y"][2]["z"]
的值,类似地,在测试2中,修改b
等同于修改a
。这些复制语义是否被认为是API的一部分(即它们将来可能会发生变化)?我希望能够编写z = getZ()
之类的代码,并让getZ()
返回a["x"][1]["y"][2]["z"]
(“x”,“y”和“z”的名称可能会发生变化未来)。修改z
然后会修改a
,如示例所示。
另外,有没有办法将a
克隆到新对象b
中,以便修改b
也不会修改a
?
在test3中,c
中的值与a
中的值相同。有没有办法为YAML :: Node对象做a.equals(c)
一般来测试两个节点中的值是否都相同?在示例中,a.equals(c)
将为真。
答案 0 :(得分:1)
深度复制节点:
YAML::Node node = /* ... */;
YAML::Node other = Clone(node);
(现已实施;您可以看到旧的bug report。)
目前的行为是有意的(换句话说,典型的“副本”只是设置身份),并且不会改变。
至于平等,对于YAML来说,这是一个非常困难的问题。在yaml-cpp项目页面上对this issue进行了一些讨论。