十三、C#笔记

/// <summary>
/// 第二十三章:使用任务提高吞吐量
/// </summary>
namespace Chapter23
{
    class Program
    {
        static void Main(string[] args)
        {
            //23.1使用并行处理执行多任务处理
            /*
            * 多任务处理的原因:
            * 1.增强可响应性
            * 2.增强可伸缩性(减少执行所需要的时间)
            */

            //23.2多核处理器的崛起(要最大化地利用多核处理器,必须在写程序时就想好怎么利用多任务处理。)

            //23.3用Microsoft.NET实现多任务处理(System.Threading.Tasks)
            ///23.3.1任务、线程和线程池
            /*
             * Task类是对一个并发操作的抽象
             *      桌面应用程序用System.Threading的Threading类
             *      UWP应用中使用Task类
             * 在单处理器上无区别,
             * 在多处理器上:
             *      线程数少于可用的处理器数量会造成CPU“欠饱和”,处理能力会浪费,
             *      如果多于可用处理器数量,或造成CPU“过饱和”以及较差的响应能力
             * 重点在于:将应用程序分解成可并行运行的任务。(WinRT会安排高效运行)
             */
            ///23.3.2创建、运行和控制任务
            /*
             * Task构造器有多个重载版本,但所有版本都要求提供一个Action委托作为参数。
             */
            Action<Object> action;
            action = doWorkWithObject;
            object parameterData = 1;
            Task task = new Task(action, parameterData);
            //创建好的对象用start方法启动
            task.Start();
            //由于要经常创建和运行任务,Task提供了Run合并两个操作
            Task task1 = Task.Run(() => doWorkWithObject(parameterData));
            //一个任务后延续另一个任务
            Task newTask = task.ContinueWith(doMoreWork);
            /*
             * ContinueWith方法有许多个重载版本
             * 其中一个指定了TaskCreationOptions的值(TaskCreationOptions是枚举,它包含了枚举值的一个超集)
             * 1.NotOnCanceled和OnlyOnCanceled
             *  NotOnCanceled指定上一个行动顺利完成,没有中途取消,延续任务才应该进行。
             *  OnlyOnCanceled指定上一个行动被取消的钱地下,延续任务才应该进行。
             * 2.NotOnFaulted和OnlyOnFaulted
             *  NotOnFaulted指定上一个行动顺利完成,没有抛出未处理的异常,延续任务才应该进行。
             *  OnlyOnFaulted指定只有上一个行动抛出未处理的异常,延续任务才应该进行。
             * 3.NotOnRanToCompletion和OnlyOnRanToCompletion
             *  NotOnRanToCompletion指定上一个行动没成功完成,延续任务才应该进行。
             *  OnlyOnRanToCompletion指定只有上一个行动成功完成,延续任务才应该进行。
             */
            task.ContinueWith(doMoreWork, TaskContinuationOptions.NotOnFaulted);
            //想好后面延续之后,后面再tack.start()
            task.Wait();//等待
            Task.WaitAll(task, task1);//等待task和task1都完成
            Task.WaitAny(task, task1);//等待task或task1都完成
                                      ///23.3.3使用Task类实现并行处理(略)
                                      ///23.2.4使用Parallel类对任务进行抽象
            /*
             * 1.cpu核心数不一样,每种情况的代码也不一样
             * 2.任务同步非常重要
             * 
             * 所以Parallel对编程构造进行“并行化”,任务完成时会自动同步。
             */
            //(1)Parallel.For
            Parallel.For(0, 100, performLoopProcessing);//相当于i=0;i<100;i++
            //利用这个方法的重载版本,可以提供对于每个线程来说都是私有的局部数据,以便将状态信息传给循环的其他并发迭代。
            //(2)Parallel.ForEach<T>
            //(3)Parallel.Invoke
            /*
             * 以并行任务的形式执行一组无参的方法。
             * 要指定无参且无返回值的一组委托方法调用。
             */
            Parallel.Invoke(
                dowork,
                doMoreWork
                );
            ///23.2.5 什么时候使用Parallel类
            /*
             * 只有绝对必要时才使用,计算密集型的操作才使用
             * 前提是:并行操作必须独立!
             */

            //23.4 取消任务和处理异常
            /*
             * 粗暴地终止任务可能造成应用程序的数据处于不确定性
             * 使用task类实现的协作式取消,允许任务在方便时停止处理,并允许它在必要时撤销之前的工作
             */
            ///23.4.1协作式取消的原理
        }

        private static void dowork()
        {
            throw new NotImplementedException();
        }

        private static void doMoreWork()
        {
            throw new NotImplementedException();
        }

