您的位置:首页 > 新闻资讯 >文章内容
多线程容易发生死锁的原因?怎么应对多线程的死锁问题?
来源:互联网 作者:admin 时间:2019-03-09 16:05:58

  爬虫使用多线程的过程中,若不小心,容易出现多线程死锁的情况,这是什么原因导致的呢?什么情况下会发生多线程死锁呢?若是发生多线程死锁,我们应该怎么处理呢?下面就去了解下关于多线程死锁问题。


  一、多线程容易发生死锁的原因


  1.顺序不当


  进程在运行过程中,请求和释放资源的顺序不当,也同样会导致死锁。例如,并发进程P1、P2分别保持了资源R1、R2,而进程P1申请资源R2,进程P2申请资源R1时,两者都会因为所需资源被占用而阻塞。


  信号量使用不当也会造成死锁。进程间彼此相互等待对方发来的消息,结果也会使得这些进程间无法继续向前推进。例如,进程A等待进程B发的消息,进程B又在等待进程A发的消息,可以看出进程A和B不是因为竞争同一资源,而是在等待对方的资源导致死锁。


多线程容易发生死锁的原因?怎么应对多线程的死锁问题?


  2.资源竞争


  通常系统中拥有的不可剥夺资源,其数量不足以满足多个进程运行的需要,使得进程在运行过程中,会因争夺资源而陷入僵局,如磁带机、打印机等。只有对不可剥夺资源的竞争才可能产生死锁,对可剥夺资源的竞争是不会引起死锁的。


  二、怎么应对多线程的死锁问题


  1.预防死锁


  这是一种较简单和直观的事先预防的方法。方法是通过设置某些限制条件,去破坏产生死锁的四个必要条件中的一个或者几个,来预防发生死锁。预防死锁是一种较易实现的方法,已被广泛使用。但是由于所施加的限制条件往往太严格,可能会导致系统资源利用率和系统吞吐量降低。


  2.避免死锁


  事先预防的策略,但它并不须事先采取各种限制措施去破坏产生死锁的的四个必要条件,而是在资源的动态分配过程中,用某种方法去防止系统进入不安全状态,从而避免发生死锁。(安全状态、银行家算法)


  3.检测死锁


  这种方法并不须事先采取任何限制性措施,也不必检查系统是否已经进入不安全区,此方法允许系统在运行过程中发生死锁。但可通过系统所设置的检测机构,及时地检测出死锁的发生,并精确地确定与死锁有关的进程和资源,然后采取适当措施,从系统中将已发生的死锁清除掉。


  4.解除死锁


  这是与检测死锁相配套的一种措施。当检测到系统中已发生死锁时,须将进程从死锁状态中解脱出来。常用的实施方法是撤销或挂起一些进程,以便回收一些资源,再将这些资源分配给已处于阻塞状态的进程,使之转为就绪状态,以继续运行。死锁的检测和解除措施,有可能使系统获得较好的资源利用率和吞吐量,但在实现上难度也最大。(资源剥夺法,撤销进程法,进程回退法)


  多线程死锁问题是面试的热门问题,因此即使所有了解,也是要多注意一些关于多线程死锁问题,比如造成的原因,怎么预防,出现问题的时候怎么处理等,这些都是需要去掌握的。


相关文章内容简介
推荐阅读
  • 30 2019-04
    国内的代理IP质量怎么样?

    国内的代理IP质量怎么样?有些项目需要使用到代理IP的,如果选择使用国内的代理IP,这质量上有保障吗?

  • 05 2019-06
    换IP地址还能上网吗?

    换IP地址还能上网吗?通常换IP有两种情况,一种是更改了不能上网了,一种是更改了可以上网。一般来说是没什么影响的,如果所更换的IP地址是正确的

  • 29 2019-04
    爬虫如何设置用代理和模拟浏览器访问

    爬虫如何设置用代理和模拟浏览器访问?爬虫要想活得久,势必是要把自己好好整下的,以用户的模式访问,这是活得最长久的方法。基于这个原因,我们在给爬虫伪装时,可以从IP地址以及访

  • 25 2019-05
    爬虫用代理IP爬取微博内容

    爬虫用代理IP爬取微博内容,这需要注意些什么呢?一般做爬虫爬取网站,首选的都是m站,其次是wap站,最后考虑PC站。当然,这不是绝对的,有的时候PC站的信息最全,而你又恰好需要全部的

  • 12 2019-03
    如何应对网站的反爬虫?写爬虫的注意事项

    由于网站有多种反爬虫,因此这要求我们在写爬虫时,要注意各种可能会遇到的问题,否则我们的爬虫绕不过去,最终也就拿不到数据了,这样也就毫无意义了。

  • 11 2019-06
    搭建移动设备使用的代理服务器

    搭建移动设备使用的代理服务器,这与pc端有什么不同呢?移动设备想要访问位于局域网中的某个特定设备上搭建的服务,需要通过代理服务器来实现,针对不同操作系统搭建代理服务器有不同

在线客服
大客户VIP渠道
点击这里给我发消息
讨论QQ群
HTTP代理IP爬虫
客服电话
13318873961