.NET 3.5在System.Collections.Generic命名空间中包含一个新的集合类:HashSet。这个集合类包含不重复项的无序列表。这种集合称为“集(set)”。集是一个保留字,所以该类有另一个名称HashSet。这个名称很容易理解,因为这个集合基于散列值,插入元素的操作非常快,不需要像List类那样重排集合。

HashSet类提供的方法可以创建合集和交集。

在示例代码中,创建了3个字符串类型的新集,并用一级方程式汽车填充。HashSet类实现了ICollection接口。但是在该类中,Add()方法是显式实现的,还提供了另一个Add()方法。Add()方法的区别是返回类型,它返回一个布尔值,说明是否添加了元素。如果该元素已经在集中,就不添加它,并返回false。

HashSet < string > companyTeams =new HashSet < string > (){ "Ferrari", "McLaren", "Toyota", "BMW","Renault", "Honda" };HashSet < string > traditionalTeams =new HashSet < string > (){ "Ferrari", "McLaren" };HashSet < string > privateTeams =new HashSet < string > (){ "Red Bull", "Toro Rosso", "Spyker","Super Aguri" };if (privateTeams.Add("Williams"))Console.WriteLine("Williams added");
if (!companyTeams.Add("McLaren"))Console.WriteLine("McLaren was already in this set");

两个Add()方法的输出写到控制台上:

Williams added

McLaren was already in this set

方法IsSubsetOf()和IsSupersetOf()比较集和实现了IEnumerable接口的集合,返回一个布尔结果。这里,IsSubsetOf()验证traditionalTeams中的每个元素是否都包含在companyTeams中,IsSupersetOf()验证traditionalTeams是否没有与companyTeams比较的额外元素。

if (traditionalTeams.IsSubsetOf(companyTeams))
{Console.WriteLine("traditionalTeams is " +"subset of companyTeams");
}if (companyTeams.IsSupersetOf(traditionalTeams))
{Console.WriteLine("companyTeams is a superset of " +"traditionalTeams");
}

这个验证的结果如下:

traditionalTeams is a subset of companyTeams

companyTeams is a superset of traditionalTeams

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/pretyjfh/archive/2010/08/08/579493.aspx

HashSet 用法

.NET 3.5在System.Collections.Generic命名空间中包含一个新的集合类:HashSet。这个集合类包含不重复项的无序列表。这种集合称为“集(set)”。集是一个保留字,所以该类有另一个名称HashSet。这个名称很容易理解,因为这个集合基于散列值,插入元素的操作非常快,不需要像List类那样重排集合。

HashSet类提供的方法可以创建合集和交集。

创建HashSet:

HashSet hs = new HashSet();

HashSet companyTeams = new HashSet() { “Ferrari”, “McLaren”, “Toyota”, “BMW”, “Renault”, “Honda” };

HashSet改变集的值的方法:

Add(): 如果某元素不在集合中,Add()方法就把该元素添加到集合中。在其返回值Boolean中,返回元素是否添加的信息

eg:

if (!companyTeams.Add(“McLaren”))
Console.WriteLine(“McLaren was already in this set”);

Clear():方法Clear()删除集合中的所有元素

eg: companyTeams.Clear();

Remove():Remove()方法删除指定的元素

eg: companyTeams.Remove(“McLaren”);

RemoveWhere(): RemoveWhere()方法需要一个Predicate委托作为参数。删除满足谓词条件的所有元素

Predicate 可以委托给一个函数或者一个拉姆达表达式:

委托给拉姆达表达式:

eg:
companyTeams.RemoveWhere(company => { if (company.Length > 5) { return true; } else { return false; } });

委托给一个函数:

eg:

companyTeams.RemoveWhere(CheckLength);

public bool CheckLength(string company)
{
return company.Length > 5 ? true : false;
}

CopyTo(): CopyTo()把集合中的元素复制到一个数组中

eg:

string[] strArray = new string[companyTeams.Count];
companyTeams.CopyTo(strArray);
foreach (string str in strArray)
{
Console.WriteLine(str);
}

ExceptWith():ExceptWith()方法把一个集合作为参数,从集中删除该集合中的所有元素

eg:

companyTeams.ExceptWith(privateTeams);
foreach (var str in companyTeams)
{
Console.WriteLine(str);
}

UnionWith():UnionWith()方法把传送为参数的集合中的所有元素添加到集中

eg:

