java 面试知识点笔记(七)多线程与并发 上篇

ぐ巨炮叔叔 提交于 2019-11-30 00:13:40

问:进程和线程的区别?

进程是资源分配的最小单位,线程是CPU调度的最小单位

  • 所有与进程相关的资源,都被记录在PCB中
  • 进程是抢占处理器的调度单位;线程属于某个进程,共享其资源
  • 线程只由堆栈寄存器、程序计数器和TCB组成

总结:

  1. 线程不能看作独立应用,而进程可以看作独立应用
  2. 进程由独立的地址空间,互不影响,线程只是进程的不同执行路径(一个线程挂掉了整个进程就挂掉了)
  3. 线程没有独立的地址空间,多进程的程序比多线程的程序健壮
  4. 进程的切换比线程的切换开销大很多(所以做高并发的程序采用多线程开发)

 

  • java对操作系统提供的功能进行封装,包括进程和线程
  • 运行一个程序会产生一个进程,进程包含至少一个线程
  • 每一个进程对应一个JVM实例,多个线程共享JVM里的堆
  • java采用单线程编程模式,程序自动创建主线程
  • 主线程可以创建子线程,原则上要后于子线程完成执行

 

问:Thread中start和run方法的区别?

直接看源码

这是一个本地方法

去openjdk里面查看 java/lang/Thread.c

start0方法调用了JVM_StartThread

再去vm/prims/jvm.cpp查看JVM_StartThread方法

方法里面代码很多 最关键的是看new JavaThread方法 传入了thread_entry

thread_entry里面主要是 call虚拟机传入run方法名字 就是new一个线程并执行run方法里面的内容

总结:

  • 调用start()方法会创建一个新的子线程并启动
  • run()方法只是Thread的一个普通方法调用

start是

run是

问:Thread和Runnable是什么关系?

  • Thread是实现了Runnable接口的类,使用run支持多线程
  • 因类的单一继承原则,推荐多使用Runnable接口
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!