进程
进程是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。
每个程序都有一个独立的进程,比如运行QQ,微信,就是一个进程。
线程
一个进程内部可能包含了很多顺序执行流,每个顺序执行流就是一个线程。线程是指进程中的一个执行流程,一个进程中可以运行多个线程。
一个标准的线程由线程ID,当前指令指针(PC),寄存器集合和堆栈组成
线程优先级
线程是有优先级的,优先级越大执行的可能性越大(并不是最先执行)。
线程状态
线程的状态有新建(new)、可运行(runnable)、运行(running)、阻塞(block)、死亡(dead)。
线程安全
什么是线程安全?
线程安全, 是指变量或方法( 这些变量或方法是多线程共享的) 可以在多线程的环境下被安全有效的访问。
多个线程访问同一个对象时,如果不用考虑这些线程在运行时环境下的调度和交替执行,也不需要进行额外的同步,或者在调用方进行任何其他操作,调用这个对象的行为都可以获得正确的结果,那么这个对象就是线程安全的。
如何做到线程安全?
什么是并发
并发,在操作系统中,是指一个时间段中有几个程序都处于已启动运行到运行完毕之间,且这几个程序都是在同一个处理机上运行,但任一个时刻点上只有一个程序在处理机上运行。
怎么避免并发
- 线程封闭
- 无状态的类
- 让类不可变
- volatile
- 加锁和CAS
- 安全的发布
- ThreadLocal
解决线程安全
基本上所有的并发模式在解决线程安全问题上,都采用“序列化访问临界资源”的方案,即在同一时刻,只能有一个线程访问临界资源,也称同步互斥访问。
通常来说,是在访问临界资源的代码前面加上一个锁,当访问完临界资源后释放锁,让其他线程继续访问。
在Java中,提供了两种方式来实现同步互斥访问:synchronized和Lock。
创建线程的四种方式
- 继承Thread类
- 实现Runnable接口
- 使用Callable和FutureTask
- 使用线程池,例如用Executor框架
详解参考:创建线程的四种方式