using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using System.Windows.Forms; namespace WindowsFormsApplication1
{
public partial class Form5 : Form
{
public Form5()
{
InitializeComponent();
}
string aa = "aaaa";
bool bl = false;
private object syncstate = new object();
TaskScheduler scheduler = null;
System.Timers.Timer tmPulse = new System.Timers.Timer();//位置刷新
System.Timers.Timer tmPulse1 = new System.Timers.Timer();//位置刷新
Thread t;
Thread t1;
Thread t2;
private void Form5_Load(object sender, EventArgs e)
{
scheduler = TaskScheduler.FromCurrentSynchronizationContext();
t = new Thread(new ThreadStart(SetData));
t.IsBackground = true;
t.Start(); t1 = new Thread(new ThreadStart(Set1));
t1.IsBackground = true;
t1.Start(); t2 = new Thread(new ThreadStart(Set2));
t2.IsBackground = true;
t2.Start();
} void Set()
{
tmPulse.Interval = ;
tmPulse.AutoReset = true;//设置是执行一次(false)还是一直执行(true); 位置刷新
tmPulse.Start();
tmPulse.Elapsed += (o, a) =>
{
SetData();
};
tmPulse.Enabled = true; tmPulse1.Interval = ;
tmPulse1.AutoReset = true;//设置是执行一次(false)还是一直执行(true); 位置刷新
tmPulse1.Start();
tmPulse1.Elapsed += (o, a) =>
{
Set1();
};
tmPulse1.Enabled = true; }
void SetData()
{
while (true)
{ for (int i = ; i < ; i++)
{
if (i == )
{
ShowMessage("执行结果,是否成功?", "结果确认", MessageBoxButtons.YesNo, MessageBoxIcon.Question);
}
Task.Factory.StartNew(() =>
{
lock (syncstate)
{
textBox1.Text += ("测试:" + aa + " " + i + "\r\n");
textBox1.SelectionStart = textBox1.Text.Length;
this.textBox1.ScrollToCaret();
}
}, CancellationToken.None, TaskCreationOptions.None, scheduler);
Thread.Sleep();
aa = "第一个测试";
if (i == )
{ }
}
return;
}
}
void Set1()
{
while (true)
{ for (int i = ; i < ; i++)
{
Task.Factory.StartNew(() =>
{
lock (syncstate)
{
textBox1.Text += ("设置1:" + aa + " " + i + "\r\n");
textBox1.SelectionStart = textBox1.Text.Length;
this.textBox1.ScrollToCaret();
}
}, CancellationToken.None, TaskCreationOptions.None, scheduler);
aa = "第1个设置" + i;
Thread.Sleep();
}
Task.Factory.StartNew(() =>
{
lock (syncstate)
{
textBox1.Text += ("设置1:完成\r\n");
textBox1.SelectionStart = textBox1.Text.Length;
this.textBox1.ScrollToCaret();
}
}, CancellationToken.None, TaskCreationOptions.None, scheduler);
return;
}
}
void Set2()
{
while (!bl)
{
for (int i = ; i < ; i++)
{
Task.Factory.StartNew(() =>
{
lock (syncstate)
{
textBox1.Text += ("设置2:" + aa + " " + i + "\r\n");
textBox1.SelectionStart = textBox1.Text.Length;
this.textBox1.ScrollToCaret();
}
}, CancellationToken.None, TaskCreationOptions.None, scheduler);
aa = "第2个设置" + i;
Thread.Sleep();
}
}
}
private void button1_Click(object sender, EventArgs e)
{
bl = true;
} public DialogResult ShowMessage(string text, string caption, MessageBoxButtons buttons, MessageBoxIcon icon)
{
var dr = new DialogResult();
try
{
var tmp = this.Invoke(new MessageBoxShow(MessageBoxShowF), new object[] { text, caption, buttons, icon });
if (tmp != null)
{
dr = (DialogResult)tmp;
}
}
catch
{ }
return dr;
}
delegate DialogResult MessageBoxShow(string text, string caption, MessageBoxButtons buttons, MessageBoxIcon icon);
DialogResult MessageBoxShowF(string text, string caption, MessageBoxButtons buttons, MessageBoxIcon icon)
{ var dr = MessageBox.Show(text, caption, buttons, icon);
return dr;
} private void Form5_FormClosed(object sender, FormClosedEventArgs e)
{
t.Abort();
t.Join(); t1.Abort();
t1.Join();
t2.Abort();
t2.Join();
}
}
}

