进程和线程的区别
进程:系统做一件事运行一个任务,所运行的任务通常是
程序,每个
运行中的程序就是一个进程
特征:独立性:进程是系统中独立的实体,拥有自己独立的资源,每个进程都有自己私有的地址空间
动态性:程序是静态的(静态的指令集合)进程是动态的(系统中运行的指令集合,有了生命周期)
并发性:进程之间,交替的执行
线程:当一个程序运行时,内部可能有多个顺序执行流,每个顺序执行流就是一个线程
特征:一个顺序执行流,他是进程的组成部分,一个进程有多个线程
优势:进程之间不能共享内存,系统创建进程要为进程重新分配资源
单线程之间共享内存简单,创建线程的代价小,所以多线程的实现多任务并发比多进程实现并发的效率高
总结:一个程序运行至少一个进程,一个进程里面至少包含一个线程,线程是进程的组成成分
Java定制线程类的两种方法
(1)、继承Thread
public class MyThread{
public static void main(String[] args) {
new MyThread("A").start();
new MyThread("B").start();
}
}
class MyThread extends Thread{
String name = null;
public MyThread(String name){
this.name = name;
}
public void run(){
for(int i = 0;i<5;i++){
try {
Thread.sleep((long)Math.random()*1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.print(name);
}
}
}
(2)、实现Runnable接口
public class MyTread{
public static void main(String[] args) {
new Thread(new MyThread("A")).start();
new Thread(new MyThread("B")).start();
}
}
class MyThread implements Runnable{
String name = null;
public MyThread(String name){
this.name = name;
}
public void run(){
Thread current = Thread.currentThread();
for(int i = 0;i<5;i++){
try {
current.sleep((long)Math.random()*1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.print(name);
}
}
}
注意:线程一旦进入休眠,run方法将中断,当前线程进入阻塞状态,从而给其他线程执行的机会,进程休眠结束后,不一定立刻被执行,只有被再次调用才会执行
区别:线程的并发:计算机只有一个CPU,某一个具体时刻只能执行一个线程,但是在一段时间内,多个线程可以得到执行
线程的并行:计算机有多个CPU,某一时刻,可以同时执行多个线程
线程的生命周期
注意:创建线程后我们只有通过start()方法才能启动线程
线程启动后进入可运行状态,但是不一定能运行,只有被调度才真正出于运行状态
出于运行状态的线程也可能被调度出于可运行状态
线程中断
原理:当调用一个线程的interrupted方法时,即向该线程发送一个中断请求,并将该线程的interrupted状态值置为true
但是该线程由于调用sleep或wait出于阻塞状态那么会抛出一个InterruptedException异常
线程的优先级
通过setPriority()方法来设置优先级
在任意时刻,当有多个线程处于可运行状态,运行系统会挑一个优先级高的线程执行,只有当线程停止或者退出或由于某种原因不执行的时候,低优先级的线程才可以被执行
如果优先级一样,会以round-robin的方式选择一个执行
被选中的线程可能由于下面几个原因退出,从而给其他线程以执行的机会
1.一个更高优先级的线程处于可运行状态
2.线程主动退出(调用yield方法),或者他的run结束
3.在支持分时方式的系统上,分配给该线程的时间片结束(Java本身并不实现分时,分时是和平台相关的)
-------------------------------------------------------------------------------------------------------------------------------------------------------------
以上都是线程异步的,接下来的一篇通过生产者消费者总结线程同步问题