请看这篇文章:
http://www.microsoft.com/china/msdn/library/dnforms/html/winforms08162002.asp

解决方案 »

  1.   

    可能就是将:线程.Lock();起来把。
      

  2.   

    变量:a,b
    同步线程1,2
    线程1
    lock(a)
    {
    //....
        lock(b)
            {
             //....
             }
    }
    线程2
    lock(b)
    {
    //....
        lock(a)
            {
             //....
             }
    }
    注意:同步,如果不是同步,就不存在.
      

  3.   

    1. 假设在multi-therad环境下thread A 等待 thread B占用的资源而thread B也在等待thread A占用的资源就可能发生线程死锁的情况.2. 防止线程死锁:
      迫使concurrency的threads为serialized.
      

  4.   

    对于饥饿的定义-由于别的并发的激活的过程持久占有所需资源,是莫个异步过程载客预测的时间内不能被激活。最常遇到的线程的两个缺陷是死锁和饥饿。当一个或者多个进程,在一个给定的任务中,协同作用,互相干涉,而导致一个或者更多进程永远等待下去,死锁就发生了。与此类似,它当一个进程永久性地占有资源,使得其他进程得不到该资源,就发生了饥饿。首先我们看一下死锁问题。考虑一个简单的例子,假如你到ATM机上取钱,但是你却看到如下的信息“现在有没有现金,请等会儿再试。”你需要钱,所以你就等了一会儿再试,但是你又看到同样的信息。与此同时,在你后面,一辆运款装甲车正等待着把钱放进ATM中,但是运款装甲车到不了ATM取款机,因为你的汽车挡着道。而你又要取到钱,才会离开原地。这种情况下,就发生了死锁。在饥饿的情形下,系统不处于死锁状态中,因为有一个进程仍在处理之中,只是其他进程永远得不到执行的机会。在什么样的环境下,会导致饥饿的发生,没有预先确定好的规则。而一旦发生下面四种情况之一,就会导致死锁的发生。相互排斥: 一个线程或者进程永远占有一共享资源,例如,独占该资源。 
    循环等待: 进程A等待进程B,而后者又在等待进程C,而进程C又在等待进程A。 
    部分分配: 资源被部分分配。例如,进程A和B都需要用访问一个文件,并且都要用到打印机,进程A获得了文件资源,进程B获得了打印机资源,但是两个进程不能获得全部的资源。 
    缺少优先权: 一个进程访问了某个资源,但是一直不释放该资源,即使该进程处于阻塞状态。 
    如果上面四种情形都不出现,系统就不会发生死锁。请再看一下刚才的文件/打印机的例子,当其中一个进程判断出它得不到它所需要的第二个资源,就释放已经得到的第一个资源,那么第二个教程可以获得两个资源,并能够运行下去。
      

  5.   

    就是 a 蹲在茅坑朝 b 要手纸,b 拿着手纸一定要让 a 先让出茅坑
      

  6.   

    不会吧,CSDN上真的是什么帖子都有!
    sarcophile(食肉动物) 的解释挺形象的,很能说清楚问题。线程a需要资源x,y才能运行下去。现在a占有资源x,而资源y被另一个线程b占有,线程a等待线程b释放资源y;另一方面,线程b需要线程a所占有的资源x才能继续运行,于是线程b就等待线程a……。这样a等b,b等a……一直等待下去就是线程死锁。要详细了解的话建议还是看一看操作系统的书
      

  7.   

    To sarcophile(食肉动物)
       用瓦片刮行不行啊??
       (出自寻秦记)