带你玩转Java多线程(Ⅰ)

发布于 2019-09-18 09:49:57

1.线程概述

1.1线程相关概念

进程

进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是操作系统进行资源分配与调度的基本单位.

可以把进程简单的理解为正在操作系统中运行的一个程序.

JAVA多线程

线程

线程(thread)是进程的一个执行单元,一个线程就是进程中一个单一顺序的控制流,进程的一个执行分支

进程和线程之间的关系

一个进程至少有一个线程.一个进程中也可以有多个线程. 可以理解为进程包含线程
例如:一个杀毒软件是一个进程,杀毒软件可以同时进行杀毒和清理垃圾,(杀毒和清理垃圾可以理解为线程)

主线程与子线程

JVM启动时会创建一个主线程,该主线程负责执行main方法,主线程就是运行main方法的线程

Java中的线程不孤立的,线程之间存在一些联系.如果在A线程中创建了B线程,称B线程为A线程的子线程,相应的A线程就是B线程的父线程

那么什么是串行,并发与并行呢?

串行(Sequential) : 所有任务逐个执行

并发(Concurrent) : 同一时间段内执行

并行(parallel) : 同一时间点

JAVA串行 并发 并行

并发可以提高以事物的处理效率, 即一段时间内可以处理或者完 成更多的事情.

并行是一种更为严格,理想的并发

从硬件角度来说, 如果单核CPU,一个处理器一次只能执行一个线程的情况下,处理器可以使用时间片轮转技术,可以让CPU快速的在各个线程之间进行高速切换,对于用来来说,感觉是三个线程在同时执行. 如果是多核心CPU,可以为不同的线程分配不同的CPU内核.

1.2 线程的创建与启动

创建线程的两种方式:
定义 Thread 类的子类
定义一个 Runnable 接口的实现类
这两种创建线程的方式没有本质的区别

方式一:

// 1. 继承Thread
public class MyThread extends Thread {

    // 2.重写Thread类中的run方法


    @Override
    public void run() {
        // 子线程要执行的内容
        System.out.println("======我是子线程=====");
    }
}
public class Test1 {

    public static void main(String[] args) {

        System.out.println("JVM启动main线程,main线程执行main方法");

        // 创建子线程对象MyThread
        MyThread myThread = new MyThread();

        // 启动线程
        myThread.start();

        /**
         * 调用线程的start()方法来启动线程,启动线程的实质就是请求JVM运行相应的线程,这个线程具体在什么时候运行由线程调度器(Scheduler)决定
         * 需要注意的是:
         * start()方法调用结束并不意味着子线程开始运行
         * 新开启的线程会执行run()方法
         * 如果开启了多个线程,start()调用的顺序并不一定就是线程启动的顺序,多线程运行结果与代码执行顺序或调用顺序无关
         */

        System.out.println("main主线程以后的其他代码");
    }
}

运行结果:
image.png

0 条评论

发布
问题