c#多线程操作测试(阻塞线程,结束任务)的更多相关文章

  1. C# 多线程join的用法,等待多个子线程结束后再执行主线程

    等待多个子线程结束后再执行主线程 class MultiThread{ #region join test public void MultiThreadTest() { Thread[] ths = ...

  2. Java多线程之以7种方式让主线程等待子线程结束

    记一次主线程等待子线程结束的多种方法的学习 在学习多线程时,最开始遇到的问题其实是"计算子线程运行时间",写到最后发现本文和标题更为符合,但是仍然基于问题:"在主线程中获 ...

  3. .NET面试题解析(07)-多线程编程与线程同步

      系列文章目录地址: .NET面试题解析(00)-开篇来谈谈面试 & 系列文章索引 关于线程的知识点其实是很多的,比如多线程编程.线程上下文.异步编程.线程同步构造.GUI的跨线程访问等等, ...

  4. .NET面试题解析(07)-多线程编程与线程同步 (转)

    http://www.cnblogs.com/anding/p/5301754.html 系列文章目录地址: .NET面试题解析(00)-开篇来谈谈面试 & 系列文章索引 关于线程的知识点其实 ...

  5. VC中利用多线程技术实现线程之间的通信

    当前流行的Windows操作系统能同时运行几个程序(独立运行的程序又称之为进程),对于同一个程序,它又可以分成若干个独立的执行流,我们称之为线程,线程提供了多任务处理的能力.用进程和线程的观点来研究软 ...

  6. Qt线程QThread简析(8个线程等级,在UI线程里可调用thread->wait()等待线程结束,exit()可直接退出线程,setStackSize设置线程堆栈,首次见到Qt::HANDLE,QThreadData和QThreadPrivate)

    QThread实例代表一个线程,我们可以重新实现QThread::run(),要新建一个线程,我们应该先继承QThread并重新实现run()函数. 需要注意的是: 1.必须在创建QThread对象之 ...

  7. Java多线程学习(二)---线程创建方式

    线程创建方式 摘要: 1. 通过继承Thread类来创建并启动多线程的方式 2. 通过实现Runnable接口来创建并启动线程的方式 3. 通过实现Callable接口来创建并启动线程的方式 4. 总 ...

  8. 一般来说,主方法main()结束的时候线程结束

    suspend()是将一个运行时状态进入阻塞状态(注意不释放锁标记).恢复状态的时候用resume().Stop()指释放全部. 这几个方法上都有Deprecated标志,说明这个方法不推荐使用. 一 ...

  9. java多线程三之线程协作与通信实例

    多线程的难点主要就是多线程通信协作这一块了,前面笔记二中提到了常见的同步方法,这里主要是进行实例学习了,今天总结了一下3个实例: 1.银行存款与提款多线程实现,使用Lock锁和条件Condition. ...

  10. Delphi 实现多线程编程的线程类 TThread

    http://blog.csdn.net/henreash/article/details/3183119 Delphi中有一个线程类TThread是用来实现多线程编程的,这个绝大多数Delphi书藉 ...

随机推荐

  1. Linux学习总结(11)——Linux文件查找

    Linux下的常用查找命令 locate whereis which find locate  -i, 忽略大小写  find  根据文件名或正则表达式搜索  -name    条件限制  -a 与条 ...

  2. HDU 4366 Successor

    Successor Time Limit: 1000ms Memory Limit: 65536KB This problem will be judged on HDU. Original ID:  ...

  3. Opencv(3.0.0beta)+Python(2.7.8 64bit) 简单具体,一遍成功

    看到非常多配置的文章,都没法正常走完流程 使用到的资源,都是今天为止最新的: python-2.7.8.amd64.msi opencv-3.0.0-beta.exe numpy-MKL-1.9.1. ...

  4. MySQ学习笔记之十 NULL值处理

    这是MySQL一大特殊之处. 概念上.NULL意味着"没有值"或"未知值",且它被看作有点与众不同的值. 为了測试NULL.你不能使用算术比較运算符比如=.&l ...

  5. [HNOI2008] GT考试(DP+矩阵快速幂+KMP)

    题目链接:https://www.luogu.org/problemnew/show/P3193#sub 题目描述 阿申准备报名参加 GT 考试,准考证号为 N 位数 X1,X2…Xn(0 <= ...

  6. 131.typename在嵌套类中的作用

    #include <iostream> using namespace std; class myit { public: static int num; class itit { }; ...

  7. Spring MVC模式示例(未采用解耦控制器)

    Product package com.mstf.bean; import java.io.Serializable; /** * Product类,封装了一些信息,包含三个属性 * @author ...

  8. PostgreSQL 系统表

    postgres=# \d pg_class      Table "pg_catalog.pg_class"     Column     |   Type    | Modif ...

  9. codeforces 544 D Destroying Roads 【最短路】

    题意:给出n个点,m条边权为1的无向边,破坏最多的道路,使得从s1到t1,s2到t2的距离不超过d1,d2 因为最后s1,t1是连通的,且要破坏掉最多的道路,那么就是求s1到t1之间的最短路 用bfs ...

  10. caffe命令及其参数解析

    caffe的c++主程序(caffe.cpp)放在根目录下的tools文件夹内, 当然还有一些其它的功能文件,如:convert_imageset.cpp, train_net.cpp, test_n ...