多线程

Posted 在劫

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了多线程相关的知识,希望对你有一定的参考价值。

多线程的概述
    进程:
          正在运行的程序,是系统进行资源分配和调用的独立单位
          每一个进程都有它自己的内存空间和系统资源
    线程:
          进程中的单个顺序控制流,是一条执行路径
          一个进程如果只有一条执行路径,则成为单线程程序
          一个进程如果有多条执行路径,则成为多线程程序。
          一个进程内可以执行多个任务,则每个任务是一个线程。
    多进程有什么意义?
          单进程计算机只能做一件事,现在的计算机同一时间段内可以执行多个任务,提高CPU的使用率。
    多线程有什么意义?
          多线程的存在,不是提高程序的执行速度,其实是为了提高应用程序的使用率。
          程序执行其实就是抢CPU的资源,CPU的执行权。
          多个进程是在抢这个资源,而其中的某一个进程如果执行路径比较多,就会有更高的几率抢到。
          无法保证线程在哪个时刻抢到资源,线程执行有随机性。

并发:逻辑上同时发生,指在某个时间内同时运行多个程序。
并行:物理上同时发生,指在某个时间点运行多个程序。、
Java程序运行原理
    java命令启动java虚拟机,启动JVM,等于启动一个应用程序,也就是启动一个进程。
    该进程会自动启动一个主线程,然后主线程去调用某个类的main方法,所以main方法运行在主线程中,
    再次之前程序都是单线程的。
    JVM是多线程,垃圾回收线程也要先东西,否则会很容易出现内存溢出。
    最少启动了主线程和垃圾回收线程两个线程。

  由于线程是依赖进程存在的,所以我们应该先调用一个进程。进程是由系统创建的,所以我们应该调用系统功能创建一个进程。
  Java是不能调用系统功能的,所以我们没办法直接实现多线程程序。Java可以调用C/C++写好的程序实现多线程,由C/C++调用系统功能创建进程,然后由Java去调用这样的东西,然后提供一些类供我们使用,我们就可以实现多线程程序了。
  Java提供的类:Thread(线程 是程序中的执行线程。Java 虚拟机允许应用程序并发地运行多个执行线程。)
两种方式实现多线程程序:
  1、一种方法是将类声明为 Thread 的子类。该子类应重写 Thread 类的 run 方法。接下来可以分配并启动该子类的实例

//继承Thread类实现多线程
public class ThreadTest extends Thread{
    public void run(){
        for(int i = 0; i < 20; i++){
            System.out.println(new Thread().getName() + "---" + i);
        }
    }
    public static void main(String[] args) {
        ThreadTest t = new ThreadTest();
        t.start();
    }
}

  2、声明实现 Runnable 接口的类。该类然后实现 run 方法。然后可以分配该类的实例,在创建 Thread 时作为一个参数来传递并启动

//实现Runnable接口实现多线程
public class RunableDemo implements Runnable{
    public static void main(String[] args) {
        //创建实现接口类对象
        RunableDemo rd = new RunableDemo();
        //把对象传入Thread类中
        Thread t = new Thread(rd);
        t.start();
    }
    public void run() {
        for(int i = 0; i < 10; i++){
            System.out.println(new Thread().getName() + "---" + i);
        }
    }
}

 

以上是关于多线程的主要内容,如果未能解决你的问题,请参考以下文章

线程学习知识点总结

多个请求是多线程吗

python小白学习记录 多线程爬取ts片段

多线程编程

多线程编程

python多线程