线程第一章
来源:互联网 发布:met.sf.json tobean 编辑:程序博客网 时间:2024/05/21 10:57
使用多线程的情况:
- 一个程序同时执行多个任务;
- 单线程可以完成,单多线程效率高。
并发原理:
线程调度将时间划分为很多时间片段,尽可能均匀分配给每一个线程,获取时间片段的线程将被CPU运行,其余线程全部等待。微观上是“走走停停”,宏观上都在运行,这种现象叫“并发”。
线程调度
给线程分配时间片段
线程的生命周期(摘自:http://blog.csdn.net/mayouarebest8621/article/details/6755036)
线程是一个动态执行的过程,它也有一个从产生到死亡的过程。
生命周期的五种状态
新建(new Thread)
当创建Thread类的一个实例(对象)时,此线程进入新建状态(未被启动)。
例如:Thread t1=new Thread();
就绪(runnable)相当于注册
线程已经被启动,正在等待被分配给CPU时间片,也就是说此时线程正在就绪队列中排队等候得到CPU资源。例如:t1.start();
运行(running)
线程获得CPU资源正在执行任务(run()方法),此时除非此线程自动放弃CPU资源或者有优先级更高的线程进入,线程将一直运行到结束。
死亡(dead)将被GC回收
当线程执行完毕或被其它线程杀死,线程就进入死亡状态,这时线程不可能再进入就绪状态等待执行。
自然终止:正常运行run()方法后终止
异常终止:调用stop()方法让一个线程终止运行
堵塞(blocked)不能运行,不能回到就绪状态
由于某种原因导致正在运行的线程让出CPU并暂停自己的执行,即进入堵塞状态。
正在睡眠:用sleep(long t) 方法可使线程进入睡眠方式。一个睡眠着的线程在指定的时间过去可进入就绪状态。
正在等待:调用wait()方法。(调用motify()方法回到就绪状态)
被另一个线程所阻塞:调用suspend()方法。(调用resume()方法恢复)
创建线程(New Thread)1
**同步运行:有先后顺序的运行方式
**异步运行:各干各的,多个线程并发运行的效果。
//代码示例public class CreateAThread { public static void main(String[] args) { Thread t1 = new MyThread1(); Thread t2 = new MyThread2(); /** * start方法将线程纳入线程调度 * 此时线程进入就绪(runable)状态,等待线程 * 调度分配时间片段。 */ t1.start(); t2.start(); }}//过于局限,重用性太差class MyThread1 extends Thread{ public void run(){ for(int i = 0; i < 1000; i++){ System.out.println("你是谁啊"); } }}class MyThread2 extends Thread{ public void run(){ for(int i = 0; i < 1000; i++){ System.out.println("我是去年买了个表的"); } }}
解耦与耦合
耦合:强制绑定。
解耦:接触耦合关系。
线程就是线程,任务就是任务。
Spring框架
程序松散绑定
创建线程(New Thread)2
package day01;/** * 介绍创建线程的第二种方法:定义线程体Runnable * @author Administrator * */public class CreatedAThread_02 { public static void main(String[] args) { Runnable runn1 = new MyRunnable1(); Runnable runn2 = new MyRunnable2(); Thread t1 = new Thread(runn1); Thread t2 = new Thread(runn2); t1.start(); t2.start(); }}//灵活,重用性好,需要干的活直接实现接口class MyRunnable1 implements Runnable{ public void run(){ for(int i = 0 ;i < 1000;i++){ System.out.println("你丫谁啊"); } }}class MyRunnable2 implements Runnable{ public void run(){ for(int i = 0 ;i < 1000;i++){ System.out.println("老子去年买了表的"); } }}
温故知新:匿名内部类
故名思义,就是没有名字的内部类。
只能(需)使用一次。用于简化代码。
创建线程(New Thread)3
package day01;/**使用匿名内部类的形式创建线程 */public class CreatedThread_03 { public static void main(String[] args) { //1 Thread t1 = new Thread(){ public void run(){ for(int i = 0;i < 1000;i++){ System.out.println("你丫谁啊"); } } }; //2 Runnable runn = new Runnable(){ public void run(){ for(int i = 0 ;i < 1000;i++){ System.out.println("老子查水表的"); } } }; Thread t2 = new Thread(runn); t1.start(); t2.start(); }}
- 线程第一章
- 第一章线程管理
- 第一章 线程安全性
- 第一章 线程概述
- 第一章线程管理
- 第一章、主线程与子线程
- 第一章 Thread Management(线程管理) 上
- 第一章 Thread Management(线程管理) 中
- 第一章 Thread Management(线程管理) 下
- 第一章>
- 第一章
- 第一章
- 第一章
- 第一章
- 第一章
- 第一章
- 第一章
- 第一章
- An Introduction to SCSI Drivers
- 在Android上跑TensorFlow之接入TensorFlow
- Android webView加载数据时内存溢出问题
- leetcode 192. Word Frequency
- 网络的拓扑和算法复杂度
- 线程第一章
- Android NDK: From Elementary to Expert Episode 10
- 自动加载更多的listView
- vs2010下 转换到 COFF 期间失败: 文件无效或损坏
- C语言getchar()、getch()、scanf()对比(二)
- [Havok学习笔记(2)] HAT样例AnimatedAttachments
- Java日期工具类
- ueditor iframe被过滤掉问题,优酷视频链接
- iOS利用HealthKit获取健康里的步数和睡眠时间