加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

C#队列问题

发布时间:2020-12-15 19:58:47 所属栏目:百科 来源:网络整理
导读:假设我有一堂课 XYNode{ protected int mX; protected int mY;} 和一个队列 QueueXyNode testQueue = new QueueXYNode(); 我想检查具有该特定x和y坐标的节点是否已在队列中. 以下显然不起作用: testQueue.Contains(new XYNode(testX,testY)) 因为即使具有这
假设我有一堂课

XYNode
{
    protected int mX;
    protected int mY;
}

和一个队列

Queue<XyNode> testQueue = new Queue<XYNode>();

我想检查具有该特定x和y坐标的节点是否已在队列中.
以下显然不起作用:

testQueue.Contains(new XYNode(testX,testY))

因为即使具有这些坐标的节点在队列中,我们也会针对不同的XYNode对象进行测试,因此它总是返回false.

什么是正确的解决方案?

解决方法

最简单的方法是重写Equals,以便一个XYNode知道它是否等于另一个XYNode.您应该同时覆盖GetHashCode(),并且还可能实现IEquatable< XYNode>允许强类型的相等比较.

或者,您可以编写IEqualityComparer< XYNode>实现比较任何两个节点并返回它们是否相同 – 然后将其传递给对Enumerable中定义的appropriate overload of the Contains extension method的调用(假设您使用的是.NET 3.5).

还需要考虑的事项:

>您可以使用私有字段而不是受保护字段吗?>你的班级可以密封吗?>你的班级可以不变吗?>你的班级应该是一个结构吗? (判决电话……)>你应该重载==和!=运算符吗?

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读