java 面试知识点笔记(七)多线程与并发 上篇
问:进程和线程的区别? 进程是资源分配的最小单位,线程是CPU调度的最小单位 所有与进程相关的资源,都被记录在PCB中 进程是抢占处理器的调度单位;线程属于某个进程,共享其资源 线程只由堆栈寄存器、程序计数器和TCB组成 总结: 线程不能看作独立应用,而进程可以看作独立应用 进程由独立的地址空间,互不影响,线程只是进程的不同执行路径(一个线程挂掉了整个进程就挂掉了) 线程没有独立的地址空间,多进程的程序比多线程的程序健壮 进程的切换比线程的切换开销大很多(所以做高并发的程序采用多线程开发) 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方法名字