首页 程序笔记 C#13新特性 使用System.Threading.Lock简化线程同步

C#13新特性 使用System.Threading.Lock简化线程同步

C# 13 引入了新的线程同步类型 System.Threading.Lock,它通过作用域管理的方式简化了锁的使用,使代码更加清晰可靠。本文将全面介绍 System.Threading.Lock 的功能、适用场景,并提供完整的运行示例程序。

1. 什么是 System.Threading.Lock?

System.Threading.Lock 是一个新的线程同步类型,用于简化对共享资源的访问控制。通过 EnterScope() 方法,可以在特定的作用域内进入临界区,并在作用域结束时自动释放锁。

System.Threading.Lock的优势

自动化管理锁释放: 无需手动调用 Monitor.Exit 或 Dispose。

作用域管理: 锁的生命周期与代码块作用域一致,减少内存泄漏或死锁的风险。

简洁性: 避免手动 try-finally 处理,代码更加清晰。

2. 适用场景和完整示例

以下是一些典型使用场景,每个场景都包含完整的代码示例,可以拷贝测试运行。

场景 1:多线程计数器的线程安全操作

多个线程同时递增共享计数器,使用 System.Threading.Lock 确保线程安全。

using System;
using System.Threading;
using System.Threading.Tasks;
namespace CSharp13App
{
    class Program
    {
        private static Lock _lock = new Lock();
        private static int _counter = 0;
        static async Task Main(string[] args)
        {
            Console.WriteLine("多线程计数器示例开始...");
            // 启动多个并发任务
            Task[] tasks = new Task[10];
            for (int i = 0; i < 10; i++)
            {
                tasks[i] = Task.Run(() => IncrementCounter());
            }
            // 等待所有任务完成
            await Task.WhenAll(tasks);

            Console.WriteLine($"计数器最终值: {_counter}");
        }

        static void IncrementCounter()
        {
            using (_lock.EnterScope())
            {
                Console.WriteLine($"线程 {Thread.CurrentThread.ManagedThreadId} 正在递增计数器...");
                int temp = _counter;
                Thread.Sleep(100); // 模拟复杂操作
                _counter = temp + 1;
                Console.WriteLine($"线程 {Thread.CurrentThread.ManagedThreadId} 更新后的计数器值: {_counter}");
            }
        }
    }
}

执行结果:

场景 2:保护共享队列的线程安全操作

在生产者-消费者模式中,保护队列的读写操作。

using System;
using System.Threading;
using System.Threading.Tasks;

namespace CSharp13App
{
    class Program
    {
        private static Lock _queueLock = new Lock();
        private static Queue<int> _queue = new Queue<int>();
        static async Task Main(string[] args)
        {
            Task producer = Task.Run(() => Producer());
            Task consumer = Task.Run(() => Consumer());

            await Task.WhenAll(producer, consumer);
        }
        static void Producer()
        {
            for (int i = 0; i < 10; i++)
            {
                using (_queueLock.EnterScope())
                {
                    _queue.Enqueue(i);
                    Console.WriteLine($"生产者添加: {i}");
                }
                Thread.Sleep(200); // 模拟生产延迟
            }
        }
        static void Consumer()
        {
            for (int i = 0; i < 10; i++)
            {
                int item;
                using (_queueLock.EnterScope())
                {
                    if (_queue.Count > 0)
                    {
                        item = _queue.Dequeue();
                        Console.WriteLine($"消费者取出: {item}");
                    }
                    else
                    {
                        Console.WriteLine("队列为空,等待中...");
                        continue;
                    }
                }
                Thread.Sleep(300); // 模拟消费延迟
            }
        }
    }
}

执行结果:

场景 3:异步代码中的线程同步

在异步任务中保护共享资源,避免死锁或资源竞争。

using System;
using System.Threading;
using System.Threading.Tasks;

class Program
{
    private static Lock _lock = new Lock();
    private static int _sharedResource = 0;

    static async Task Main(string[] args)
    {
        Task[] tasks = new Task[5];
        for (int i = 0; i < 5; i++)
        {
            tasks[i] = PerformAsyncTask(i);
        }

        await Task.WhenAll(tasks);
        Console.WriteLine($"共享资源最终值: {_sharedResource}");
    }
    
