多线程
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); } } }
以上是关于多线程的主要内容,如果未能解决你的问题,请参考以下文章