您获得的标记是<代码>int*,作为<代码>std:map的关键,仍然能够按价值检索部件。 之所以如此,只是一个单独的<代码>int*,只是提供一个阵列的开端,你也需要最终来计算任何东西(相当于和更多的C类一样的长度)。 换言之,<代码>int*不构成一个阵列(动力或其他方式);在这种情况下,它成为起序号的保存人。
您可使用<代码>std:pair<int*, int*>,但只能用于对数据的非发表看法。 也就是说,如果你用<条码”对记忆进行人工管理:地图和设计;std:pair<int*, int*> int>,你用头痛填写。 一种可能性是使用智能标识:std:pair<std:unique_ptr<int[]> int*>
。 但正如其他人所建议的那样,只是使用<代码> :vector。 因为它仍然符合处理<代码>int*的类似C接口。 加上“<代码>const :pair<std:unique_ptr<int> int*>,仍然使你能够播下记忆,因为记忆能够打破地图的次序,使你陷入困境。
使用<代码>int*>t*或std:unique_ptr<int[]>
的最终打击是:你需要提供严格软弱的次序,即<代码>:要求,而std:vector<int>
随附适当的<代码>operator<。 另一方面,如果你在<条码>上填写,则你需要为两者提供一 has。 对于其价值而言,使用<代码>的简单校长: (same semantics as std:vector
compar):
struct compare {
typedef std::pair<std::unique_ptr<int[]>, int*> value_type;
bool
operator()(value_type const& lhs, value_type const& rhs) const
{
return std::lexicographical_compare(lhs.first.get(), lhs.second
, rhs.first.get(), rhs.second);
}
};
然后可以使用<代码>std:map<std:pair<std:unique_ptr<int[]> int*> int, compar>。