*线程
·进程
操作系统运行的一个程序
·线程
进程的一个执行单元或执行路径
一个进程至少有一个线程,当有多个线程时成为多线程进程,每一个线程都有一个栈
所有线程共享堆区和方法区
·主线程
Java虚拟机启动主线程运行,main方法
·用户线程
开启的新的线程,也成子线程
·守护线程
为其他线程提供服务线程,不能独立运行
如:垃圾回收期
*创建线程
·继承Thread
1)定义一个类继承Thread
2)重新run方法
3)创建线程对象
4)开启新的线程
·实现Runnable接口
1)创建Runnable接口的实现类
2)重写run方法
3)创建线程对象
4)开启新的线程
·实现Callable接口
1)创建Callable接口的实现类
call()有返回值,通过Callable泛型指定返回值类型
2)重写call方法
3)使用FutureTask<>创建线程对象
4)开启新的线程
*线程常用操作
·activeCount()返回当前活动线程的数量
·currentThread()返回当前线程
·getContextClassLoader()线程的上线文加载器
·getId()返回线程的id
·getName()返回线程的名称
·getPriority()返回线程优先级
·getStackTrace()返回线程状态
·interrupt()中断线程
·interrupted()测试线程是否被中断
·isAlive()测试线程是否结束
·isDaemon()判断是否守护线程
·isInterrupted()测试线程是否被中断
·join()线程合并
·run()线程代码
·setDaemon(boolean on)设置线程为守护线程
·setName(String name)设置线程的名称
·setPriority(int newPriority)设置线程优先级
·sleep(long millis, int nanos)线程休眠
·start()开启线程
·stop()终止线程
·yield()线程让步
*线程终止
·建立多种标志位让线程运行结束
*线程同步
·线程安全
问题:
当多个线程同时操作堆区或方法区,出现的数据不一致的问题
解决:
每个线程都访问自己的局部变量
使用线程同步技术
·线程同步
·在一个线程执行操作期间,不允许其他线程加入
·同步方法
·语法
synchronize(锁对象){
同步代码块
}
·原理:
·任意对象都可以作为锁对象,通常采用常量作为锁对象
·某一时刻,锁对象只能被一个线程持有
·线程获得了锁对象后会一直所有知道执行完同步代码块
·线程要执行同步代码快,必须先获得锁对象
*生产者消费者设计模式
·解决了数据的平衡问题
·设计模式
别人总结的一套解决方案
*Timer
·定时器类