 static async Task PerformAsyncTask(int taskId)
 {
     // 在加锁范围内操作共享资源
     int temp;
     using (_lock.EnterScope())
     {
         Console.WriteLine($"任务 {taskId} 正在访问共享资源...");
         temp = _sharedResource + 1; // 加锁范围内完成操作
     }
     // 在加锁范围外进行异步操作
     await Task.Delay(500); // 模拟异步操作
     using (_lock.EnterScope())
     {
         _sharedResource = temp; // 再次进入锁更新共享资源
         Console.WriteLine($"任务 {taskId} 完成,更新共享资源为: {_sharedResource}");
     }
 }
    //static async Task PerformAsyncTask(int taskId)
    //{
    //    using (_lock.EnterScope())
    //    {
    //        Console.WriteLine($"任务 {taskId} 正在访问共享资源...");
    //        int temp = _sharedResource;
    //        await Task.Delay(500); // 模拟异步操作
    //        _sharedResource = temp + 1;
    //        Console.WriteLine($"任务 {taskId} 完成,更新共享资源为: {_sharedResource}");
        }
    }
}

执行结果 这里有一个错误的写法,会导致异常出现:

这个错误是因为 System.Threading.Lock.Scope 的实例不能跨越 await 或 yield 边界。原因在于 C# 编译器不允许某些结构(值类型)在 async 方法的 await 关键字之后被持有,因为它们可能在任务的不同时间点被破坏或复制,从而导致未定义行为。

System.Threading.Lock 是一个值类型,当我们使用 using (_lock.EnterScope()) 时,它返回的 Scope 结构无法正确跨越 await 边界。这种限制需要我们重新设计异步操作的锁逻辑。

修改之后的执行:

场景 4:复杂计算的线程安全管理

在并发的计算任务中保护计算结果。

using System;
using System.Threading;
using System.Threading.Tasks;
namespace CSharp13App
{
    class Program
    {
        private static Lock _lock = new Lock();
        private static int _result = 0;
        static async Task Main(string[] args)
        {
            Console.WriteLine("并发计算示例开始...");
            Task[] tasks = new Task[10];
            for (int i = 0; i < 10; i++)
            {
                int value = i;
                tasks[i] = Task.Run(() => PerformCalculation(value));
            }
            await Task.WhenAll(tasks);
            Console.WriteLine($"计算结果: {_result}");
        }
        static void PerformCalculation(int value)
        {
            using (_lock.EnterScope())
            {
                Console.WriteLine($"线程 {Thread.CurrentThread.ManagedThreadId} 计算: {_result} + {value}");
                _result += value;
                Thread.Sleep(100); // 模拟计算耗时
            }
        } 
    }
}

执行结果:

3. 为什么选择 System.Threading.Lock?

代码可读性: 使用 using 块管理锁的生命周期,减少繁琐的锁释放代码。

线程安全: 确保锁的自动释放,避免死锁或锁泄漏。

适配异步场景: 与异步代码的无缝集成。

降低错误率: 封装复杂的同步操作,开发者无需关注底层实现。

4. 总结

System.Threading.Lock 是 C# 13 引入的一项强大功能,提供了简洁、安全、高效的线程同步解决方案。它适用于所有需要保护共享资源的场景,无论是多线程计数器、队列操作,还是异步任务管理。通过上述示例程序,我们可以清晰地看到 System.Threading.Lock 的实际应用,并快速将其应用到自己的项目中。

你还在手动管理锁吗?是时候尝试 System.Threading.Lock 了!

3

站星网

C# 13 引入了新的线程同步类型 System.Threading.Lock,它通过作用域管理的方式简化了锁的使用,使代码更加..

为您推荐

C# 认识 System.Guid

GUID:全局唯一标识符 (Globally Unique Identifier,共32位,其中每个 x 是 0-9 或 a-f 范围内的一个十六进制的数字)格 式:xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx例 如:0d9d526e-77c4-46bc-9955-6c0e95bc176e为什..

传统线程技术中创建线程的两种方式

传统的线程技术中有两种创建线程的方式:一是继承Thread类,并重写run()方法;二是实现Runnable接口,覆盖接口中的run()方法,并把Runnable接口的实现扔给Thread。这两种方式大部分人可能都知道,但是为什么这样玩就..

优秀软件工程师必备的7大特性

不是每一个程序员都能成为优秀的软件工程师。在过去的6年时间里,我在Ooyala、Quora和now Quip这3个创业公司面试过许许多多挺有发展潜力的“种子选手”,他们都有着5年以上的工作经验,并且曾为类似于谷歌这样的顶级..

