JAVA线程入门简介

简介: JAVA线程入门简介



什么是程序?

是为完成特定任务,用某种语言编写的一组指令集合。`

简单的说:就是我们写的代码


什么是进程?

进程是指运行中的程序,操作系统会为进程分配内存空间

进程是你程序的一次执行过程,或是正在运行的一个程序,是动态 过程,它自身的产生、存在和消亡过程

启动一个程序

启动两个程序


结束进程之后,进程就随之消亡


什么是线程?

1.线程是由进程创建的,是进程的实体

2.一个进程可以拥有多个线程

当你在使用百度网盘下载东西的时候,你可以将百度网盘的整体界面看成一个进程,当它每次下载一个东西的时候对应启动一个线程

单线程与多线程

单线程:同一时刻,只允许执行一个线程

多线程:同一时刻,可以执行多个线程,比如百度网盘下载东西

并发与并行

并发:同一时刻,多个任务交替执行,造成一种你好像看起来它们同时的错觉,简单的说,单核cpu实现的多任务就是并发

并行:同一时刻,多个任务同时执行,多核cpu可以实现并行

你可以将cpu想象成我们的大脑,一个人只有一个,你能遍看电视遍写作业吗,在你心里可能感觉你可以有这个能力,但其实你这是在看电视和做作业的过程中来回不断切换

并发和并行可能同时存在


线程的使用

用java查看有多少个cpu

示例代码:

public class CpuNum {
    public static void main(String[] args) {
        Runtime runtime = Runtime.getRuntime();
        //获取当前电脑的cpu数量
        int cpuNums = runtime.availableProcessors();
        System.out.println("当前有cpu个数 = "+cpuNums);
    }
}

运行结果:



创建线程的两种方式

继承Thread类,重写run方法

示例:每隔1s输出一句小猫喵喵叫

public class Thread01 {
    public static void main(String[] args) {
        //创建Cat对象,可以当线程使用
        Cat cat = new Cat();
        cat.start();//启动线程
    }
}
//1.当一个类继承了Thread类,该类就可以当作线程使用
//2.我们会重写run方法,写上自己的业务代码
//3.run Thread 类 实现了Runnable接口的run方法
/* @Override
public void run() {
if (target != null) {
target.run();
}
}*/
class Cat extends Thread{
    int times  = 0;
    @Override
    public void run() {//重写run方法,写上自己的业务逻辑
        while(true) {
            //该线程每隔1秒,在控制台输出”喵喵,我是小猫咪“
            System.out.println("喵喵,我是小猫咪"+(++times));
            //让该线程休眠1秒
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}

示例:在上述的基础之后,加上一个仅仅输出8次的条件

public class Thread01 {
    public static void main(String[] args) {
        //创建Cat对象,可以当线程使用
        Cat cat = new Cat();
        cat.start();//启动线程
    }
}
//1.当一个类继承了Thread类,该类就可以当作线程使用
//2.我们会重写run方法,写上自己的业务代码
//3.run Thread 类 实现了Runnable接口的run方法
/* @Override
public void run() {
if (target != null) {
target.run();
}
}*/
class Cat extends Thread{
    int times  = 0;
    @Override
    public void run() {//重写run方法,写上自己的业务逻辑
        while(true) {
            //该线程每隔1秒,在控制台输出”喵喵,我是小猫咪“
            System.out.println("喵喵,我是小猫咪"+(++times));
            //让该线程休眠1秒
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            if(times==8){
                break;//当times 到80,退出while,这时线程就会结束
            }
        }
    }
}

实现Runnable接口,重写run方法

实现案例:请编写程序,该程序可以每隔1秒,在控制台输出"hi",当输出10次后,自动退出

public class Thread02 {
    public static void main(String[] args) {
        Dog dog = new Dog();
        //dog.start();这里不能调用start
        //创建Thread对象,把dog对象(实现Runnable),放入Thread
        Thread thread = new Thread(dog);
        thread.start();
    }
}
class Dog implements Runnable{//通过实现Runnable接口,并发线程
    int count = 0;
    @Override
    public void run() {//普通方法
        while(true){
            System.out.println("小狗汪汪叫..hi"+(++count)+Thread.currentThread().getName());
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            if(count==10){
                break;
            }
        }
    }
}

这里底层使用了设计模式(代理模式)
模拟代理类

//线程代理
class ThreadProxy implements Runnable{//把Proxy当成ThreadProxy
    private Runnable target = null;//属性,类型是Runnable
    @Override
    public void run() {
        if(target!=null){
            target.run();
        }
    }
    public ThreadProxy(Runnable target){
        this.target = target;
    }
    public void start(){
        start0();//这个方法时真正实现多线程方法
    }
    public void start0(){
        run();
    }
}

多线程机制

多个线程同时进行

示例代码:

public class Thread01 {
    public static void main(String[] args) throws InterruptedException {
        //创建Cat对象,可以当线程使用
        Cat cat = new Cat();
        cat.start();//启动线程
        //说明:当main线程启动了一个子线程 Thread-0,主线程不会阻塞,会继续执行
        //这时,主线程和子线程是交替执行
        System.out.println("主线程继续执行"+Thread.currentThread().getName());//名字main
        for (int i=0;i<10;i++){
            System.out.println("主线程 i="+i);
            //让主线程休眠
            Thread.sleep(1000);
        }
    }
}
//1.当一个类继承了Thread类,该类就可以当作线程使用
//2.我们会重写run方法,写上自己的业务代码
//3.run Thread 类 实现了Runnable接口的run方法
/* @Override
public void run() {
if (target != null) {
target.run();
}
}*/
class Cat extends Thread{
    int times  = 0;
    @Override
    public void run() {//重写run方法,写上自己的业务逻辑
        while(true) {
            //该线程每隔1秒,在控制台输出”喵喵,我是小猫咪“
            System.out.println("喵喵,我是小猫咪"+(++times)+"线程名 = "+Thread.currentThread().getName());
            //让该线程休眠1秒
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            if(times==80){
                break;//当times 到80,退出while,这时线程就会结束
            }
        }
    }
}


执行流程,当我们去运行的时候,打开一个进程,由这个进程给我们启动了一个主线程,主线程里面有开启了一个子线程,等所有线程均挂掉的时候,进程才随之结束,只要有一个线程存活,应用程序就还没有结束

为社么是start?

run方法就是一个普通的方法,没有真正的启动一个线程,就会把run方法执行完毕才向下执行,即会阻塞


源码解析

(1)

public synchronized void start(){
  start0();
}

(2)

//start0()是本地方法,是jvm调用,底层是c/c++

//真正实现多线程的效果,是start0(),而不是run

private native void start0();

start()方法调用start0()方法后,该线程并不一定会立马执行,只是将线程变成了可运行状态。具体什么时候执行,取决于CPU,由CPU统一调度。


目录
相关文章
|
19天前
|
Java 开发者
Java多线程编程中的常见误区与最佳实践####
本文深入剖析了Java多线程编程中开发者常遇到的几个典型误区,如对`start()`与`run()`方法的混淆使用、忽视线程安全问题、错误处理未同步的共享变量等,并针对这些问题提出了具体的解决方案和最佳实践。通过实例代码对比,直观展示了正确与错误的实现方式,旨在帮助读者构建更加健壮、高效的多线程应用程序。 ####
|
5天前
|
监控 架构师 Java
Java虚拟机调优的艺术:从入门到精通####
本文作为一篇深入浅出的技术指南,旨在为Java开发者揭示JVM调优的神秘面纱,通过剖析其背后的原理、分享实战经验与最佳实践,引领读者踏上从调优新手到高手的进阶之路。不同于传统的摘要概述,本文将以一场虚拟的对话形式,模拟一位经验丰富的架构师向初学者传授JVM调优的心法,激发学习兴趣,同时概括性地介绍文章将探讨的核心议题——性能监控、垃圾回收优化、内存管理及常见问题解决策略。 ####
|
10天前
|
缓存 Java 开发者
Java多线程编程的陷阱与最佳实践####
本文深入探讨了Java多线程编程中常见的陷阱,如竞态条件、死锁和内存一致性错误,并提供了实用的避免策略。通过分析典型错误案例,本文旨在帮助开发者更好地理解和掌握多线程环境下的编程技巧,从而提升并发程序的稳定性和性能。 ####
|
5天前
|
监控 Java 开发者
深入理解Java中的线程池实现原理及其性能优化####
本文旨在揭示Java中线程池的核心工作机制,通过剖析其背后的设计思想与实现细节,为读者提供一份详尽的线程池性能优化指南。不同于传统的技术教程,本文将采用一种互动式探索的方式,带领大家从理论到实践,逐步揭开线程池高效管理线程资源的奥秘。无论你是Java并发编程的初学者,还是寻求性能调优技巧的资深开发者,都能在本文中找到有价值的内容。 ####
|
10天前
|
安全 Java 开发者
Java中的多线程编程:从基础到实践
本文深入探讨了Java多线程编程的核心概念和实践技巧,旨在帮助读者理解多线程的工作原理,掌握线程的创建、管理和同步机制。通过具体示例和最佳实践,本文展示了如何在Java应用中有效地利用多线程技术,提高程序性能和响应速度。
39 1
|
18天前
|
安全 Java 开发者
Java 多线程并发控制:深入理解与实战应用
《Java多线程并发控制:深入理解与实战应用》一书详细解析了Java多线程编程的核心概念、并发控制技术及其实战技巧,适合Java开发者深入学习和实践参考。
|
18天前
|
Java 开发者
Java多线程编程的艺术与实践####
本文深入探讨了Java多线程编程的核心概念、应用场景及实践技巧。不同于传统的技术文档,本文以实战为导向,通过生动的实例和详尽的代码解析,引领读者领略多线程编程的魅力,掌握其在提升应用性能、优化资源利用方面的关键作用。无论你是Java初学者还是有一定经验的开发者,本文都将为你打开多线程编程的新视角。 ####
|
17天前
|
存储 安全 Java
Java多线程编程中的并发容器:深入解析与实战应用####
在本文中,我们将探讨Java多线程编程中的一个核心话题——并发容器。不同于传统单一线程环境下的数据结构,并发容器专为多线程场景设计,确保数据访问的线程安全性和高效性。我们将从基础概念出发,逐步深入到`java.util.concurrent`包下的核心并发容器实现,如`ConcurrentHashMap`、`CopyOnWriteArrayList`以及`BlockingQueue`等,通过实例代码演示其使用方法,并分析它们背后的设计原理与适用场景。无论你是Java并发编程的初学者还是希望深化理解的开发者,本文都将为你提供有价值的见解与实践指导。 --- ####
|
20天前
|
安全 Java 开发者
Java多线程编程中的常见问题与解决方案
本文深入探讨了Java多线程编程中常见的问题,包括线程安全问题、死锁、竞态条件等,并提供了相应的解决策略。文章首先介绍了多线程的基础知识,随后详细分析了每个问题的产生原因和典型场景,最后提出了实用的解决方案,旨在帮助开发者提高多线程程序的稳定性和性能。
|
23天前
|
监控 安全 Java
Java中的多线程编程:从入门到实践####
本文将深入浅出地探讨Java多线程编程的核心概念、应用场景及实践技巧。不同于传统的摘要形式,本文将以一个简短的代码示例作为开篇,直接展示多线程的魅力,随后再详细解析其背后的原理与实现方式,旨在帮助读者快速理解并掌握Java多线程编程的基本技能。 ```java // 简单的多线程示例:创建两个线程,分别打印不同的消息 public class SimpleMultithreading { public static void main(String[] args) { Thread thread1 = new Thread(() -> System.out.prin