1、并发和并行
并发是指同一时间段内多个任务同时都在执行,并且都没有执行结束,而并行是在说单位时间内多个任务同时在执行。并发任务强调在一个时间段内同时执行,而一个时间段由多个单位时间累计而成,所以说并发的多个任务在单位时间内不一定同时在执行。
在单CPU时代多任务都是并发执行的,这是因为单个CPU同时只能执行一个任务。在单CPU时代,多任务是共享一个CPU的,当一个任务占用CPU运行时,其他任务就会被挂起,当占用CPU的任务时间片用完后,会把CPU让给其他任务来使用。
2、共享资源
所谓共享资源,就是说该资源被多个线程所持有或者说多个线程都可以去访问该资源。
线程安全问题是指当多个线程同时读写一个共享资源并且没有任何同步措施时,导致出现脏数据或者其他不可预见的结果的问题。
3、Java共享变量的内存可见性问题
Java内存模型规定,将所有的变量都存放在主内存中,当线程使用变量时,会把主内存里面的变量赋值到自己的工作空间或者叫作工作内存,线程读变量时操作的是自己工作内存中的变量。
Java内存模型是一个抽象的概念,在实际实现中线程的工作内存如下: