博客
关于我
线程基础示例代码之Barrier
阅读量:499 次
发布时间:2019-03-07

本文共 1634 字,大约阅读时间需要 5 分钟。

Barrier是算法中的一个同步基元,允许多个线程(称为参与者)在分阶段同时处理任务。在到达代码中的拦截点之前,每个参与者都会继续执行。拦截点表示一个工作阶段的结束,单个参与者如果在所有参与者都到达拦截点之前到达,就会被阻塞,直到所有参与者都到达。只有所有参与者都到达屏障后,才可以执行后续操作。

举个例子,假设我们约好几位好友前往同一个地点A见面。在到达地点A之前,每个人会选择不同的交通工具(执行任务)。已经到达的人会等待,直到所有人到达。大家到达后才能继续搭车去旅游景点(后续操作)。

Barrier在算法中应用广泛,特别是当任务可以被拆分成多个小任务以充分利用多核处理器时。每个小任务完成后,需要对结果进行处理以得到最终答案。

然而,大多数情况下,建议使用TaskFactory.ContinueWhenAll来替代Barrier。但在涉及共享资源的情况下,Barrier是更好的选择。

Barrier在初始化时会等待指定数量的信号到来,这个数量在初始化时确定。所有信号到达后,Barrier会执行指定的动作,这个动作也是在初始化时确定的。Barrier执行动作后会重置,重新开始等待指定数量的信号,再执行指定动作。

信号可以通过SignalAndWait()方法发送。执行这个方法的Task或线程会进入等待状态。

参与者数量可以通过AddParticipant()和RemoveParticipant()方法动态管理。

以下是一个示例代码:

using System;
using System.Threading;
using System.Threading.Tasks;
public class App
{
private static Barrier barrier;
private static int count = 0;
private static void DoWork()
{
Interlocked.Add(ref count, 4);
Console.WriteLine("A participant arrived..");
barrier.SignalAndWait();
}
static void Main(string[] args)
{
barrier = new Barrier(3, (b) =>
{
Console.WriteLine($"Task completed: count={count}");
});
barrier.AddParticipants(2);
Console.WriteLine($"Current participant count: {barrier.ParticipantCount}");
barrier.RemoveParticipant();
Console.WriteLine($"Current participant count: {barrier.ParticipantCount}");
Parallel.Invoke(DoWork, DoWork, DoWork, DoWork);
Console.ReadLine();
barrier.Dispose();
}
}

输出结果如下:

当前参与者数量:5
当前参与者数量:4
A participant arrived..
A participant arrived..
A participant arrived..
A participant arrived..
Task completed: count=16

转载地址:http://ubmcz.baihongyu.com/

你可能感兴趣的文章
Mysql学习总结(65)——项目实战中常用SQL实践总结
查看>>
Mysql学习总结(66)——设置MYSQL数据库编码为UTF-8
查看>>
Mysql学习总结(68)——MYSQL统计每天、每周、每月、每年数据 SQL 总结
查看>>
Mysql学习总结(69)——Mysql EXPLAIN 命令使用总结
查看>>
Mysql学习总结(6)——MySql之ALTER命令用法详细解读
查看>>
Mysql学习总结(70)——MySQL 优化实施方案
查看>>
Mysql学习总结(71)——MySQL 重复记录查询与删除总结
查看>>
Mysql学习总结(73)——MySQL 查询A表存在B表不存在的数据SQL总结
查看>>
Mysql学习总结(77)——温故Mysql数据库开发核心原则与规范
查看>>
Mysql学习总结(78)——MySQL各版本差异整理
查看>>
Mysql学习总结(79)——MySQL常用函数总结
查看>>
Mysql学习总结(7)——MySql索引原理与使用大全
查看>>
Mysql学习总结(80)——统计数据库的总记录数和库中各个表的数据量
查看>>
Mysql学习总结(81)——为什么MySQL不推荐使用uuid或者雪花id作为主键?
查看>>
Mysql学习总结(82)——MySQL逻辑删除与数据库唯一性约束如何解决?
查看>>
Mysql学习总结(83)——常用的几种分布式锁:ZK分布式锁、Redis分布式锁、数据库分布式锁、基于JDK的分布式锁方案对比总结
查看>>
Mysql学习总结(84)—— Mysql的主从复制延迟问题总结
查看>>
Mysql学习总结(85)——开发人员最应该明白的数据库设计原则
查看>>
Mysql学习总结(8)——MySql基本查询、连接查询、子查询、正则表达查询讲解
查看>>
MySQL学习笔记十七:复制特性
查看>>