companyTeams.UnionWith(privateTeams);
foreach (var str in companyTeams)
{
Console.WriteLine(str);
}

HashSet仅返回集的信息、不修改元素的方法。

Contains():如果所传送的元素在集合中,方法Contains()就返回true

eg:

if (companyTeams.Contains(“BMW”))
{
Console.WriteLine(“companyTeams contains “BMW””);
}

IsSubsetOf():如果参数传送的集合是集的一个子集,方法IsSubsetOf()就返回true

eg:

if (traditionalTeams.IsSubsetOf(companyTeams))
{
Console.WriteLine("traditionalTeams is " + “subset of companyTeams”);
}

IsSupersetOf():如果参数传送的集合是集的一个超集,方法IsSupersetOf()就返回true

eg:
if (companyTeams.IsSupersetOf(traditionalTeams))
{
Console.WriteLine("companyTeams is a superset of " + “traditionalTeams”);
}

Overlaps():如果参数传送的集合中至少有一个元素与集中的元素相同,Overlaps()就返回true

eg:

traditionalTeams.Add(“Williams”);
if (privateTeams.Overlaps(traditionalTeams))
{
Console.WriteLine("At least one team is " + "the same with the traditional " + “and privateteams”);
}

SetEquals():如果参数传送的集合和集包含相同的元素,方法SetEquals()就返回true

http://www.cnblogs.com/xiaopin/archive/2011/01/08/193050.html

HashSet是以数学Set集合为基础的,使用HashSet可以提高集合的运算。使用HashSet集合不自带排序方法,如果需要排序的需求可以参考使用List集合配合Sort方法。

HashSet的优势在与运算快,作为一种存放在内存的数据,可以很快的进行设置和取值的操作。HashSet无法向里面添加重复的数据,避免添加HashSet里面的数据重复。我们使用HashSet常常在集合相加集合相减这些集合与集合之间的操作之中。

使用HashSet作为内存存储的快速数据库,这个需要随时跟新HashSet里面的数据,因为在HashSet中一个长时间未被访问的数据,将被系统自动回收掉,那么就会导致失败,那么如何才能保证HashSet里面的值是长存在的而且达到不断的更新里面的值呢?

首先程序过来访问我们HashSet里面有没有需要的数据,如果有我们需要的数据就直接返回给用户,不用调用查询数据库的操作。如果HashSet里面没有我们需要的数据,程序再去查询一次数据库是否有该Query数据,如果有返回给用户同时把查询的结果添加到HashSet里面,这么做可以一定程度的降低查询数据库所带来的不便,但是不能根除,需要进一步提升性能,可以查看前面的缓存策略使用memcached来提高网站查询和访问。

两个集合的并集

HashSet<int> numbers1;
HashSet<int> numbers2;
//分别进行numbers1和numbers2的值初始化或赋值
numbers1.UnionWith(numbers2);//求两个集合的并集。

求两个集合的交集

HashSet<int> numbers1;
HashSet<int> numbers2;
//分别进行numbers1和numbers2的值初始化或赋值
numbers1.IntersectWith(numbers2);//求两个集合的交集。

求两个集合的差集

HashSet<int> numbers1;
HashSet<int> numbers2;
//分别进行numbers1和numbers2的值初始化或赋值
numbers1.ExceptWith(numbers2);//求两个集合的差集。

求两个集合的对称差集

HashSet<int> numbers1;
HashSet<int> numbers2;
//分别进行numbers1和numbers2的值初始化或赋值
numbers1.SymmetricExceptWith(numbers2);//求两个集合的对称差集。

.HashSet常用扩展方法

2.1.Add,将项目添加到HashSet之中。

2.2.Clear,清空HashSet里面的值。

2.3.Remove,从HashSet中移除值。

2.4Contains,判断HashSet是否包含指定项目。

2.4Equals(Object),判断是否相等。

HashSet与Linq操作
HashSet与LINQ的对等的方法

UnionWith ==> Union

IntersectWith ==> Interset

ExceptWith ==> Except

不提供排序 ==> Distinct

那么我们已经有很多的集合类型如List ,Dictionary<TKey,TValue>或Hashtable等这些集合类型,我们该如何选定我应该采用的哪一个集合类型呢?

“如果你必须建立新的设定,或则如果应用程序只需要存取提供的任务,那么使用任何的IEnumerable集合都已经足够了。但是,如果应用程序需要存取其他值,或则不建议不需要建立新的集合,这时可使用HashSet.”

