1、线程和进程(linux下fork系统调用以及操作系统详解)
进程:资源分配基本单位
线程:资源占有基本单位
2、单进程:DOS、主线程:main
3、Thread 核心方法run()
**start() 使该线程开始执行;Java 虚拟机调用该线程的 run 方法。
4、两种方式:
1.实现runnable()接口
2.定义一个Thread子类并重写run()方法
5、线程启动 和 方法调用
线程启动:1.实现runnable接口(重写run方法) -->new Thread(实现runnable接口的类的对象)-->调用start()方法
2.继承Thread类(重写run方法) -->start方法
方法调用 : run方法的调用 虚拟机实现的只是start方法
由此:JVM调用start方法,而start后台需要创建deamon精灵线程调用run方法
6、线程基本方法
isAlive 判断线程是否终止
getPriority 获得线程优先数值
setPriority 设置线程优先数值
Thread.sleep(mm) 线程睡眠毫秒数
join 合并线程
yield 让出cpu进入就绪就绪队列
wait
notify/notifyAll 唤醒等待线程
sleep:静态方法 睡眠 若被其他线程打断 则抛出异常InteruptedException
7、线程同步
执行顺序问题
锁定同步内容:synchoronized(this){锁定内容} 或者在方法类型前面添加关键字synchronized 互斥锁
类似于静态块static修饰
由synchoronized造成死锁
面试实例剖析:
public class TT implements Runnable {
int b = 100;
public synchronized void m1(){
try{
b = 1000;
Thread.sleep(5000);
System.out.println("m1:b="+b);
}catch(Exception e){ }
}
public void m2() {
System.out.println("m2:"+b);
}
public void run() {
m1();
}
public static void main(String[] args) throws Exception{
TT tt = new TT();
Thread t = new Thread(tt);
t.start();
// Thread.sleep(1000); //修改睡眠时间或删除该行观察变量b结果
tt.m2();
}
}
若添加Thread.sleep(1)一句,tt.t2()打印出1000,若删除Thread.sleep(1);,tt.t2()打印出100
-------------------->线程机制
Object 类 两个重要方法被继承:wait 和 notify