线程
来源:互联网 发布:pptv网络大电影合作 编辑:程序博客网 时间:2024/05/29 19:52
线程的状态:
[新建 new] --> [可运行(Runnable)] <--> [运行态(Running)]
线程:
线程状态:
1 new (新建)
2 Runnable
3 Running
4 Block
5 Dided
线程状态管理:
Thread.yield() 当前线程让出处理器(离开Running),
使当前线程进入Runnable等待
Thread.sleep(times) 使当前线程从 Running 放弃处理器
进入Block状态, 休眠times毫秒, 再返回到Runnable
如果其他线程打断当前线程的Block(sleep), 就会发生
InterruptedException.
后台线程(守护线程, 精灵线程)
t4.setDaemon(true);
Java进程的结束: 当前所有前台线程都结束时, Java进程结束
后台线程, 不管是否结束, 都被停掉!
线程的优先级
t3.setPriority(Thread.MAX_PRIORITY-1);
默认有10 优先级, 优先级高的线程获得执行的机会多. 机会
的多少不能通过代码干预.
默认的优先级是 5
两种方式创建线程
1 继承Thread类
a 继承Thread类, 覆盖run()方法, 提供并发运程的过程
b 创建这个类的实例
c 使用start() 方法启动线程
2 实现Runnable接口
a 实现Runnable接口, 实现run()方法, 提供并发运程的过程
b 创建这个类的实例, 用这个实例作为Thread构造器参数
创建Thread类.
c 使用start() 方法启动线程
class Foo implements Runnable{
public void run(){
//....
}
}
Thread t = new Thread(new Foo());
t.start();
3 使用内部类创建线程
可以使用 Thread.currentThread() 方法获得当前线程的引用
线程的同步
1 多个线程并发读写同一个临界资源时候会发生线程安全问题
2 可以使用 同步代码块解决 同步读写临界资源, 解决并发安全
问题.
3 a 同步代码块
synchronized(同步监视器){
}
b 同步监视器 是一个任意对象实例. 是一个多个线程之间的互
斥的锁机制. 多个线程要使用同一个"监视器" 实现同步互斥
c 常见写法:
synchronized(this){
}
d 如果方法的全部过程需要同步, 可以简单使用 synchronized
修饰方法.
Java中同步的API
1 StringBuffer 是同步的
synchronized append();
StringBuilder 不是同步的
append();
2 Vector 和 Hashtable 是同步的
ArrayList 和 HashMap 不是同步的
3 Collections.synchronizedList()
ArrayList list = new ArrayList();
List syncList = Collections.synchronizedList(list);
异步线程之间, 协作通信
异步写文件操作
1 同步写文件: 从控制台读取一行,立即写道文件中
Timer 计时器
- 线程
- 线程
- 线程
- 线程
- 线程
- 线程
- 线程
- 线程
- 线程
- 线程
- 线程
- 线程
- 线程
- 线程
- 线程
- 线程
- 线程
- 线程
- uestc oj 1035 论文搜索(子串查找)
- 正则表达式学习笔记
- mysql书库表检查
- phpize和php-config安装模块
- 深入理解指针函数
- 线程
- 智能语义搜索 - 徐海蛟
- c 中的 # #@ ##
- 启动服务器的时候遇到的org.hibernate.PropertyNotFoundException: field [set] not found on xx.xxx.xx问题
- 网络通信框架Volley使用详细说明
- mysql数据库检查、数据库表导出、数据库表修复
- 图片服务器分离
- Android权限中文描述大全(转)
- TCP/IP详解学习笔记