菜鸟求助多线程的一些问题……(这分对于懂的人应该很好拿)

zouyong311 2011-12-27 05:06:10
我是个C#菜鸟,刚刚设计线程有点弄得云里雾里。所以希望各位高手帮我一把,我觉得入门往往就是自己怎么也琢磨不透,但只要点一下就通了。谢谢啦。
我想用主线程同时启动n个子线程实例Func1,Func2...FuncN,每个子线程均是去执行Calculate算法,算出结果的子线程(设FuncX)立刻传递结果给主线程,之后主线程会强行结束其他未算出结果的线程,并且保留FuncX实例。然后进行第二步计算。
第二步计算的逻辑如同第一步,也是并发计算然后竞争剩下一个。但这次需要把FuncX复制多份每份作为一个子线程继续去执行Calculate,因为FuncClass的实例在第一次计算过程中,会产生一些数据a_1,a_2,a_3,这些在第二次计算的时候会用到,所以没法重新实例化一个FuncClass。
然后是第三步计算。。第四步。。。

我想问这样的一个计算逻辑是否可以实现?我主要困惑在
1、如何主线程子线程传递参数的同时还要加上一个“竞争”的机制
2、就是怎么把“获胜”的实例复制再计算。

*对于第一个问题我想可能是用委托,但我不知道具体怎么做,还有就是我那个Calculate方法的计算是会对远程数据库操作的,会改变远程数据库的值。会不会在第一个线程算出结果之后,主线程还未来得及杀死其他线程,其他线程就把数据库的值又给变掉了。
*对于第二个问题。。。是要克隆自己的实例吗?网上搜了克隆一个实例貌似蛮复杂的。。。


class mainthread
{
public mainthread()
{
FuncClass Func1=new FuncClass();
thdSubThread1 = new Thread(new ThreadStart(Func.Calculate));
thdSubThread1.Start();

FuncClass Func2 = new FuncClass();
thdSubThread2 = new Thread(new ThreadStart(Func.Calculate));
thdSubThread2.Start();

//....;
}
}


class FuncClass
{
private object a_1;
private object a_2;
private object a_3;

public string Calculate(string para) //这样的方法貌似没法当线程启动,我只是示意一下,我希望主线程传进去参数,传出来结果……
{
//.....;
}
}
...全文
166 13 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
zouyong311 2011-12-28
  • 打赏
  • 举报
回复
自己顶一下……真心求助~!
zouyong311 2011-12-28
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 mayswind 的回复:]
你可以再开个线程专门监视锁,然后每隔一段判断下,然后Sleep。


引用 4 楼 zouyong311 的回复:

引用 2 楼 wddw1986 的回复:
竞争就用一个锁好了,锁就是FuncClass的对象,子线程计算完成后发现锁是空的就对锁赋值,如果锁有值就退出。主线程检测到这个锁有值了,就把对象取出来,杀掉所有线程,然后通过FuncClass对象提供的一个Clone方法,复制N……
[/Quote]

这样不行的,每个Calculate在算出结果之后会对远端数据库产生影响,我需要在算出结果的第一瞬间立刻杀死其他未出结果的线程,因为一旦其他线程也算出结果就会覆盖掉第一个线程对远端数据库的影响。
zouyong311 2011-12-28
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 sp1234 的回复:]
如果都纠结在“锁了”还搞什么多线程?那种不过是拿线程当作概念幌子而已,不过是拿并行的幌子来做同步的事情而已。

线程就是把函数式思维编程回调式思维,然后再考虑通讯问题。
[/Quote]

你说的应该是多线程的宗旨吧。。虽然抽象,我有点懂你的意思。你说的没错,其实我这样做的确和一个线程的结果没有什么区别。但事实是我的Calculate需要访问远端服务器,从服务器得到响应,然后在继续计算工作,但服务器响应是不固定的,如果远程人多,就要等很久才能得到回应。
打个比方,我们打开一个很拥挤的网站,因为人多,打不开,我们就会多开几个浏览器,往往会发现第一个显示网站页面的浏览器并不是我们第一个输入网址的浏览器。之后我们的操作完全就针对这个打开网站的浏览器了,其他的统统关掉。
而我就是要获取这个“打开网站最快”的浏览器。这个是我想到提高响应速度的一个办法,当然我更希望有更好更高效的方法,但我真的不知道哦……如果你知道,希望你能教教我,谢谢啊~
吾非大神 2011-12-27
  • 打赏
  • 举报
回复
会不会死机?
  • 打赏
  • 举报