        private static void performLoopProcessing(int x)
        {
            throw new NotImplementedException();
        }

        private static void doMoreWork(Task obj)
        {
            throw new NotImplementedException();
        }

        /// <summary>
        /// task被创建时,将运行委托的指定的方法
        /// </summary>
        /// <param name="obj"></param>
        private static void doWorkWithObject(object obj)
            {
                throw new NotImplementedException();
            }
    }

}
 

namespace Chapter23
{
    /// <summary>
    /// 23.4.1 协作取消的原理
    /// </summary>
    class MyApplication
    {
        private void initiateTasks(){
            //创建CancellationTokenSource对象,并查询其Token属性来获得一个取消标志
            CancellationTokenSource cancellationTokenSource = new CancellationTokenSource();
            CancellationToken cancellationToken = cancellationTokenSource.Token;
            //创建一个任务,启动它来运行dowork方法
            Task myTask = Task.Run(() => doWork(cancellationToken));
            int i = 0;
            if (i == 0)//指定在什么情况下取消任务
            {
                cancellationTokenSource.Cancel();//取消任务
            }
       }

        /// <summary>
        /// 这是由任务运行的方法
        /// </summary>
        /// <param name="token"></param>
        private static void doWork(CancellationToken token)
        {
            throw new NotImplementedException();
        }
    }
}
 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/215992.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue--第八天

Vue3 1.优点&#xff1a; 2.创建&#xff1a; 3.文件&#xff1a; 换运行插件&#xff1a; 4.运行&#xff1a; setup函数&#xff1a; setup函数中获取不到this&#xff08;this 在定义的时候是Undefined) reactive()和ref(): 代码&#xff1a; <script setup> // …

数字孪生技术的应用场景

数字孪生技术具有广泛的应用场景&#xff0c;涉及多个行业和领域。以下是一些数字孪生的常见应用场景&#xff0c;希望对大家有所帮助。北京木奇移动技术有限公司&#xff0c;专业的软件外包开发公司&#xff0c;欢迎交流合作。 1.制造业优化&#xff1a; 数字孪生可用于建模和…

前后端交互—数据库与身份认证

数据库 代码下载 数据库(database)是用来组织、存储和管理数据的仓库。常见的数据库有如下几个: MySQL 数据库(目前使用最广泛、流行度最高的开源免费数据库;Community Enterprise)Oracle 数据库(收费)SQL Server 数据库(收费)Mongodb 数据库(Community Enterprise) MySQ…

易基因:MeRIP-seq等揭示m6A RNA甲基化以ABA依赖性方式调控草莓果实成熟 | 作物育种

大家好&#xff0c;这里是专注表观组学十余年&#xff0c;领跑多组学科研服务的易基因。 DNA甲基化等表观遗传标记在调控不同成熟阶段果实成熟中起着关键作用。m6A甲基化已被证明可以调控番茄成熟&#xff0c;但目前尚不清楚 mRNA m6A甲基化是否对不同类型水果的成熟调控具有功…

快速入门Tailwind CSS:从零开始构建现代化界面

快速入门Tailwind CSS&#xff1a;从零开始构建现代化界面 介绍 Tailwind CSS 是一个以原子类的方式快速构建界面的 CSS 框架。它提供了丰富的预定义类&#xff0c;使得开发者能够快速构建样式和布局。 安装和设置 首先&#xff0c;我们需要在项目中安装 Tailwind CSS。可以…

linux应用层编程问题--沙雕问题

