前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >.NET6新东西--PriorityQueue

.NET6新东西--PriorityQueue

作者头像
喵叔
发布2021-12-27 08:41:42
2040
发布2021-12-27 08:41:42
举报
文章被收录于专栏:喵叔's 专栏

在.NET6以前的版本中中我们为了表示先进先出集合通常会使用Queue类,这个集合中的对象一般会按照放入顺序检索。比如下面的代码:

代码语言:javascript
复制
var users = new Queue<User>();
users.Enqueue(new User() { Name = "张三", Age = 10 });
users.Enqueue(new User() { Name = "李四", Age = 20});
users.Enqueue(new User() { Name = "王五", Age = 30 });
users.Enqueue(new 
 
while (users.TryDequeue(out var user))
{
    Console.WriteLine(user.Age);
}

输出结果如下:

代码语言:javascript
复制
10
20
30

在.NET6中,新增了另一个能表示先进先出集合的类,就是PriorityQueue类,它可以用来表示具有值和优先级的集合。它里面存储的对象按照优先级值从小到大的顺序检索。比如最后放入队列的任务必须优先处理,那么我们的代码可以这么写:

代码语言:javascript
复制
var users = new PriorityQueue<User, int>(); 

users.Enqueue(new User() { Name = "张三", Age = 10}, 100);
users.Enqueue(new User() { Name = "里斯", Age = 20}, 100);
users.Enqueue(new User() { Name = "王五", Age = 30}, 1);
 
while (users.TryDequeue(out var user,out var priority))
{
    Console.WriteLine(user.Age);
}

输出结果如下:

代码语言:javascript
复制
30
10
20

在上面的代码中优先级TPriority是int类型,但是它可以不是数字,可以是任何类型,只要满足它的实例之间能比较大小就可以。甚至我们可以自定义比较器,实现更加复杂的优先级计算逻辑。比如按照年龄从大到小的顺序排列优先级并输出:

代码语言:javascript
复制
var users = new PriorityQueue<User, int>();
users.Enqueue(new User() { Name = "张三", Age = 10 }, 100);
users.Enqueue(new User() { Name = "里斯", Age = 20 }, 200);
users.Enqueue(new User() { Name = "王五", Age = 30 }, 300);
while (users.TryDequeue(out var job, out var priority))
{
    Console.WriteLine(job.Age);
}
public class UserComparer : IComparer<int>
{
    public int Compare(int x, int y)
    {
        return y.CompareTo(x);
    }
}

输出结果为:

代码语言:javascript
复制
30
20
10

在这里一定会有读者疑问,比较是在什么时候进行的呢?是放入队列时还是从队列取出时呢?答案是放入和取出时都会进行优先级比较,放入时只和队列顶部元素进行比较,取出时需要比较队列中所有剩余元素的优先级。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/12/25 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档