原文链接:https://blog.csdn.net/scalzdp/article/details/2734427

C# HashSet 用法相关推荐

  1. java高级教程_Java高级教程02

    1.Java线程 1.1. 多线程和多进程 多进程:操作系统能够同时进行多个任务: 每个app(word,播放器,浏览器)可以同时运行 多线程:同一应用程序中哟多个顺序流同时执行 线程是进程中的一部分 ...

  2. Java部分集合以及部分常用类

    学习内容: 集合 1.1 Collection接口 1.2 List接口 1.3 Set接口 1.4 Map接口 常用类 2.1 Object 2.2 String 2.3 StringBuilder ...

  3. 逆向爬虫34 Java基础二

    逆向爬虫34 Java基础二 目的 总结java和之前学过语言之间相似和不同的地方,方便记忆 关于Object ( 上节回顾 ) Object可以泛指java中的任何对象 -> 父类可以泛指子类 ...

  4. Java集合系列之四大常用集合(ArrayList、LinkedList、HashSet、HashMap)的用法

    Java集合系列之四大常用集合(ArrayList.LinkedList.HashSet.HashMap)的用法 ArrayList ArrayList就是传说中的动态数组,用MSDN中的说法,就是A ...

  5. Set中的HashSet和TreeSet特点及用法

    2.5.3 Set:接口 2.5.3.1 HashSet 特点:无序,唯一 数据结构:基于哈希表 HashSet1:基本用法及特点 创建一个HashSet集合对象: HashSet<泛型> ...

  6. JAVA知识点 HashSet 集合的用法[案例+代码+总结]

    文章目录 前言 一.HashSet 集合的存储 二.将Object类存入HashSet 总结 前言 HashSet 是 Set 接口的一个实现类,它所存储的元素是不可重复的,并且元素都是无序的.这个必 ...

  7. hashset java 键值对_Java集合 - HashSet的定义以及用法

    HashSet的定义 HashSet类实现了Set接口,由一个实际上是HashMap实例的散列表​支持.不能保证该集合的迭代次序,这意味着该类不能保证元素随时间的不变顺序.这个类允许null元素.该类 ...

  8. 【转】HashSet的用法

    原文网址:http://blog.csdn.net/aidesudi/article/details/4720201 Java代码 public class TestHashSet { public  ...

  9. set和hashset区别及用法

    [Set和HashSet] 1.Set ​ 概念:Set集合类似于一个瓶罐子,集合中的多个对象之间没有明显的顺序排列. ​ 特点如下: ​ set集合不允许包含相同的元素,如果试图要把两个相同的元素加 ...

最新文章

  1. 学术部活动具体落实计划
  2. php 扩展apc 参数优化
  3. glTF格式初步了解
  4. Spring 构造注入 传參数
  5. 资源:代码舞动动画 提供gif图片(含程序、源码、下载地址)
  6. day16 java中的package和import
  7. [转载] 05 Numpy排序搜索计数及集合操作
  8. 多线程----简单的生产者和消费者
  9. 泊松分布 二项分布 正态分布之间的联系,与绘制高斯分布图
  10. 计算机保研-中科院计算所霸面(笔试面试)
  11. 微信小程序手机号绑定功能(登录后绑定)
  12. Android Library的创建及使用详解
  13. python递归,匿名函数
  14. 股票交易一点感悟和程序化交易实战
  15. AsyncTask 的参数
  16. python PEP8问题及解决
  17. linux 时区 0900是哪,解析表PST/CEST/UTC/ETC/等时区的日期时间
  18. 高级开发工程师如何快速晋升为架构师?高级开发工程师与架构师到底有啥区别?
  19. 快消供应链管理解决方案
  20. JAVA基础之基本类型

热门文章

  1. 数据分析思维分析方法和业务知识——用数据分析解决问题
  2. python excel行数_Python:打开现有的Excel文件并计算工作表中的行数
  3. Elasticsearch查询使用
  4. Visual studio开发C#快捷键
  5. oracle 回退到某个时间,oracle 闪回技术
  6. 2020年计算机组装行业,2020年办公电脑什么配置合适 2020组装机电脑配置单推荐...
  7. libxlsxwriter在单元格中间划斜线
  8. python word.documents.open报错_Python:读取两种Word文件简述及文件未能引发事件错误...
  9. HTML基础总结 02
  10. 高能而低调的隐士:专为设计师而生的ThinkPad