1.调用沁恒 USB读取接口 读不到数据 static bool CH37XASyncReadData(int iIndex, uint32_t epindex, void *oBuffer, uint32_t *ioLength) {struct _bulkUp {uint32_t len;uint8_t epindex;uint8_t data[0];} __attribute__((packed));struct _bulkUp *bulkUp;int retval;bul…

​shutil --- 高阶文件操作​

源代码&#xff1a; Lib/shutil.py shutil 模块提供了一系列对文件和文件集合的高阶操作。 特别是提供了一些支持文件拷贝和删除的函数。 对于单个文件的操作&#xff0c;请参阅 os 模块。 警告 即便是高阶文件拷贝函数 (shutil.copy(), shutil.copy2()) 也无法拷贝所有的文件…

gitlab动态流水线

文章目录 1. 说明2. 官方样例2.1 在作业中生成配置文件&#xff0c;保存为产物2.2 将触发器作业配置为在生成配置文件的作业之后运行。 3. 实战应用3.1 背景介绍3.2 项目介绍3.3 公共项目配置3.4 测试项目配置3.5 测试 4. 总结 1. 说明 顾名思义&#xff0c;动态流水线就是一种…

Shell函数数组练习

1、编写函数&#xff0c;实现打印绿色OK和红色FAILED&#xff0c;判断是否有参数&#xff0c;存在为Ok&#xff0c;不存在为FAILED [rootshell ~]# vim ok.sh #!/bin/bash read -p "请输入一个参数:" i function ok…

mac 安装nvm以及切换node版本详细步骤

1、nvm介绍&#xff08;node版本管理工具&#xff09; nvm 可以让你通过命令行快速安装和使用不同版本的node 有时候项目太老&#xff0c;node版本太高,执行npm install命令会报错,可以借助nvm切换低版本的node。 2、安装nvm 在终端执行安装命令 curl -o- https://raw.gith…

后端只打印了info等级的日志?-SpringBoot日志打印-Slf4j

在调用log变量的方法来输出日志时&#xff0c;有以上5个级别对应的方法&#xff0c;从不太重要&#xff0c;到非常重要 调用不同的方法&#xff0c;就会输出不同级别的日志。 trace&#xff1a;跟踪信息debug&#xff1a;调试信息info&#xff1a;一般信息warn&#xff1a;警告…

1、混合方式UI设计

1、混合方式UI设计 新建项目添加静态资源添加资源添加action添加菜单菜单栏工具栏中间编辑区域 代码添加其他组件字体和大小状态栏 添加槽函数UI设置的转到槽的手写的设置应用程序图标 代码 新建项目 MainWindow代码文件夹主窗口为 (QMainWindow) 添加静态资源 AppIcon.icoi…

scikit-learn-feature_selection

参考&#xff1a; Feature selection 1. 移除低方差的特征 方差低&#xff0c;说明变化不大。 将特征方差值小于一定值的特征移除 单变量特征分析 通过单特征分析&#xff0c;选择最好的&#xff08;前k个&#xff09;的特征&#xff0c;scikit-learn 提供的方法有&#x…

LeetCode-1475. 商品折扣后的最终价格【栈 数组 单调栈】

LeetCode-1475. 商品折扣后的最终价格【栈 数组 单调栈】 题目描述&#xff1a;解题思路一&#xff1a;暴力解法。两层for。解题思路二&#xff1a;单调栈&#xff0c;具体思路是反向遍历数组prices。遇到栈顶元素小于当前元素的就出栈&#xff0c;目的是为了找到当前位置右边的…

基于JAVA+SpringBoot+Vue的前后端分离的旅游网站

✌全网粉丝20W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取项目下载方式&#x1f345; 一、项目背景介绍&#xff1a; 近年来&#xff0c;随…

区块链的可拓展性研究【01】layer1

什么是一层网络&#xff1f; 一层网络是底层区块链。以太坊和比特币都是一层网络区块链&#xff0c;因为它们是基石&#xff0c;各种二层网络都构建于其上。二层网络项目的示例包括以太坊上的“卷叠”和基于比特币的闪电网络。所有这些二层网络项目上的用户交易活动最终都可以回…

IntelliJ IDEA 自带的 HTTP Client接口调用插件,替代 Postman

文章目录 引言建议目录结构新建请求不同环境的变量配置添加环境http-client.env.jsonhttp-client.private.env.json引用变量 请求示例Get请求示例Post请求示例鉴权示例断言示例Websocket请求示例 内置对象和动态变量内置对象&#xff1a;内置变量&#xff1a; 引言 在日常的 W…

关于引用unpkg.com的mars3d相关依赖文件报错无法请求的说明

问题来源&#xff1a; 1.关于引用unpkg.com的mars3d相关依赖文件报错无法请求的说明 说明&#xff1a; 1.最近npm、unpkeg都访问异常&#xff0c;可能是unpkg.com等国外的服务器不稳定导致的请求未响应。 解决方案&#xff1a; 1.请切换静态文件引入的方式请求相关资源。参…

LaTex:如何在数学环境下打出大的右括号“}“

一般来说多行公式打左大括号都知道使用语法"cases" \begin{cases} foo\\ foo\\ \end{cases}最近需要键入右边大花括号括起来公式的时候犯难了&#xff0c;搜了很多用的都是"\left.array\right}"&#xff0c;看得我昏迷&#xff0c;屡屡报错。 突然想起很久…

selenium自动化(中)

显式等待与隐式等待 简介 在实际工作中等待机制可以保证代码的稳定性&#xff0c;保证代码不会受网速、电脑性能等条件的约束。 等待就是当运行代码时&#xff0c;如果页面的渲染速度跟不上代码的运行速度&#xff0c;就需要人为的去限制代码执行的速度。 在做 Web 自动化时…