你真的清楚什么是线程安全吗?
如果面试官问你,线程安全的类有哪些,究竟什么是线程安全?你怎么回答呢?我们整天说线程安全,但你真的知道什么是线程安全吗? 什么是进程 从学术上理解,进程就是包含上下文切换的程序执行时间总和 = CPU加载上下文+CPU执行+CPU保存上下文。 另一个简单的理解,进程就是程序的一次执行,比如看看一下这个图,每一个运行中的程序就是一个独立的进程,进程是相互独立存在的。 什么是线程 线程就是CPU执行那一部分的一个个小段,线程是CPU的基本调度单位。 注:平时大家说“因为Redis是单线程的,所以它是原子性的”,根本原因是,因为线程是CPU的最小调度单元,CPU每次只能执行成功或者失败才调度切换到下一个线程,所以Redis的操作都是原子的。 进程和线程都是一个时间段的描述,是CPU工作时间段的描述,不过是颗粒大小不同。 堆和栈 进程与线程中比较重要的内存区域有堆和栈。 堆是进程和线程共有的空间,分全局堆和局部堆。全局堆就是所有没有分配的空间,局部堆就是用户分配的空间。堆在操作系统对进程初始化的时候分配,运行过程中也可以向系统要额外的堆,但是用完了要还给操作系统,要不然就是内存泄漏。 在Java中,堆是Java虚拟机所管理的内存中最大的一块,是所有线程共享的一块内存区域,在虚拟机启动时创建。堆所存在的内存区域的唯一目的就是存放对象实例,几乎所有的对象实例以及数组都在这里分配内存。 栈是每个线程独有的,保存其运行状态和局部自动变量的。栈在线程开始的时候初始化,每个线程的栈互相独立,因此,栈是线程安全的。操作系统在切换线程的时候会自动切换栈。栈空间不需要在高级语言里面显式的分配和释放。 进程和线程中的数据 程序几乎都需要与数据打交道,读取数据(命令行参数,文件),写入数据(设置变量,写入文件)。这些数据是保存在进程所管理的内存里。 为了保证数据的安全,比如一个进程中修改的数据不会影响到另一个进程的数据,每一个进程都会拥有操作系统分配给自己的内存空间,而不能访问其他进程的数据,这一点是由操作系统保证的。 进程占有的资源:地址空间,全局变量,打开的文件,子进程,信号量,账户信息 线程占有的资源:栈,寄存器,状态,程序计数器 进程是操作系统进行资源分配和调度的一个独立单位,不会共享资源,通过进程间通信共享资源,而线程可以共享部分资源,独自占有的资源不共享。 (编辑:ASP站长网) |