美文网首页
关于多线程的一些知识点(一)——基础

关于多线程的一些知识点(一)——基础

作者: li_荔枝 | 来源:发表于2019-10-20 21:43 被阅读0次

1.串行与并发

image.png

串行,如上图左边,一个时间点只能单一执行任务,如有任务a,b,c,它们只能按顺序执行。并发,如图右边,多个任务可以同时执行,在单核cpu中并发并不是真正的在同一时间点去执行任务,多个任务或进程会共享一个cpu,cpu会在这些任务之间迅速的切换,以使得每个任务都有机会获得一定的时间片运行。

2.进程线程

进程,系统中正在运行的程序,这些程序在运行中会占用一定的内存,cpu等资源。进程之间资源不共享。进程中有一个或多个线程。就像A,B,C几个市的高速收费站,他们的收入是不共享的, 每个市的收费站(进程)有多条通道(线程)。

线程,线程是一个进程中执行任务的最小单元,线程之间资源共享。假如一个工人就是一个cpu, 某个收费站(进程)有4条通道, 但只有一个工人, 多线程任务的并发就是这个工人在这四条通道迅速切换进行工作。

3.线程的生命周期

既一个线程从被实例化到销毁的过程。
中间有几种状态(不同教程的说法可能不同):

1.新建状态(new):

一个线程被实例化完成,Thread t = new MyThread();但是还没有做任何操作。

2.就绪状态(Runnable):

调用start()方法,线程已开启,进入就绪状态,争抢cpu时间片。

3.运行状态(Running):

线程抢到了cpu时间片,开始执行线程中的逻辑,就绪态是进入到运行状态的唯一入口。

4.阻塞状态(interrupt):

一个线程运行中受到某些操作的影响,暂时放弃了cpu的使用权,并不参与cpu时间片的争抢,进入阻塞状态。直到其进入就绪状态,才有机会继续争抢cpu时间片。阻塞又分为下面几种:
a. 等待阻塞:运行状态中的线程调用wait()方法,使线程进入阻塞状态。
b. 同步阻塞:线程获取同步锁synchronized失败,因为锁被其他资源占用。
c. 其他阻塞:通过调用线程的sleep()或join()方法或者是发出了IO请求,线程会进入到阻塞状态,当sleep()超时join()终止或超时,IO处理完毕是线程重入就绪状态。

5.死亡状态(Dead):线程执行完毕或者异常退出

image.png

4.开辟新线程

1.继承Thread类;
2.实现Runnable接口;

5.线程命名

image.png

6.线程休眠

public class ThreadMethod {
    public static void main(String[] args) {
        sleepMethod();
    }
    
    public static void sleepMethod(){
        MyThread2 thread = new MyThread2();
        thread.start();
    }
}

class MyThread2 extends Thread{
    
    public MyThread2(){}
    public MyThread2(String name){
        //super(name);
        this.setName(name);
    }
    
    public void run(){
        for (int i = 0; i < 10; i++) {
            System.out.println(i);
            try {
                Thread.sleep(1000);//毫秒值,休眠1秒
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
    }
}

7.优先级

/*线程优先级,设置优先级只是修改该线程抢到cpu时间片的概率
    并不是优先级高的一定能抢到
    线程优先级是[0,10]的整数,默认是5*/
    public static void threadPriority(){
        Runnable runnable = new Runnable() {
            @Override
            public void run() {
                // TODO Auto-generated method stub
                for (int i = 0; i < 10; i++) {
                    System.out.println(Thread.currentThread().getName()+":"+i);
                }
            }
        };
        
        Thread t1 = new Thread(runnable, "t1");
        Thread t2 = new Thread(runnable, "t2");
        //必须在start前设置
        t1.setPriority(10);
        t2.setPriority(1);
        
        t1.start();
        t2.start();
    }

8.常用方法——yield()

/*线程常用方法yield,让出cpu资源,回到就绪状态,重新争抢cpu资源
    礼让cpu使用权后下次抢到cpu的还可能是该线程*/
    public void threadYield(){
        Runnable r = new Runnable() {
            @Override
            public void run() {
                // TODO Auto-generated method stub
                for (int i = 0; i < 10; i++) {
                    System.err.println(Thread.currentThread().getName()+":"+i);
                    if (i == 3) {
                        Thread.yield();
                    }
                }
            }
        };
        
        Thread t1 = new Thread(r, "t1");
        Thread t2 = new Thread(r, "t2");
        t1.start();
        t2.start();
    }

持续更新中。。。

相关文章

网友评论

      本文标题:关于多线程的一些知识点(一)——基础

      本文链接:https://www.haomeiwen.com/subject/kwuamctx.html