使用 html2canvas 实现截图功能

html2canvas 是一个开源的 JavaScript 库,用于将网页上的 HTML 元素渲染成图像。它通过遍历页面的 DOM 树和计算样式,然后将其绘制到 <canvas> 元素上,最终生成图片。该库不依赖服务器端,而是通过浏览器端的 Java..

使用SuperWebSocket实现Web消息推送

在大部分Web系统中,我们可能遇到需要向客户端推送消息的需求。SuperWebSocket第三方库能让我们轻松的完成任务。SuperWebSocket第三方库可以从网上下载,不过通过Visual Studio Nuget安装更快。引用SuperWebSocket相..

.NET C# 使用Hook钩子实现全局监听键盘和鼠标

C# 是一种面向对象的编程语言,具有丰富的类库和工具支持,适用于各种类型的应用程序开发。Windows 提供了一种称为"钩子"(Hook)的机制,允许拦截并处理系统级别的事件,如键盘按键和鼠标移动。通过结合 C# 和 Hook..

C#使用 Attribute 实现 AOP 功能

在 C# 中,通过自定义 Attribute 并结合一些技术(如动态代理、反射等)可以实现 AOP(面向切面编程)。AOP 通常用于日志记录、性能监控、权限验证等横切关注点。以下是一个使用 C# Attribute 实现 AOP 功能的示例。..

ABP.Net Core使用教程(一)启动模版项目

只需要简单的3步:1,到官网下载模版项目 https://aspnetboilerplate.com/Templates2,用VS2017打开,将Web.Host设置为启动项3,在程序包管理器控制台(Nuget控制台)里设定默认项目为EntityFrameworkCore,执行命令..

C#中的线程安全的集合ConcurrentQueue使用示例

在多线程编程中,如何安全地在不同线程之间共享数据是一个非常重要的问题。C# 为我们提供了一些专门设计的线程安全集合,其中之一就是 ConcurrentQueue<T>。它是一种先进先出(FIFO)的数据结构,专门为多线程环境设..

CSS砌体布局示例和使用场景

CSS砌体布局(Masonry Layout)CSS砌体布局是一种网页布局技术,它的灵感来源于砖石墙的排列方式,类似于“拼图”或“拼砖”的效果。在砌体布局中,元素的排列并不完全遵循传统的网格布局规则,..

使用CSS columns-visibility实现砌体布局

CSS的 columns 属性(如 columns、column-count 和 column-width)通常用于多列文本布局,而不是直接用于砌体布局。然而,结合 columns 和 visibility 属性,可以在某些情况下实现类似砌体布局的效果,虽然它并不完..

使用System.Linq.Dynamic.Core扩展库动态构建 LINQ 查询

System.Linq.Dynamic.Core 是一个扩展库,用于在运行时动态构建 LINQ 查询,支持字符串形式的表达式解析和动态查询操作。它是 .NET 的一个强大工具,适合处理需要灵活定义查询逻辑的场景,例如动态过滤、排序、投影..

小米开源智能家居平台 ha_xiaomi_home 使用示例

小米近期在 GitHub 上开源了名为“ha_xiaomi_home”的项目,即 Home Assistant 米家集成组件。该组件由小米官方支持,旨在让用户在 Home Assistant 中集成和控制小米 IoT 智能设备。主要特点:官方支持:..

微软官方Microsoft.Extensions.AI库使用示例

Microsoft.Extensions.AI 库介绍Microsoft.Extensions.AI 是一个扩展库,用于在 .NET 应用程序中轻松集成人工智能(AI)服务,例如 OpenAI、Azure OpenAI 和其他支持文本生成或语言模型的 API。通过与 Microsoft.Ext..

.Net Core中Dapper的使用详解

1.安装Dapper这里直接使用Nuget安装。安装版本是1.50.5安装完成之后,发现Nuget下已经有了Dapper。2.创建DapperHelper接下来创建一个DapperHelper帮助类,来进行读取数据库连接字符串,打开数据库等操作。public cla..

最新CentOS7安装搭建shadowsocks服务端+客户端使用图文教程

使用的CentOS版本是7.9,其他版本也可以。超级推荐的是搭建shadowsocks服务端,安装配置都很简单,几分钟就搞定,客户端支持PC移动端,下面是安装shadowsocks的过程,只要复制粘贴命令就行了,文件夹路径都不需要改..

