Java 多线程学习(1)一些容易被遗忘的基础概念

有些知识很久不看很容易就会忘掉,尤其是一些概念性知识。好记性不如烂笔头,不如记下来便于以后翻看。


1、并发和并行

  • 并发:处理多个任务的能力,不一定要同时
  • 并行:同时处理多个任务的能力。

二者区别在于是否同时。参考:并发与并行的区别?

2、进程和线程

放几个比较有趣的答案,参考:线程和进程的区别是什么?

  • 进程和线程都是一个时间段的描述,是 CPU 工作时间段的描述,只不过颗粒大小不同。

    进程就是时间总和 = CPU 加载程序上下文的时间 + CPU 执行时间 + CPU 保存程序上下文的时间
    
    线程也是时间总和 = CPU 加载线程上下文的时间 + CPU 执行时间 + CPU 保存线程上下文的时间 	
    复制代码
  • 进程是爹妈,管着众多的线程儿子

3、线程安全性

当多个线程访问某个类时,不管运行时环境采用何种调度方式或者这些线程将如何交替执行,并且在主调代码中不需要任何额外的同步或协同,这个类都能表现出正确的行为,那么就称这个类是线程安全的。摘自:《Java 并发编程实战》

4、竞态条件和临界区

当多个线程竞争同一资源时,如果对资源的访问顺序敏感,就称存在竞态条件。导致竞态条件发生的代码区称作临界区。

5、线程的生命周期

  • NEW:新建
  • RUNNABLE:运行
  • BLOCKED:阻塞
  • WAITING:无限期等待
  • TIMED_WAITING:限期等待
  • TERMINATED:结束

6、Java 线程调度

线程调度是指系统为线程分配处理器使用权的过程,主要调度方式有两种,分别是协同式线程调度抢占式线程调度

7、僵尸进程和孤儿进程

  • 一个进程使用 fork 创建子进程,如果子进程退出,而父进程并没有调用 waitwaitpid 获取子进程的状态信息,那么子进程的进程描述符仍然保存在系统中。这种进程称之为僵尸进程(或称僵死进程)。
  • 一个父进程退出,而它的一个或多个子进程还在运行,那么那些子进程将成为孤儿进程。

参考资料:

(1)《深入理解 Java 虚拟机》周志明 著.

(2)《Java 并发编程实战》

扫描二维码关注公众号,回复: 8286105 查看本文章

(3)并发与并行的区别?

(4)线程和进程的区别是什么?

猜你喜欢

转载自juejin.im/post/5dfee07bf265da33dd2f61df