
编程对于很多人来说,还是比较好上手的。当你学会了一门语言,可以编写一些程序了,很快就会遇到一道坎,并发编程,单线程下好好跑着的程序,怎么就运行异常了?怎么就得不到期望的结果。在面试中,并发编程也是经常出现,我们今天来讨论一个问题, 并发编程,容易出哪些问题?
相信大家在学习并发编程的时候,都会遇到这样一个经典问题,有一个函数,执行i=i+1,执行1000遍。在单线程的环境下,得到的结果都是预期的1000。如果是两个线程同时运行,那么,得到的结果可能是2000,也有可乱拍能小于2000。
这是因为i=i+1不是一个原子 *** 作,我们会获取i的值,然后执行一次加法运算,最后将结果赋值给i。当多个线程执行的时候,获取到的i的值之后,在执行后面的动作之前,另外一个线程已经修改了i,造成最终的结果小于2000。
并发编程的时候,我们往往无法确定多个线程之间的执行顺序,经常我们会出现这样一个错误。我们在一个线程中使用的变量,会在另外一个线程中进行初始化或者赋值。最常见的,便是我们在主线程上创建一个子线程,然后再进行变量的初始化,子线程的执行可能早于父线程,造成程序错误。
为了解决并发问题,我们通常会引入锁链消、信号、信号量等手段来保证临界区只会被一个线程访问,或者让一个线程等待另外一个线程执行完成。但是,引入锁之后,我们又可能会出现死锁的问题,例如:线程1与线程2都需要抢占AB两把锁,假设线程1先抢占了A锁,线程2抢占了B锁,这个时候,线程1在等待B锁,线程2在等待A锁,就这样,等到海枯石烂,我们称之为死锁。
出现死锁,需要同时满足下面几个条件:1.线程需要对需要的资源进行互斥访问(例如一个线程抢到锁)2.持有并等待(例如一个线程抢到了A锁,然后在等待B锁)3.非抢占(线程抢到了锁之后,不能被其他线程抢到)4.循环等待,线程之前存在一个环哗唤羡路。
那么,如何解决死锁的问题呢?既然出现死锁需要同时满足上面的几个条件,那么,我们只要破坏其中一个条件,就能够避免死锁问题。
今天,我们了解到并发编程带来的问题与解决方案,希望对你在平时的工作或者面试有所帮助。
两个程序并发的判断通常需要考虑以下几个方面:1. 是否共享资源:如果两个程序需要同时访问同一个资源,比如文件、数据库、网络连接等,那么它们就可能会产生并发。如果两个程序没有共享资源,它们就不会产生并发。
2. 是否存在竞争条件:如果两个闷销程序在访问共享资源的过程中,它们的 *** 作顺序会影响最终的结果,那么它们就可能会产生竞争条件,从而产生并发。
3. 是否具有时间重叠性:如果两个程序的执行时间有重叠部分,那么它们就可能会产生并发。
4. 是否交替执行:如果两个程序的执行顺序没有固定的规律,或者它们会在不同的时间片上交替执行,那么它们就可能会产生并发。
综上所述,如果两个程序共享资源、存在竞争条洞罩慎件、具有时间重叠性或者交替执行,那么它们就可能会产生并发。可纳敬以通过观察它们的执行过程、分析它们的代码逻辑等方式来判断它们是否并发。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)