ASP.NET 使用Entity Framework (EF) 创建迁移修改SQLite数据库表结构

在 ASP.NET 中,使用 Entity Framework (EF) 创建并连接 SQLite 数据库是一种轻量级、高效的数据库管理方式。以下是详细步骤:安装必要的 NuGet 包安装EntityFrameworkCore.Sqlite包:Install-Package Microsoft.Ent..

.NET9 F#有什么新特性?

F# 9 的新特性简介F# 9 是 .NET 9 的一部分,带来了多项增强功能,旨在提升开发效率和语言特性的一致性。这些改进不仅为现有的 F# 开发者提供了更强大的工具,也使新手更容易上手。以下是主要特性概览:1. 改进的类..

使用shields.io来实时显示GitHub项目star、watch和fork的数量

如何获取GitHub repo实时的star,watch和fork数量呢?这里推荐一个Shields.io工具,可以实时生成GitHub徽章,同时显示star数。显示效果如下:什么是 Shields.io?Shields.io 是一个开源项目,用于生成各种类型的徽章..

.NET 开源 ORM FreeSql 使用教程

什么是 FreeSql?FreeSql 是一个高性能、灵活且易用的 .NET 开源 ORM(对象关系映射工具),提供数据库操作的强大功能,包括实体类映射、链式查询、表达式树支持、数据库迁移等。它可以帮助开发者快速、高效地操作数..

发表回复

返回顶部

微信分享

微信分享二维码

扫描二维码分享到微信或朋友圈

