http://www.sufeinet.com/plugin.php?id=keke_group

苏飞论坛

 找回密码
 马上注册

QQ登录

只需一步,快速开始

分布式系统框架(V2.0) 轻松承载百亿数据,千万流量!讨论专区 - 源码下载 - 官方教程

HttpHelper爬虫框架(V2.7-含.netcore) HttpHelper官方出品,爬虫框架讨论区 - 源码下载 - 在线测试和代码生成

HttpHelper爬虫类(V2.0) 开源的爬虫类,支持多种模式和属性 源码 - 代码生成器 - 讨论区 - 教程- 例子

查看: 3843|回复: 5

[其他] 这个带参数的多线程怎么处理?

[复制链接]
发表于 2015-12-1 22:36:33 | 显示全部楼层 |阅读模式
两个arraylist:arraylistA,arraylistB。A大约2万多,B大约20万。
需要:遍历A中每个元素,每个元素又在B中遍历寻找符合要求的元素。单线程太慢,需要多线程来做。


我目前是这么做的:
[C#] 纯文本查看 复制代码
public void KeywordProcessor(int i)
{
	for(int i = 0; i < arraylistB.Count; i++)
	{
	   //找到符合arraylistA[i]对应条件的元素
	}
}

//这里是固定100个线程,怎么循环开启多线程处理那2万多条数据呢?
for (int i = 0; i < 100; i++)
{
    //这里怎样传参数i?
	Thread thread = new Thread(new ParameterizedThreadStart(KeywordProcessor));
    thread.Start();
}





1. 开通SVIP会员,免费下载本站所有源码,不限次数据,不限时间
2. 加官方QQ群,加官方微信群获取更多资源和帮助
3. 找站长苏飞做网站、商城、CRM、小程序、App、爬虫相关、项目外包等点这里
发表于 2015-12-2 08:49:11 | 显示全部楼层
你想要怎样的循环开启多线程呢,可以这样,100个线程每个线程去取一定范围的B中的元素,分成100份,每份取2000条,线程1取1-2000,线程2取2001-4000,。。。
 楼主| 发表于 2015-12-2 09:32:20 | 显示全部楼层
songwenqi 发表于 2015-12-2 08:49
你想要怎样的循环开启多线程呢,可以这样,100个线程每个线程去取一定范围的B中的元素,分成100份,每份取2 ...

我是想:一次开100个线程,每个线程取A中的一个,根据这个值遍历所有的B。这样2万个,大概要20000/100次。
但是怎么传递参数啊? 比如线程1,取A[1]的值,线程100,取取A[100]的值
发表于 2015-12-2 12:59:07 | 显示全部楼层
bluescharp 发表于 2015-12-2 09:32
我是想:一次开100个线程,每个线程取A中的一个,根据这个值遍历所有的B。这样2万个,大概要20000/100次 ...

你定义的每个线程,在这个线程里面是可以取到这个线程数的
[C#] 纯文本查看 复制代码
for (int i = 1; i <= sum; i++)
            {
                Thread t = new Thread(new ThreadStart(delegate
                {
                    Do(i);
                }));
                t.Start();
            }
private void Do(int i)
        {
//i就是这个线程数
}

 楼主| 发表于 2015-12-3 11:33:07 | 显示全部楼层
songwenqi 发表于 2015-12-2 12:59
你定义的每个线程,在这个线程里面是可以取到这个线程数的
[mw_shl_code=csharp,true]for (int i = 1; i ...

用线程池怎么做啊? 2万个循环的话。。。
发表于 2015-12-3 13:53:13 | 显示全部楼层
bluescharp 发表于 2015-12-3 11:33
用线程池怎么做啊? 2万个循环的话。。。

线程就可以了吧,2万条数据循环开启100个线程应该就行了吧
您需要登录后才可以回帖 登录 | 马上注册

本版积分规则

QQ|手机版|小黑屋|手机版|联系我们|关于我们|广告合作|苏飞论坛 ( 豫ICP备18043678号-2)

GMT+8, 2024-11-23 21:25

© 2014-2021

快速回复 返回顶部 返回列表