标签:style java 使用 io art 问题 ar 时间
线程的简单学习笔记:
1、进程与线程的概念
进程:从用户角度看进程是应用程序的一个执行过程。
从操作系统核心角度看进程代表的是操作系统分配的内存和CPU时间片等资源的基本单位,是为正在运行的程序提供的运行环境。
线程:是程序执行流的最小单位(处理器调度的最小单位)
线程是一个程序中一个单一的顺序控制流程。
线程是程序执行的一条路径, 一个进程中可以包含多条线程。
2、创建线程
在线程类使用new 关键字实例化之后且在调用start()方法之前,线程处于创建状态,处于创建状态的线程仅仅分配了内存空间,属于生命周期的初始状态。
启动线程:类Thread定义了start()方法用来完成线程的启动。
创建线程有两种方法:
继承java.lang.Thread类或者实现Runnable接口
第一种方法:继承继承java.lang.Thread类
可以通过继承Thread类,覆盖其Run()方法创建自己的线程类。语法格式如下;
Class MyThread(线程名) extends Thread{
//覆盖Thread类的run()方法
Public void run(){
//执行语句;
}
}
在main方法中:
MyThread mt=new MyThread();
Mt.start();
第二种创建线程的方法是实现Runnable接口
如果定义的线程类还要继承其他类,这时就不能继承Thread类了,这种情况可以采用实现Runnable接口的方式创建,语法格式如下:
Class MyThread(线程名) implements Runnable{
Public void run(){
//执行语句;
}
}
在main方法中:
MyThread mt=new MyThread();
Thread t=new Thread(mt);
t.start();
3、线程的生命周期
1)、创建线程
在线程类使用new 关键字实例化之后且在调用start()方法之前,线程处于创建状态,处于创建状态的线程仅仅分配了内存空间,属于生命周期的初始状态。类Thread定义了start()方法用来完成线程的启动。
2)、就绪
在线程调用了start()方法后即处于就绪状态。处于就绪状态的线程就具备了除CPU之外运行所需的所有资源,就绪状态线程排队等待CPU,有系统调度为其分配。
3)、运行
处于就绪状态的线程获得CPU之后即处于运行状态。处于运行状态的线程才开始真正执行线程run()方法的内容。
4)、阻塞
处于运行状态的线程如果因为某种原因不能执行,则进入阻塞状态。阻塞状态与就绪状态的不同是:就绪状态只是因为确实CPU不能执行,而阻塞状态由于各种原因引起线程不能执行,不仅仅是缺少CPU。引起阻塞的原因解除后,线程再次转为就绪状态,等待分配CPU运行。
5)、死亡
当线程执行完run()方法的内容或被强制终止时,线程处于死亡状态,线程的整个生命周期结束。
线程再整个生命周期中始终处于某种状态,从一种状态到另一种状态的转换由线程调度方法实现。
4、线程的调度
处于生命周期中的线程,通过调度实现各种状态间的转换,线程的调度是使用各种线程调度方法;如;setPriority(),sleep(),
yield(),join()等。对线程进行不同的操作。
setPriority():线程的优先级
sleep():线程休眠
yield():线程让步
join():线程等待
setPriority():线程的优先级 线程的优先级是指线程调度执行时的优先执行级别。在多线程程序中,往往是多个线程同时等待被调度执行。然而,每个线程的重要层度不一样,在同等条件下,有些重要的线程需要优先执行。在java语言中,通过调用setPriority()方法为线程设置优先级,优先级用1--10 的数字表示,数字越大,优先级越高。
sleep()方法: 在指定的毫秒数内让当前正在执行的线程休眠(暂停执行),此操作受到系统计时器和调度程序精度和准确性的影响。
可以引起当前线程挂起执行一个指定的时期,这意味着处理时间可用于程序其他线程,或者执行在计算机系统内的其他应用程序。sleep()方法还被用于控制步调等待另外的线程完成有时间要求的任务。
yield()方法:暂停当前正在执行的线程对象,并执行其他线程。
对于正在执行的线程,可以调用yield()方法使其重新排队,将CPU让给排在后面的线程,此线程转为就绪状态。另外,yield()方法只让步给高优先级或者同等优先级的线程,如果后面是低优先级线程,则继续执行此线程。
join()方法:对于正在运行的线程,可以调用jion方法等待其结束,然后执行其他程序。jion()方法有几种重载形式,其中,不带任何参数的join()方法,等待线程执行结束为止,带有一个参数的join(long millis):表示等待该线程终止的时间最长为millis毫秒,超时为 0 意味着要一直等下去。0代表超时时间无限长。
简单理解为;可以等待指定的毫秒之后继续
5、线程之间的同步
当多个线程操作多个共享资源时,比如读写同一个变量,才在着资源竞争的问题。为了解决此类问题,需要使用同步机制。在java语言中,利用synchronized关键字实现线程的同步。
语法格式如下:
访问修饰符 同步关键字(synchronized) 返回值类型 方法名(参数)
标签:style java 使用 io art 问题 ar 时间
原文地址:http://www.cnblogs.com/jingjing0907/p/3875295.html