C#之多线程
多线程在C#中使用得非常频繁,线程之间的充分利用显得尤为重要,一般的写法都是得不到充分利用资源,本人针对多线程写了一种方法,可以充分利用资源,保证每次同时启动10条线程,现在执行完马上再启动一条,总之线程维持10条。
1. 线程启动方法,使用while死循环,获取需要计算的参数和创建线程。
while (true)
{
bool isALlSuccess = IsALlSuccess(fundCodes);//判断全部数据有没有执行完
if (isALlSuccess)//所有风控全部走完后则跳出while循环
{
//Log.Log.Debug("个券指令相关性判断完成!");
break;
}
if (ThrowFlag)//多线程执行失败
{
break;
}
//--
string fundcode = GetFund(fundCodes);//获取单个基金
if (fundcode == null) continue;
//--
Thread t = GetThread();//获取线程
if (t == null) continue;
AutoResetEvent are = new AutoResetEvent(false);
InternalThreadInfo tti = new InternalThreadInfo(are, fundcode);
//t.Name = "Thread" + irisk.ToString();
t.Start(tti);//启动线程 //已执行的基金
SetInsIndex();
}
动态创建多线,保存每次都会执行10条线程。
#region * 获取线程
private List<Thread> Ts = new List<Thread>();//定义线程的集合
private Thread GetThread()
{
Thread td = null;
if (Ts.Count < )
{
td = new Thread(TheeadMod);
Ts.Add(td);
}
else
{
for (int i = ; i < Ts.Count; i++)
{
if (Ts[i] == null)
{
Ts[i] = new Thread(TheeadMod);
td = Ts[i];
break;
}
}
}
return td;
}
#endregion
用于判断多线主要计算的行、数组是否计算完毕。
#region * 判断多线程是否已经执行完毕
private int successCount = ;//运行成功的行数
/// <summary>
/// 判断多线程是否已经执行完毕
/// </summary>
/// <returns></returns>
private Boolean IsALlSuccess(List<string> fundcodes)
{
if (successCount >= fundcodes.Count)
{
return true;
}
else
{
return false;
}
}
#endregion
获取一条数据,用户传递到多线程里。
#region * 获取一条单个基金
private int InsIndex = ;
/// <summary>
/// 获取一条风控条目
/// </summary>
/// <returns></returns>
private string GetFund(List<string> fundcodes)
{
if (InsIndex < fundcodes.Count)
{
string str = fundcodes[InsIndex];
return str;
}
else
{
return null;
}
}
#endregion
主要用于计数。
#region * 自增已执行的基金
/// <summary>
/// 自增已执行的风控条目
/// </summary>
private void SetInsIndex()
{
//lock (insIndexLockObject)
//{
InsIndex++;
//}
}
#endregion #region * 自增线程已执行成功
/// <summary>
/// 自增线程已执行成功
/// </summary>
private void SetSuccessIndex()
{
//lock (successLockObject)
//{
successCount++;
//}
}
#endregion
多线程执行的主要方法,线程执行完后,都会Set掉,并将数据的对于的线程清空。
#region * 多线程执行的方法
private void TheeadMod(object fundcodes)
{
try
{
InternalThreadInfo tti = fundcodes as InternalThreadInfo;
string fundCode = tti.obj as string;
//--执行的核心代码
//--............................
SetSuccessIndex();//调用计数器 #region * 线程的控制
for (int i = ; i < Ts.Count; i++)
{
Thread t = Ts[i];
if (t != null && t.Name == Thread.CurrentThread.Name)
{
Ts[i] = null;
break;
//t.Join();
}
}
tti.are.Set();
#endregion
}
catch (Exception ex)
{
ThrowFlag = true;
Log.Error("多线程执行出错:" + ex.Message);
//ErrorMsg = ex.Message;
}
}
#endregion
类:InternalThreadInfo用于给多线程传统参数,are主要是多线程执行的状态,obj主要是传递的参数,可以是实体类、string、datarow行。
internal class InternalThreadInfo
{
public AutoResetEvent are = null;
public object obj = null;
public InternalThreadInfo(AutoResetEvent are, object obj)
{
this.are = are;
this.obj = obj;
}
}
C#之多线程的更多相关文章
- Python中的多进程与多线程(一)
一.背景 最近在Azkaban的测试工作中,需要在测试环境下模拟线上的调度场景进行稳定性测试.故而重操python旧业,通过python编写脚本来构造类似线上的调度场景.在脚本编写过程中,碰到这样一个 ...
- 多线程爬坑之路-Thread和Runable源码解析之基本方法的运用实例
前面的文章:多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类) 多线程爬坑之路-Thread和Runable源码解析 前面 ...
- 多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类)
前言:刚学习了一段机器学习,最近需要重构一个java项目,又赶过来看java.大多是线程代码,没办法,那时候总觉得多线程是个很难的部分很少用到,所以一直没下决定去啃,那些年留下的坑,总是得自己跳进去填 ...
- Java多线程
一:进程与线程 概述:几乎任何的操作系统都支持运行多个任务,通常一个任务就是一个程序,而一个程序就是一个进程.当一个进程运行时,内部可能包括多个顺序执行流,每个顺序执行流就是一个线程. 进程:进程 ...
- .NET基础拾遗(5)多线程开发基础
Index : (1)类型语法.内存管理和垃圾回收基础 (2)面向对象的实现和异常的处理基础 (3)字符串.集合与流 (4)委托.事件.反射与特性 (5)多线程开发基础 (6)ADO.NET与数据库开 ...
- Java多线程基础——对象及变量并发访问
在开发多线程程序时,如果每个多线程处理的事情都不一样,每个线程都互不相关,这样开发的过程就非常轻松.但是很多时候,多线程程序是需要同时访问同一个对象,或者变量的.这样,一个对象同时被多个线程访问,会出 ...
- C#多线程之线程池篇3
在上一篇C#多线程之线程池篇2中,我们主要学习了线程池和并行度以及如何实现取消选项的相关知识.在这一篇中,我们主要学习如何使用等待句柄和超时.使用计时器和使用BackgroundWorker组件的相关 ...
- C#多线程之线程池篇2
在上一篇C#多线程之线程池篇1中,我们主要学习了如何在线程池中调用委托以及如何在线程池中执行异步操作,在这篇中,我们将学习线程池和并行度.实现取消选项的相关知识. 三.线程池和并行度 在这一小节中,我 ...
- C#多线程之线程池篇1
在C#多线程之线程池篇中,我们将学习多线程访问共享资源的一些通用的技术,我们将学习到以下知识点: 在线程池中调用委托 在线程池中执行异步操作 线程池和并行度 实现取消选项 使用等待句柄和超时 使用计时 ...
- C#多线程之线程同步篇3
在上一篇C#多线程之线程同步篇2中,我们主要学习了AutoResetEvent构造.ManualResetEventSlim构造和CountdownEvent构造,在这一篇中,我们将学习Barrier ...
随机推荐
- NFS服务基础
NFS服务部署: (一)NFS环境准备: 操作系统 角色 IP地址 CentOS Linux release 7.3.1611 (Core) NFS服务端 192.168.152.138 CentOS ...
- Buy the souvenirs---hdu2126(01背包输出方案数)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2126 有n个物品每个物品的价格是v[i],现在有m元钱问最多买多少种物品,并求出有多少种选择方法: 如 ...
- js获取浏览器信息及版本(兼容IE)
获取浏览器信息方法有很多种,但是要是兼容ie旧版本就有点麻烦了,因为很多方法在旧版本ie是不支持的,所以ie我做了单独处理,但是目前还有小问题,就是想显示QQ浏览器,搜狗浏览器..这样的,这样还实现不 ...
- 【Django错误】OSError: raw write() returned invalid length 14 (should have been between 0 and 7)
错误环境 使用Django框架创建完models类的之后,用python manage.py migrate命令来生成数据库表的时候出错 错误代码 Operations to perform: App ...
- HttpServletRequest获取请求参数中所有的信息
/** * 获取客户端请求参数中所有的信息 * @param request * @return */ private Map<String, String> getAllRequestP ...
- [转]Earth Mover's Distance (EMD)
转自:http://www.sigvc.org/bbs/forum.php?mod=viewthread&tid=981 Earth Mover's Distance (EMD)原文: htt ...
- Submine Text 快捷键
Ctrl+Shift+P:打开命令面板 Ctrl+P:搜索项目中的文件 Ctrl+G:跳转到第几行 Ctrl+W:关闭当前打开文件 Ctrl+Shift+W:关闭所有打开文件 Ctrl+Shift+V ...
- Lua 基础总结
lua 数组下标从 1 开始, 不是 0 lua 逻辑运算符 与 或 非 就是英文 and or not local 局部变量 数据类型:lua是一门动态类型语言,变量没有类型,只有值才有 ...
- 金融即服务(FaaS),将开启场景化金融新格局
转自: https://www.iyiou.com/p/28494/fs/1 [ 亿欧导读 ] 金融即服务揭示了场景金融的实现路径,通过双向连接做一个开放的系统,按需给客户提供金融服务. 本文系作者在 ...
- linux下不同服务器间数据传输(wget,scp)
一.wget是Linux下最常用的http/ftp文件下载工具1.wget断点续传,只需要加上-c参数即可,例如:代码:wget-chttp://www.abc.com/abc.zip-Oabc.zi ...