Java多线程基本概念

简介: 进程、线程是动词,相当于动词(执行)。程序:静态代码,是应用程序执行的蓝本。进程:程序的一次动态执行。(代码加载、执行、执行完毕)=>

多线程

进程、线程是动词,相当于动词(执行)。

程序:静态代码,是应用程序执行的蓝本。

进程:程序的一次动态执行。(代码加载、执行、执行完毕)=>

进程:产生、发展、消亡

操作系统:同时管理计算机中的多个进程(多个进程轮流使用CPU资源、多个进程共享操作系统所管理的资源)。

线程:是比进程更小的执行单位,没有进程就不会有线程、线程是运行在进程中的小线程、一个进程在执行过程中可以产生多个线程。每个线程(产生、发展、消亡),线程间也可以共享进程中的某些内存单元(包括代码与数据)

多线程:一个应用程序中同时存在几个执行体。

主线程:当JVM加载代码,发现main方法后,就会启动一个线程,这个线程称为“主线程”(main线程),该线程负责执行main方法。

main方法中没有创建其他线程:当main方法执行完最后一个语句,即main方法返回时,JVM就会结束我们的java应用程序。

main方法中有创建其他线程:JVM就要在主线程和其它线程之间轮流切换,保证每个线程都有机会使用CPU资源,main方法及时执行完最后的语句(主线程结束),JVM也不会结束java应用程序,JVM一直要等到java应用程序中的所有线程都结束之后,才结束java应用程序。

Java语言使用Thread类及其子类的对象表示线程,新建的线程在它的一个完整的生命周期中通常要经历4种状态,即新建、运行、中断、死亡

新建:当一个Thread类或其子类的对象被声明并创建时,新生的线程对象处于新建状态。此时它已经有了相应的内存空间和其它资源。

线程创建后仅仅是占有了内存资源,在JVM管理的线程中还没有这个线程,此线程必须调用start()方(从父类继承的方法)通知JVM,这样JVM就会知道又有一个新线程排队等候切换了。

运行:当JVM将CPU使用权切换给该线程时,此线程就可以脱离创建它的主线程独立开始自己的生命周期了。

当JVM将CPU使用权切换给线程时,如果线程是Thread的子类创建的,该类中的run()方法就立刻执行,run方法规定了该线程的具体使命,由于Thread类中的run()方法没有具体内容,所以需要重写run()方法

中断:(1)JVM将CPU资源从当前线程切换给其它线程。

          (2) 线程在使用CPU资源期间,执行了sleep(int millsecond)方法,使当前线程进入休眠状态。

          (3)线程使用CPU资源期间,执行了wait()方法,使得当前线程进入等待状态。

          (4)线程使用CPU资源期间,执行某个操作进入阻塞状态。

死亡:线程释放了实体,即释放分配给线程对象的内存。死亡有下面两种情况。

线程执行完:即执行完了run()方法中的全部语句。

线程被强制终止。

Thread的构造方法:Thread的构造方法的参数是一个Runnable类型的接口,因此,在创建线程对象时必须向构造方法的参数传递一个实现Runnable接口类的实例,该实例对象称作所创建线程的目标对象,当线程调用start()方法后,一旦轮到它来享用CPU资源,目标对象就会自动调用接口中的run()方法(接口回调),这一过程是自动实现的,用户程序只需要让线程调用start方法即可。

如果某个线程死亡,那么该线程将不加入JVM切换的行列中。

创建线程

创建线程有两种方法,一种是使用Thread的构造方法,一种是不使用Thread发构造方法。

当线程调用start()方法后,一旦轮到它来享用CPU资源,目标对象就会自动调用接口中的run()方法,这一过程是自动实现的,用户程序只需要让线程调用start方法即可。

不使用Thread的构造方法

public class demo1 {
  public static void main(String[] args) {
    demo2 d2=new demo2();
    demo3 d3=new demo3();
    d2.start();
    d3.start();
    for(int i=1;i<20;i++){
      System.out.println("1");
    }
  }
}
public class demo2 extends Thread{//继承Thread,成为其子类
  public void run(){
    for(int i=1;i<20;i++){
      System.out.println("2");
    }
  }
}
public class demo3 extends Thread {
  public void run(){
    for(int i=1;i<20;i++){
      System.out.println("3");
    }
  }
}

使用Thread的构造方法

public class A {
  public static void main(String[] args) {
    Thread tb;
    Thread tc;
    B b;
    C c;
    b=new B();
    c=new C();
    tb=new Thread(b);//Thread构造方法需要传一个接口变量,这里传的是实现接口的类的实例,进而实现接口回调
    tc=new Thread(c);
    tb.start();//启动线程
    tc.start();//启动线程
    //run方法自动调用
    for(int i=1;i<=20;i++){
      System.out.println("1");
    }
  }
}
class B implements Runnable{//实现接口
  public void run(){
    for(int i=1;i<=20;i++){
      System.out.println("2");
    }
  }
}
class C implements Runnable{
  public void run(){
    for(int i=1;i<=20;i++){
      System.out.println("3");
    }
  }
}

创建线程–>调用start()方法–>重写run()方法。

相关文章
|
2月前
|
设计模式 消息中间件 安全
【JUC】(3)常见的设计模式概念分析与多把锁使用场景!!理解线程状态转换条件!带你深入JUC!!文章全程笔记干货!!
JUC专栏第三篇,带你继续深入JUC! 本篇文章涵盖内容:保护性暂停、生产者与消费者、Park&unPark、线程转换条件、多把锁情况分析、可重入锁、顺序控制 笔记共享!!文章全程干货!
318 1
|
2月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
198 1
|
2月前
|
Java 编译器 Go
【Java】(5)方法的概念、方法的调用、方法重载、构造方法的创建
Java方法是语句的集合,它们在一起执行一个功能。方法是解决一类问题的步骤的有序组合方法包含于类或对象中方法在程序中被创建,在其他地方被引用方法的优点使程序变得更简短而清晰。有利于程序维护。可以提高程序开发的效率。提高了代码的重用性。方法的名字的第一个单词应以小写字母作为开头,后面的单词则用大写字母开头写,不使用连接符。例如:addPerson。这种就属于驼峰写法下划线可能出现在 JUnit 测试方法名称中用以分隔名称的逻辑组件。
222 4
|
2月前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
223 1
|
3月前
|
数据采集 存储 弹性计算
高并发Java爬虫的瓶颈分析与动态线程优化方案
高并发Java爬虫的瓶颈分析与动态线程优化方案
Java 数据库 Spring
172 0
|
3月前
|
算法 Java
Java多线程编程:实现线程间数据共享机制
以上就是Java中几种主要处理多线程序列化资源以及协调各自独立运行但需相互配合以完成任务threads 的技术手段与策略。正确应用上述技术将大大增强你程序稳定性与效率同时也降低bug出现率因此深刻理解每项技术背后理论至关重要.
282 16
|
4月前
|
缓存 并行计算 安全
关于Java多线程详解
本文深入讲解Java多线程编程,涵盖基础概念、线程创建与管理、同步机制、并发工具类、线程池、线程安全集合、实战案例及常见问题解决方案,助你掌握高性能并发编程技巧,应对多线程开发中的挑战。
|
4月前
|
数据采集 存储 前端开发
Java爬虫性能优化:多线程抓取JSP动态数据实践
Java爬虫性能优化:多线程抓取JSP动态数据实践
|
5月前
|
Java API 调度
从阻塞到畅通:Java虚拟线程开启并发新纪元
从阻塞到畅通:Java虚拟线程开启并发新纪元
377 83