比较两个对象 - 严格弱

Comparing two objects - strict weak

本文关键字:对象 两个 比较      更新时间:2023-10-16

我在比较以下类的对象时遇到问题:(只有字段是相关的)

class Rule{
private:
    string _src_IP,
        _src_port,
        _dest_IP,
        _dest_port,
        _protocol; };

_src_IP和_dst_IP可以包含 IP 地址("0.0.0.0"-"255.255.255.255") 或"任何"。
_src_Port 和_dst_Port可以包含端口号 ("0" - "65535") 或"任何"。
_protocol可以包含"TCP"、"UDP"或"any"。

困难在于创建一个比较(运算符<和运算符>),它将满足严格弱排序的标准数学定义。

如果有人能想到一些事情,那将是非常有帮助的。

我想你想在基于树的关联容器(如 std::map)中使用此结构作为键,并查找与特定值集匹配的规则(如果需要,使用"任何"匹配)。

但是,这是不可能的:严格的弱排序(对键的要求)意味着,虽然您不必能够分辨出每对不同的值,哪个值更大,但唯一允许的偏差是您可以创建组,其中您认为所有元素都相等。十进制整数的字符串表示就是一个例子:U "2" 和 "002" 彼此相等,尽管它们是不同的字符串。如果我在同一组中找到另一个等于一个字符串的字符串(例如"02",它被认为等于"2"),我可以确定它与该组中的所有字符串相等。

在您的设置中,您希望将 192.168.0.1->8.8.8.8:53/udp 视为等于 any->8.8.8.8:53/udp,因此它们必须位于同一组中。10.0.3.5->8.8.8.8:53/udp 也是如此,它也应该被视为等于 any->8.8.8.8/udp。如果是严格的弱排序,您还需要考虑 10.0.3.5->8.8.8.8:53/udp 等于 192.168.0.1->8.8.8.8:53/udp,这是您很可能不想要的。

相关文章: