本例通过Timer的tick()方法触发TimerCallback委托来开辟新的线程,线程中的具体工作通过一个静态方法作为参数给TimerCallback委托。

using System;
using System.Threading; /* 这是一个关于 timer开启多线程的一个例子
* 1.Timer 的tick事件触发系统内置委托TimerCallback委托。而此委托会触发一个新的线程 。此线程中需要完成的具体的工作写成一个静态方法。作为参数传递给这个委托。
* 2.如果是用Timer触发的线程会自动开始不需要用到.Start()来启动
* 3.如果没有使用线程池threadpool 那么有多少个线程系统都会全部执行 这样的话如果线程太多那就使系统不停地在线程间切换会消耗大量时间。所以说线程太多时一定要
* 用一个线程池来管理 这样就可以提高效率
* 4.虽然timer是在主线程中创建并开始运行的, 但是主线程暂停却并不影响timer的tick事件的按时触发,比如本例中主线程设置睡眠5秒,但是并没有影响timer.tick事件触发
* 5.所有timer创建的线程都是后台线程 即 线程的.isbackground=true;
* 6.用户不创建线程池 系统是不会自己创建的。
* 7.Timer.Change(Timeout.Infinite,Timeout.Infinite) 则是取消Timer的重复性劳动等待下次启用。
* 参数1:Timer每一次触发执行回调前需等待时间,0立即触发,Timeout.Infinite永不触发回调;
* 参数2:表示每次触发timer的间隔时间,0表示只执行一次即第一次。
*/ namespace TimerCreateThread
{
class Program
{
static void Main(string[] args)
{
Console.WriteLine("主线程开始执行********************* 线程ID" + Thread.CurrentThread.ManagedThreadId);
TimerCallback delegate_tcb = new TimerCallback(ToDoSamething);//实例化一个可以创建新线程的内置委托--TimerCallback 。具体做的事写成一个静态方法作为参数传入委托。
Timer timer = new Timer(delegate_tcb, null, ,); //把这个委托作为参数传递进去,timer开启后tick延迟3秒, 之后每2秒执行一次tick()事件,而此事件就会触发TimerCallback委托。一下就要新建一个线程 int j = ;
while (j <)
{
Console.WriteLine("主线程正在执行********************* 线程ID" + Thread.CurrentThread.ManagedThreadId);
Thread.Sleep(); //主线程休眠不会影响tick执行 因为我设置的tick时间为2秒 ,而主线程要睡4秒 //证明 虽然timer是在主线程中进行的 但是 主线程暂停却并不影响timer的tick事件的按时触发
j++;
}
timer.Change(Timeout.Infinite, Timeout.Infinite);//完成上面的while循环后执行此句时钟停止。Timer就不再通过tick激发委托创建新线程 时间为4000*3=12秒。此时就不会触发新的线程 但已经触发的线程不会结束 。不管是否正在执行还是正在等待
//timer.Dispose();//不建议使用销毁。因为一旦销毁就不能再重启时间触发器
Console.WriteLine("线程池已满,不再开辟新的线程");
Console.ReadKey();
} //具体工作内容写入这个静态方法
static void ToDoSamething(object i)
{
Thread.CurrentThread.IsBackground = false;
Console.WriteLine("此线程正在执行,线程ID" + Thread.CurrentThread.ManagedThreadId);
Thread.Sleep();//模拟线程执行 需要10秒时间 。Timeout.Infinite无限长
Console.WriteLine("执行完成,线程ID" + Thread.CurrentThread.ManagedThreadId); }
}
}

