关于Thread ThreadPool Parallel 的一些小测试demo
using System;
using System.Diagnostics;
using System.Runtime.InteropServices;
using System.Threading;
using System.Threading.Tasks; namespace TestProject
{
class Program
{
//异步:不阻塞主线程的一种编程方法
//多线程(new Thread): 多个线程去做一个事情 (注意共享变量的问题)(无法监测是否完成)
//线程池(new ThreadPool):省去线程重复创建回收的消耗。(无法检测执行任务是否完成)
//Task: Task在线程池的基础上进行了优化,并且可以检测到完成状态。
//Parallel:并行多个任务。(而且能监测完成状态)
//乐观锁悲观锁
static void Main(string[] args)
{
//int a = 0;
Stopwatch stopwatch = new Stopwatch(); #region 单线程
stopwatch.Start(); // 开始监视代码运行时间
for (int i = ; i < ; i++)
{
Console.WriteLine("thread:{0}", Thread.CurrentThread.ManagedThreadId);
Thread.Sleep();
}
// you code ....
stopwatch.Stop(); // 停止监视
ConsoleTime(stopwatch, "单线程");
#endregion #region ThreadPool(没办法检测是否完成哦!)这里监测到的时间是创建线程池所需要的时间
stopwatch.Start(); // 开始监视代码运行时间 ThreadPool.SetMaxThreads(, );
ThreadPool.SetMinThreads(, );
for (int i = ; i < ; i++)
{
ThreadPool.QueueUserWorkItem(new WaitCallback((obj) =>
{
Console.WriteLine("线程池输出: thread:{0}", Thread.CurrentThread.ManagedThreadId);
Thread.Sleep();
}), i.ToString());
}
// you code ....
stopwatch.Stop(); // 停止监视
ConsoleTime(stopwatch, "ThreadPool");
#endregion #region Thread(没办法检测完成!没有返回值没有办法检测状态。)这里监测到的时间仅仅只是创建这些线程所需要的时间。
stopwatch.Start(); // 开始监视代码运行时间
for (int i = ; i < ; i++)
{
Thread thread = new Thread(new ThreadStart(DoSomeThing));
thread.Start();
//Thread.Sleep(100);
}
// you code ....
stopwatch.Stop(); // 停止监视
ConsoleTime(stopwatch, "Thread");
#endregion #region Parallel
stopwatch.Start(); // 开始监视代码运行时间
var task = System.Threading.Tasks.Parallel.For(, , new ParallelOptions() { MaxDegreeOfParallelism = }, (i) =>
{
Console.WriteLine("{0},task:{1},thread:{2}", i, Task.CurrentId, Thread.CurrentThread.ManagedThreadId);
Task.Delay();
//提供的原子性操作,保证对a的值操作每一次都是原子性的
//System.Threading.Interlocked.Add(ref a, 1);
//a++;
});
stopwatch.Stop(); // 停止监视
ConsoleTime(stopwatch, "Parallel");
#endregion //Console.Write(a);
Console.ReadKey();
}
/// <summary>
/// 模拟做点什么同时输出当前线程id
/// </summary>
private static void DoSomeThing()
{
Console.WriteLine("DoSomeThing: thread:{0}", Thread.CurrentThread.ManagedThreadId);
Thread.Sleep();
}
/// <summary>
/// 模拟异步执行方法
/// </summary>
/// <returns></returns>
private static async Task DoSomeThing2()
{
await Task.Run(() =>
{
Console.WriteLine("DoSomeThing2: task:{0},thread:{1}", Task.CurrentId, Thread.CurrentThread.ManagedThreadId);
Thread.Sleep();
}
);
}
//输出当前代码段运行时间
private static void ConsoleTime(Stopwatch stopwatch, string BlockName)
{
TimeSpan timespan = stopwatch.Elapsed; //获取当前实例测量得出的总时间
Console.WriteLine("{0} ,代码执行时间:{1}(毫秒)", BlockName, timespan.TotalMilliseconds); //总毫秒数
stopwatch.Reset();
} }
}
关于Thread ThreadPool Parallel 的一些小测试demo的更多相关文章
- Thread&ThreadPool、Parallel、Async和Await用法总结
1.线程和线程池Thread&ThreadPool //线程初始化时执行方法可以带一个object参数,为了传入自定义参数,所以执行需单独调用用于传参. Console.WriteLine(& ...
- c#中@标志的作用 C#通过序列化实现深表复制 细说并发编程-TPL 大数据量下DataTable To List效率对比 【转载】C#工具类:实现文件操作File的工具类 异步多线程 Async .net 多线程 Thread ThreadPool Task .Net 反射学习
c#中@标志的作用 参考微软官方文档-特殊字符@,地址 https://docs.microsoft.com/zh-cn/dotnet/csharp/language-reference/toke ...
- 从Thread,ThreadPool,Task, 到async await 的基本使用方法解读
记得很久以前的一个面试场景: 面试官:说说你对JavaScript闭包的理解吧? 我:嗯,平时都是前端工程师在写JS,我们一般只管写后端代码. 面试官:你是后端程序员啊,好吧,那问问你多线程编程的问题 ...
- Thread,ThreadPool,Task, 到async await 的基本使用方法和理解
很久以前的一个面试场景: 面试官:说说你对JavaScript闭包的理解吧? 我:嗯,平时都是前端工程师在写JS,我们一般只管写后端代码. 面试官:你是后端程序员啊,好吧,那问问你多线程编程的问题吧. ...
- Cad 二次开发关于SelectCrossingPolygon和SelectFence返回结果Status为error的小测试
CAD2008的二次开发,有个很奇怪的现象,只要你选择的点集不在当前视图上SelectCrossingPolygon和SelectFence返回结果Status就会为error,所以要获取正确的结果, ...
- 异步多线程 Thread ThreadPool Task
一.线程 Thread ThreadPool 线程是Windows任务调度的最小单位,线程是程序中的一个执行流,每个线程都有自己的专有寄存器(栈指针.程序计数器等),但代码区是共享的,即不同的线程可以 ...
- python 程序小测试
python 程序小测试 对之前写的程序做简单的小测试 ... # -*- encoding:utf-8 -*- ''' 对所写程序做简单的测试 @author: bpf ''' def GameOv ...
- PHP中使用PDO操作事务的一些小测试
关于事务的问题,我们就不多解释了,以后在学习 MySQL 的相关内容时再深入的了解.今天我们主要是对 PDO 中操作事务的一些小测试,或许能发现一些比较好玩的内容. 在 MyISAM 上使用事务会怎么 ...
- android gps开发必备资料(含测试demo下载)
入门资料参考: How accurate is Android GPS? Part 1: Understanding Location Data How accurate is Android GPS ...
随机推荐
- Python之hashlib模块的使用
hashlib模块主要的作用: 加密保护消息安全,常用的加密算法如MD5,SHA1等. 1.查看可用的算法有哪些 #!/usr/bin/env python # -*- coding: utf-8 - ...
- git diff 以及解决代码冲突
我是使用一台电脑测试, 然后在本地电脑创建了两个工作目录.专门用来模拟两个人提交代码.假设a.b两个人.只使用一个master分支做测试, 没有建立其他的分支. 主要就是为了研究冲突的解决方式.感觉g ...
- CCPC-Wannafly & Comet OJ 夏季欢乐赛(2019)D
题面 一开始想到一个 O(N^2) 做法,先把x排序,然后顺次枚举x最大的点,看向前最多可以保留多少点 (也就是先不管正方形的上下长度限制,先考虑左右的限制).然后再对这些点做一遍类似的..(等等这么 ...
- noi.ac #553 序列
[题目描述] 老虎和蒜头是好朋友. 众所周知,蒜头经常给老虎出一些题目,而老虎也常常被难倒,作为捧杯之王的老虎难免心有怨怼.今天,老虎发现了蒜头的一个序列 a .虽然老虎不知道这个序列是用来做什么的 ...
- JVM系列大纲
本系列主要分析JVM主要功能要点,初步大纲如下,会根据写作情况进行细化,目的在于梳理JVM的知识体系,具体分析文章会陆续发布. [JVM]类加载机制(1) [JVM]Java内存区域(2) [JVM] ...
- selenium.common.exceptions.StaleElementReferenceException: Message: stale element reference: element is not attached to the page document
抓取网页代码后,由于是在同一个li标签下,所以使用一次性抓取,所有的a标签,然后循环做不同的操作,但是抛出找不到元素异常. def office_page(_chrome: Chrome): sn = ...
- 20175215 2018-2019-2 第十周java课程学习总结
第十二章 Java多线程机制 12.1 进程与线程 12.1.1 操作系统与进程 程序是一段静态的代码,它是应用软件执行的蓝本. 进程是程序的一次动态执行过程,它对应了从代码加载.执行至执行完毕的一个 ...
- 【编程漫谈】PHP
PHP是个很古老的脚本技术了,当年CGI比较让人诟病,于是PHP横空出世.PHP即写即用特性,吸引了一大批粉丝,而且类似C语言的编程风格,让那些C程序员非常容易地转到这个平台上来.当然PHP刚出来的时 ...
- 2.HDFS和HA
1.HDFS简介 DataNode NameNode SecondaryNameNode HDFS文件权限 2.HDFS小结 3.HDFS交互操作 4.HDFS编程访问接口
- Fragment全解析系列
(一):那些年踩过的坑 开始之前 最新版知乎,单Activity多Fragment的架构,响应可以说非常“丝滑”,非要说缺点的话,就是没有转场动画,并且转场会有类似闪屏现象.我猜测可能和Fragmen ...