回复
把函数式思维编程回调式思维 --> 把函数式思维丢掉而变成回调式思维
  • 打赏
  • 举报
回复
如果都纠结在“锁了”还搞什么多线程?那种不过是拿线程当作概念幌子而已,不过是拿并行的幌子来做同步的事情而已。

线程就是把函数式思维编程回调式思维,然后再考虑通讯问题。
  • 打赏
  • 举报
回复
如果都纠结在“锁了”你还搞什么多线程?你不过是拿线程当作概念幌子而已,不过是拿并行的幌子来做同步的事情而已。
mayswind 2011-12-27
  • 打赏
  • 举报
回复
你可以再开个线程专门监视锁,然后每隔一段判断下,然后Sleep。

[Quote=引用 4 楼 zouyong311 的回复:]

引用 2 楼 wddw1986 的回复:
竞争就用一个锁好了,锁就是FuncClass的对象,子线程计算完成后发现锁是空的就对锁赋值,如果锁有值就退出。主线程检测到这个锁有值了,就把对象取出来,杀掉所有线程,然后通过FuncClass对象提供的一个Clone方法,复制N份,继续起N个线程计算。

谢谢你的回答,那么这个锁是存放在mainthread中的一个变量咯?这个我有点明白了。但是主线……
[/Quote]
mayswind 2011-12-27
  • 打赏
  • 举报
回复
你可以在开个线程专门监视锁,然后每隔一段判断下,然后Sleep。

[Quote=引用 4 楼 zouyong311 的回复:]

引用 2 楼 wddw1986 的回复:
竞争就用一个锁好了,锁就是FuncClass的对象,子线程计算完成后发现锁是空的就对锁赋值,如果锁有值就退出。主线程检测到这个锁有值了,就把对象取出来,杀掉所有线程,然后通过FuncClass对象提供的一个Clone方法,复制N份,继续起N个线程计算。

谢谢你的回答,那么这个锁是存放在mainthread中的一个变量咯?这个我有点明白了。但是主线……
[/Quote]
zouyong311 2011-12-27
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 wddw1986 的回复:]
竞争就用一个锁好了,锁就是FuncClass的对象,子线程计算完成后发现锁是空的就对锁赋值,如果锁有值就退出。主线程检测到这个锁有值了,就把对象取出来,杀掉所有线程,然后通过FuncClass对象提供的一个Clone方法,复制N份,继续起N个线程计算。
[/Quote]
谢谢你的回答,那么这个锁是存放在mainthread中的一个变量咯?这个我有点明白了。但是主线程如何“检测”到锁里有值了呢?在子线程计算的过程中,其实主线程也有事情做的,所以他没法循环着去监视锁中的值。
另外,你说的FuncClass提供的clone方法应该是要自己写的吧,我有点不太会写这个方法。。。实例中的数据(a_1,a_2,a_3....)蛮多的,需要我一个个的赋值给新实例吗?
zouyong311 2011-12-27
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 wddw1986 的回复:]
竞争就用一个锁好了,锁就是FuncClass的对象,子线程计算完成后发现锁是空的就对锁赋值,如果锁有值就退出。主线程检测到这个锁有值了,就把对象取出来,杀掉所有线程,然后通过FuncClass对象提供的一个Clone方法,复制N份,继续起N个线程计算。
[/Quote]
谢谢你的回答,那么这个锁是存放在mainthread中的一个变量咯?这个我有点明白了。但是主线程如何“检测”到锁里有值了呢?在子线程计算的过程中,其实主线程也有事情做的,所以他没法循环着去监视锁中的值。
另外,你说的FuncClass提供的clone方法应该是要自己写的吧,我有点不太会写这个方法。。。实例中的数据(a_1,a_2,a_3....)蛮多的,需要我一个个的赋值给新实例吗?
cheng2005 2011-12-27
  • 打赏
  • 举报
回复
竞争就用一个锁好了,锁就是FuncClass的对象,子线程计算完成后发现锁是空的就对锁赋值,如果锁有值就退出。主线程检测到这个锁有值了,就把对象取出来,杀掉所有线程,然后通过FuncClass对象提供的一个Clone方法,复制N份,继续起N个线程计算。
cheng2005 2011-12-27
  • 打赏
  • 举报
回复
竞争就用一个锁好了,锁就是FuncClass的对象,子线程计算完成后发现锁是空的就对锁赋值,如果锁有值就退出。主线程检测到这个锁有值了,就把对象取出来,杀掉所有线程,然后通过FuncClass对象提供的一个Clone方法,复制N份,继续起N个线程计算。

111,096

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • AIGC Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