C# 多线程之通过Timer开启线程的例子的更多相关文章

  1. Day10 多线程理论 开启线程

    多线程: 多线程和多进程的不同是他们占用的资源不一样, 一个进程里边可以包含一个或多个进程, 进程的开销大,线程的开销小. 打个比方来说:创建一个进程,就是创建一个车间.创建一个线程,就是在一个车间创 ...

  2. [并发编程 - 多线程:信号量、死锁与递归锁、时间Event、定时器Timer、线程队列、GIL锁]

    [并发编程 - 多线程:信号量.死锁与递归锁.时间Event.定时器Timer.线程队列.GIL锁] 信号量 信号量Semaphore:管理一个内置的计数器 每当调用acquire()时内置计数器-1 ...

  3. python 并发编程 多线程 开启线程的两种方式

    一 threading模块介绍 multiprocess模块的完全模仿了threading模块的接口,二者在使用层面,有很大的相似性 二 开启线程的两种方式 第一种 每造一个进程,默认有一个线程,就是 ...

  4. JAVA基础再回首(二十五)——Lock锁的使用、死锁问题、多线程生产者和消费者、线程池、匿名内部类使用多线程、定时器、面试题

    JAVA基础再回首(二十五)--Lock锁的使用.死锁问题.多线程生产者和消费者.线程池.匿名内部类使用多线程.定时器.面试题 版权声明:转载必须注明本文转自程序猿杜鹏程的博客:http://blog ...

  5. Java多线程开发系列之三:线程这一辈子(线程的生命周期)

    前文中已经提到了,关于多线程的基础知识和多线程的创建.但是如果想要很好的管理多线程,一定要对线程的生命周期有一个整体概念.本节即对线程的一生进行介绍,让大家对线程的各个时段的状态有一定了解. 线程的一 ...

  6. Java 基础 多线程进阶(锁,线程安全)

    一,前言 前面我们已经对线程和线程池有一定的了解,但是只要说到多线程,肯定需要考虑线程安全等问题.接下来我们就来好好聊聊这些问题. 二,线程安全 如果有多个线程在同时运行,而这些线程可能会同时运行这段 ...

  7. Java多线程01(Thread类、线程创建、线程池)

    Java多线程(Thread类.线程创建.线程池) 第一章 多线程 1.1 多线程介绍 1.1.1 基本概念 进程:进程指正在运行的程序.确切的来说,当一个程序进入内存运行,即变成一个进程,进程是处于 ...

  8. C# 多线程九之Timer类

    1.简介 相信写过定时任务的小伙伴都知道这个类,非常的轻量级,而且FCL中大量的类使用了这个方法,比如CancellationTokenSource的CancelAfter就是用Timer去做的. 当 ...

  9. Java多线程学习(八)线程池与Executor 框架

    目录 历史优质文章推荐: 目录: 一 使用线程池的好处 二 Executor 框架 2.1 简介 2.2 Executor 框架结构(主要由三大部分组成) 2.3 Executor 框架的使用示意图 ...

随机推荐

  1. Qt常用UI控件读取、写入方法

    本文用途:快速备忘,方便调用,写熟了自然就记下了. [1.标签label] 读取:ui->label->text() 写入:ui->label->setText("p ...

  2. IIS 32位/64位 全局模式切换

    IIS7以上可以对单个应用程序池进行设置. IIS6需要用命令. 一.32位模式1.cscript %systemdrive%\inetpub\adminscripts\adsutil.vbs set ...

  3. 爬虫之协程,selenium

    1.什么是代理?代理和爬虫之间的关联是什么? 2.在requests的get和post方法常用的参数有哪些?分别有什么作用?(四个参数) - url headers parmas/data proxi ...

  4. php--->使用callable强制指定回调类型

    php 使用callable强制指定回调类型 如果一个方法需要接受一个回调方法作为参数,我们可以这样写 <?php function dosth($callback){ call_user_fu ...

  5. laravel 服务容器的由来 代码展示

    <?php /** * 目的:代码的完善来说明从 基础类的调用到 工厂类的使用 再到容器的出现的原因 * (首先要明白工厂类和容器的关系 可以理解:容器就是工厂类的升级版(为了解决类的依赖)) ...

  6. Tomcat项目启动常见错误以及原因,持续更新.........

    一 Context initialization failed 错误截图: 原因: jdk版本与项目不对应,可重新设置项目jdk和ide编译的jdk即可

  7. springcloud ActiveMQ设置多个并行消费者

    还是结合实际项目说把,最近在做跟保险公司和第三方借贷平台对接的项目: 其中需要第三方借贷平台借款并和保险挂对勾,也就是每次借钱的时候可以做一次保: 这里面正常情况下的逻辑场景: 借贷平台:借贷审核通过 ...

  8. 初识Redis,看这一篇就够了

    环境的搭建和安装网上有很多教程,在这里就不再重复了. 1. Redis是什么? Redis(全称:Remote Dictionary Server 远程字典服务)是一个开源的使用ANSI C语言编写. ...

  9. 使用alpine制作最小化的JDK基础镜像

    注意:这里使用的是oracle的JRE,版本是1.8. 1.解压jre包,删除根目录下文本文件,然后删除其他不必要文件. #解压 tar xvcf jre-8u161-linux-x64.tar.gz ...

  10. 练习2-14 求奇数分之一序列前N项和 (15 分)

    练习2-14 求奇数分之一序列前N项和 (15 分) 本题要求编写程序,计算序列 1 + 1/3 + 1/5 + ... 的前N项之和. 输入格式: 输入在一行中给出一个正整数N. 输出格式: 在一行 ...