相等运算符用于检查给定的两个序列是否相等。在LINQ中,相等操作仅包含一个称为SequenceEqual的运算符。它用于检查序列或集合中给定的元素是否相等。如果给定的序列或集合相等,则返回true,否则返回false 。
- 如果集合或序列具有原始数据类型,它将比较元素的值和数量。
- 如果集合具有复杂的类型元素,它将检查对象的引用。
- 它不支持C#和VB.Net语言的查询语法。
- 它支持C#和VB.Net语言的方法语法。
- 它同时存在于Queryable和Enumerable类中。
- 它是通过使用延迟执行来实现的。
- 您可以使用IEqualityComparer类使用SequenceEqual方法比较两个复杂类型的集合。
范例1:
// C# program to check the given
// sequences are equal or not
using System;
using System.Linq;
class GFG {
static public void Main()
{
// Data source
char[] sequence1 = {'p', 'q', 'r', 's', 'y', 'z'};
char[] sequence2 = {'p', 'q', 'r', 's', 'y', 'z'};
// Display the sequences
Console.WriteLine("Sequence 1 is: ");
foreach(var s1 in sequence1)
{
Console.WriteLine(s1);
}
Console.WriteLine("Sequence 2 is: ");
foreach(var s2 in sequence2)
{
Console.WriteLine(s2);
}
// Check the given sequences are equal or
// not Using SequenceEqual function
var result = sequence1.SequenceEqual(sequence2);
Console.WriteLine("Given Sequences are equal: {0}", result);
}
}
输出:
Sequence 1 is:
p
q
r
s
y
z
Sequence 2 is:
p
q
r
s
y
z
Given Sequences are equal: True
范例2:
// C# program to check the names of
// the employee are equal or not
using System;
using System.Linq;
using System.Collections.Generic;
// Employee details
public class Employee1 {
public int emp_id1
{
get;
set;
}
public string emp_name1
{
get;
set;
}
public string emp_lang1
{
get;
set;
}
}
// Employee details
public class Employee2 {
public int emp_id2
{
get;
set;
}
public string emp_name2
{
get;
set;
}
public string emp_lang2
{
get;
set;
}
}
public class GFG {
// Main method
static public void Main()
{
List emp1 = new List() {
new Employee1() {emp_id1 = 209, emp_name1 = "Anjita",
emp_lang1 = "C#"},
new Employee1() {emp_id1 = 210, emp_name1 = "Soniya",
emp_lang1 = "C"},
new Employee1() {emp_id1 = 211, emp_name1 = "Rohit",
emp_lang1 = "Java"},
};
List emp2 = new List() {
new Employee2() {emp_id2 = 209, emp_name2 = "Anjita",
emp_lang2 = "Scala"},
new Employee2() {emp_id2 = 210, emp_name2 = "Soniya",
emp_lang2 = "Python"},
new Employee2() {emp_id2 = 211, emp_name2 = "Rohit",
emp_lang2 = "Ruby"},
};
// Query to check the names of
// the employee are equal or not
// Using SequenceEqual method
var res = emp1.Select(e => e.emp_name1).SequenceEqual(emp2.Select(e => e.emp_name2));
Console.WriteLine(res);
}
}
输出:
True