线程安全:
指某个方法在多线程环境中被调用时,能够正确处理多线程之间的共享变量,返回预期的程序结果。
线程同步:
同步就是协同步调,按预定的先后次序进行运行。如:你说完,我再说。
线程同步,可理解为线程A和B一块配合,A执行到一定程度时要依靠B的某个结果,于是停下来,示意B运行;B依言执行,再将结果给A;A再继续操作。
原子操作:
一个函数或动作由一个或多个指令的序列实现,对外是不可见的;也就是说没有其他进程能看到其中间状态或中断此操作。
要保证指令序列要么作为一个组来执行,要么都不执行。原子性保证了并发进程的隔离。
互斥:
当一个进程在临界区访问共享资源时,其他进程不能进入该临界区访问共享资源的情形。
临界区:
一段代码,在这段代码中进程将访问共享资源,当另外一个进程已在这段代码中运行时,这个进程就不能在这段代码中执行。
死锁:
死锁定义为一组相互竞争系统资源或进行通信的进程间的"永久"阻塞。
形成死锁的四个条件:
1 互斥;2 占有且等待;3 不可抢占;4 循环等待。
活锁:
活锁指的是任务或者执行者没有被阻塞,由于某些条件没有满足,导致一直重复尝试->失败->尝试->失败。
活锁和死锁的区别:
在于,处于活锁的实体是在不断的改变状态,所谓的“活”;而处于死锁的实体表现为等待;活锁有可能自行解开,死锁则不能。
饥饿:
一个可运行进程尽管能继续执行,但被调用程序无限期的忽视,而不能被调度执行的情形。