链接已复制
木德育儿网-健康孕育知识分享_育儿百科知识大全观知健康-健康知识小常识_养生知识分享交流平台三省养生网-养生文化分享与交流_健康知识传播知识库乾藏国学网-国学文化传播_国学经典分享与传承易学新知网-风水知识分享平台好孕堂-助孕健康知识--查询、助孕小知识分享无双运势网 - 易学爱好者交流平台!一步达贷款社区--·中介办卡贷款技术·网贷口子·卡民论坛app好运来网-易学知识分享平台_易经入门零基础自学曲大夫助孕-助孕知识分享交流平台道情先生-风水交流平台_道可道非常道巧农网 - 农业技术知识_乡村创业致富好帮手天慧理财网 - 专注财富增长_最全面的综合理财知识分享网站亿福缘网 - 风水知识分享平台亿洋易学-专注于易学知识分享的平台健康助孕科普内容平台,分享专业助孕知识-孕知网孕好网_专注试管婴儿科普_助孕问答_助您有好孕!包天龙运势网 - 易学爱好者交流平台!九六易学网 - 为易学爱好者提供一个优秀的学习知识平台来好孕 - 愿好运伴您而行风水知识网算命久久网-今日运势分享_祝您好运常伴品千年雅韵,书一纸风华 - 诗词百科诗词名句网叮当历史 - 古文排行榜_历史人物文化经典故事大全来福网 - 传统国学典故_国学文化感悟人生斗转星移网富凯风水孕力加持网-好孕汇聚之地_孕力加持_好孕终至幸孕方舟网-专业试管助孕资讯解析速配精选网-专注于理财知识分享交流平台看测运势网-周易生辰八字测算_免费八字合婚_婚姻配对测试迪肯风水头条-风水知识交流分享平台易学迷-易学风水学入门知识分享与交流久道网 - 传统国学典故_国学文化感悟人生乐禧易学网 - 专注于易学高质量案例分享网站历史时间网 - 全球历史上的今天大事件风水388 - 风水学入门_居家风水小常识伍贰易学网-专注于易学知识分享平台星座爱-专注于星座运势知识分享巴巴百科 - 专业知识问答百科分享平台族女网-引领国学新时尚_让国学流行起来_传统易学风水文化学佛笔记句子汇-每日经典语录短句推荐叶翁网-风水易学知识分享_周易易学知识占卦塔尘网素食购--素味禅心、膳养菩提术灿网-风水国学起名十二生肖运势_易学阴阳风水秘术雀牛网-2026热门汽车品牌排行榜_新能源汽车推荐_床车房车选购攻略_您身边的汽车专家植物迷-探索植物属性_种植技术知识分享平台龙哥易学网古诗词名句_诗词名句大全_古籍文学资料库-好再来网番茄免费文学平台_免费网络小说_无弹窗广告小说阅读网_诗词古文文学知识分享-番茄文学网工作岗位职责网-本年度各行业部门工作职责大全_提供各行各业岗位职责范本久图网-唯美图片_卡通动漫图片_天堂图片_帅哥美女艺术图片_数以万计美图资料库醋椒影视网-2026年热门电影作品推荐_最火爆的电视剧导航网站常能网-带您了解那些经典的历史故事超追影视网-2026最新热门电影_热播电视剧在线追剧_高清免费短剧视频导航巴佩体育网-体育赛事新闻资讯_2026最新实时体育赛事比分捷报站星网 - 用心服务每一位站长,助力每一份梦想八万四千法门助好孕 - 助孕小贴士助你有好孕经书网 - 以音声作佛事,聆听与观想的修学园地 jingshu.net佛教音乐网 - 海量佛乐、梵呗、禅音在线试听与下载塔尊佛教网|借视频之舟,渡烦恼之海 Tazun.Cn聚合地图网好客运势网 - 经典典籍文化传承者听佛音 - 最好听的静心天籁之音老司机知识库--你的自学加速引擎,海量资源带你极速成长!唯美图片 - 高清唯美壁纸头像背景图库_PicURL图集素超人 - 国内领先的素食分享平台点优作文网 - 优秀作文大全_日记周记_读后感_历年中考高考范文顺发万年历-2026年日历,2026年老黄历查询,2026年黄道吉日素食学佛网佛教导航 - 开启智慧之旅,连接十方法缘 | fjdh.org.cn顺运堂 - 专业家居风水布局,八字命理分析,助您家宅兴旺,运势亨通地藏论坛-佛教网络净土_佛法综合社区生食主义哦嘿养殖网 - 热门乡村养殖发展项目_养殖技术知识分享大师看风水道秘相取名网-生辰八字五行取名_十二生肖取名品读名篇佳句,涵养诗意人生 - 古诗词网新华字典在线查字_在线汉语学习_汉字拼音_笔画顺序_组词造句_英语词典_诗词名句-诗文谜藏佛寺官网国学在线 - 国学网,国学学校,国学经典,国学地图弘善佛教网-传播正信正知佛法的佛教网站素食美-关爱健康_素食之美藏佛坑官网必过留学网_海外院校库_留学申请条件_留学费用_排名查询江湖以冷网 - 品读历史故事,感悟世间冷暖。生死书 - 佛教文化传承与生命智慧探索平台乐乐易学网-易学知识分享_生辰八字查询_五行八卦测算久食宿 - 旅游出行特色民宿推荐_全国名宿信息一览表趣知道 - 提问与分享,人人都是知识分享家 | Quzhidao.Com地藏孝亲网--南无大愿地藏王菩萨给农网吃好素-让生活因素而美情感语录网-婚姻情感语录_经典爱情语录_情感短信七七爱生活网十二星座_十二生肖运势_配对表_查询- 星座袋风水人家-国学文化风水知识交流平台道法网-风水运势解析_家居风水知识分享玖爱星座网-星座运势配对知识分享交流就识趣_专业中国传统文化网站_风水学藏经阁-最全的佛教经典典籍文库108工具网——您的全能在线工具箱中医文献网-中医古籍全文数据库推荐奇闻网-探索历史故事_带您了解历史上那些事儿八零生活网品酒啦-酒文化知识分享平台古籍文学网-最全的古文化知识分享平台公司起名-专注于弘扬传统文化的平台_宝藏典籍网非常易学网-生辰八字预测_生肖运势星座匹配居士之家-最全面的华人居士在线交流网站平台素超人-专注于善知识分享交流平台素超人 - 正能量善知识分享平台素超市 - 纯素生活购物平台VisaMastercardAmerican ExpressPayPalDiners ClubDiscover斗图趣 - 斗图表情包_有趣的斗图资源库富达裕-古文化经典藏品知识分享平台学佛网手机版笑一个吧 O(∩_∩)O 笑话大全_给生活加点笑料-XiaoYiGe.Cn班超文学网-优秀文学知识分享交流平台政卿事迹网-带您了解历史上的那些事儿素满香取名去 - 姓氏取名一览表_百家姓名字大全学佛网 - 佛弟子在线网络分享交流平台正能量网 - 传递正能量_真善美美文推荐搞笑gif动图网 - 内涵爆笑段子gif动态图_QQ表情包恶搞图片大全_97Gif.Com