java学习之高级语法(十五)----- 线程实现方式

简介: java学习之高级语法(十五)----- 线程实现方式

 多线程

▶ 一些名词解释

并发:指两个或多个事件在同一个时间段内发生

并行:指两个或多个事件在同一时刻发生(同时发生)

内存:所有的应用程序都需要进入到内存中执行,临时存储RAM

硬盘:永久存储ROM

进程:指一个内存中运行的应用程序,每个进程都有一个独立的内存空间,一个应用程序可以同时运行多个进程;进程也是程序的一次执行过程,是系统运行程序的基本单位,系统运行一个程序即是一个进程从创建、运行、消亡的过程。

线程:线程是进程中的一个执行单元,负责当前进程中程序的执行,一个进程中至少有一个线程。一个进程中是可以有多个线程的,这个应用程序也可以称为多线程程序。

多线程好处

                    1. 效率高

                    2. 多个线程之间互不影响

简而言之:一个程序运行后至少有一个进程,一个进程中可以包含多个线程

CPU:中央处理器,对数据进行计算,指挥电脑中软件和硬件干活

CPU的分类:AMD、Inter Core(核心) i7 8866 4核心8线程

线程调度

(1)分时调度

所有线程轮流使用CPU的使用权,平均分配给每个线程占用CPU的时间

(2)抢占式调度

优先让优先级高的线程使用CPU,如果线程的优先级相同,那么会随机选择一个(线程随机性),java使用的为抢占式调度

▶ 创建线程类

主线程:执行主(main)方法的线程

单线程程序:java程序中只有一个线程,执行从main方法开始,从上到下依次执行

JVM执行main方法,main方法会进入到栈内存,JVM会找操作系统开辟一条main方法通向CPU的执行路径,CPU就可以通过这个路径来执行main方法,而这个路径有一个名字,叫main(主)线程。

●  创建多线程程序的第一种方式:创建Thread类的子类

java.lang.Thread类:是描述线程的类,想要实现多线程程序就必须继承Thread类

实现步骤:

(1)创建一个Thread类的子类

(2)在Thread类的子类中重写Thread类中的run方法,设置线程任务(开启线程要做什么?)

(3)创建Thread类的子类对象

(4)调用Thread类中的方法start方法,开启新的线程,执行run方法

        void start() 使用该线程开始执行 ;Java虚拟机调用该线程的run方法

        结果是两个线程并发地运行 ; 当前线程(main线程)和另一个线程(创建的新线程,执行其run方法)

        多次启动一个线程是非法的,特别是当线程已经结束执行后,不能再重新启动

java程序属于抢占式调度,哪个线程的优先级高,哪个线程就优先执行,同一个优先级,随机选择一个执行。

第一种创建多线程程序方式的代码展示在“ 多线程原理中的随机性打印结果 ”处

●  创建多线程程序的第二种方式:实现Runnable接口

java.lang.Runnable

Runnable 接口应该由那些打算通过某一线程执行其实例的类来实现,类必须定义一个称为 run 的无参数方法。

java.lang.Thread 类的构造方法

       Thread( Runnable target )  分配新的 Thread 对象

       Thread( Runnable target ,String name )  分配新的 Thread 对象

实现步骤:

(1)创建一个 Runnable 接口的实现类

(2)在实现类中重写 Runnable 接口的 run 方法,设置线程任务

(3)创建一个 Runnable 接口的实现类对象

(4)创建 Thread 类对象,构造方法中传递 Runnable 接口的实现类对象

(5)调用 Thread 类中的start方法,开启新的线程执行 run 方法

image.gif编辑

image.gif编辑

输出 :  

           image.gif编辑

●  Thread 和 Runnable 的区别

实现Runnable接口创建多线程程序的好处:

(1)避免了单继承的局限性

        一个类只能继承一个类(一个孩子只能有一个亲爹),类继承了Thread类就不能继承其他的类

        实现了Runnable接口,还可以继承其他的类,实现其他的接口

(2)增强了程序的扩展性,降低了程序的耦合性(解耦)

        实现 Runnable 接口的方式,把设置线程任务和开启新线程进行了分离

        实现类中,重写了run方法:用来设置线程任务

        创建 Thread 类对象,调用start方法:用来开启新线程

▶  多线程原理

1. 随机性打印结果

      image.gif编辑

          image.gif编辑

输出结果:

                 image.gif编辑

分析上面的主方法代码:

(1)JVM执行main方法,找OS开辟一条main方法通向CPU的路径,这个路径叫 main线程 / 主线程,CPU通过这个线程即这个路径可以执行main方法;

(2)main方法中创建了一个Thread类的子类MyThread对象,开辟一条通向CPU的新路径用来执行run方法,通过对象.start()来执行 run 方法;

(3)对于CPU而言,就有了两条执行的路径,CPU就有了选择的权利,CPU喜欢谁就会执行那条路径,无法控制CPU所以就有了程序的随机打印结果。

两个线程,一个main线程,一个新线程一起抢夺CPU的执行权(执行时间),谁抢到了就执行谁对应的代码

2. 多线程内存图解

image.gif编辑

▶  Thread类的常用方法

1. 获取线程的名称 :

(1)使用Thread类中的方法getName()

         String getName()  返回该线程的名称

(2)可以先获取到当前正在执行的线程,使用线程中的方法 getName() 获取线程的名称

         static Thread currentThread() 返回对当前正在执行的线程对象的引用

2. 设置线程名称

(1)使用 Thread类 中的方法 setName(名字)

         void setName( String name )改变线程名称,使之与参数 name 相同

(2)创建一个带参数的构造方法,参数传递线程的名称,调用父类的带参构造方法,把线程名称传递给父类,让父类(Thread)给子线程起一个名字

         Thread( String name )分配的 Thread 对象

        image.gif编辑

       image.gif编辑

3. sleep方法

  public static void sleep(long millis) :使当前正在执行的线程以指定的毫秒数暂停(暂时停止执行),毫秒数结束之后,线程继续执行

        image.gif编辑

▶  匿名内部类方式实现线程的创建

   匿名:没有名字

   内部类:写在其他类内部的类

   匿名内部类作用:简化代码

          把子类继承父类,重写父类的方法,创建子类对象合成一步完成

          把实现类实现接口,重写接口中的方法,创建实现类对象合成一步完成

   匿名内部类的最终产物:子类 / 实现类对象,而这个类没有名字

   格式:

            new  父类 / 接口() {

                    重复父类 / 接口中的方法

             } ;

image.gif编辑

相关文章
|
10天前
|
Java
Java—多线程实现生产消费者
本文介绍了多线程实现生产消费者模式的三个版本。Version1包含四个类:`Producer`(生产者)、`Consumer`(消费者)、`Resource`(公共资源)和`TestMain`(测试类)。通过`synchronized`和`wait/notify`机制控制线程同步,但存在多个生产者或消费者时可能出现多次生产和消费的问题。 Version2将`if`改为`while`,解决了多次生产和消费的问题,但仍可能因`notify()`随机唤醒线程而导致死锁。因此,引入了`notifyAll()`来唤醒所有等待线程,但这会带来性能问题。
Java—多线程实现生产消费者
|
12天前
|
安全 Java Kotlin
Java多线程——synchronized、volatile 保障可见性
Java多线程中,`synchronized` 和 `volatile` 关键字用于保障可见性。`synchronized` 保证原子性、可见性和有序性,通过锁机制确保线程安全;`volatile` 仅保证可见性和有序性,不保证原子性。代码示例展示了如何使用 `synchronized` 和 `volatile` 解决主线程无法感知子线程修改共享变量的问题。总结:`volatile` 确保不同线程对共享变量操作的可见性,使一个线程修改后,其他线程能立即看到最新值。
|
12天前
|
消息中间件 缓存 安全
Java多线程是什么
Java多线程简介:本文介绍了Java中常见的线程池类型,包括`newCachedThreadPool`(适用于短期异步任务)、`newFixedThreadPool`(适用于固定数量的长期任务)、`newScheduledThreadPool`(支持定时和周期性任务)以及`newSingleThreadExecutor`(保证任务顺序执行)。同时,文章还讲解了Java中的锁机制,如`synchronized`关键字、CAS操作及其实现方式,并详细描述了可重入锁`ReentrantLock`和读写锁`ReadWriteLock`的工作原理与应用场景。
|
13天前
|
安全 Java 编译器
深入理解Java中synchronized三种使用方式:助您写出线程安全的代码
`synchronized` 是 Java 中的关键字,用于实现线程同步,确保多个线程互斥访问共享资源。它通过内置的监视器锁机制,防止多个线程同时执行被 `synchronized` 修饰的方法或代码块。`synchronized` 可以修饰非静态方法、静态方法和代码块,分别锁定实例对象、类对象或指定的对象。其底层原理基于 JVM 的指令和对象的监视器,JDK 1.6 后引入了偏向锁、轻量级锁等优化措施,提高了性能。
35 3
|
13天前
|
存储 安全 Java
Java多线程编程秘籍:各种方案一网打尽,不要错过!
Java 中实现多线程的方式主要有四种:继承 Thread 类、实现 Runnable 接口、实现 Callable 接口和使用线程池。每种方式各有优缺点,适用于不同的场景。继承 Thread 类最简单,实现 Runnable 接口更灵活,Callable 接口支持返回结果,线程池则便于管理和复用线程。实际应用中可根据需求选择合适的方式。此外,还介绍了多线程相关的常见面试问题及答案,涵盖线程概念、线程安全、线程池等知识点。
93 2
|
21天前
|
安全 Java API
java如何请求接口然后终止某个线程
通过本文的介绍,您应该能够理解如何在Java中请求接口并根据返回结果终止某个线程。合理使用标志位或 `interrupt`方法可以确保线程的安全终止,而处理好网络请求中的各种异常情况,可以提高程序的稳定性和可靠性。
46 6
|
30天前
|
安全 算法 Java
Java多线程编程中的陷阱与最佳实践####
本文探讨了Java多线程编程中常见的陷阱,并介绍了如何通过最佳实践来避免这些问题。我们将从基础概念入手,逐步深入到具体的代码示例,帮助开发者更好地理解和应用多线程技术。无论是初学者还是有经验的开发者,都能从中获得有价值的见解和建议。 ####
|
30天前
|
Java 调度
Java中的多线程编程与并发控制
本文深入探讨了Java编程语言中多线程编程的基础知识和并发控制机制。文章首先介绍了多线程的基本概念,包括线程的定义、生命周期以及在Java中创建和管理线程的方法。接着,详细讲解了Java提供的同步机制,如synchronized关键字、wait()和notify()方法等,以及如何通过这些机制实现线程间的协调与通信。最后,本文还讨论了一些常见的并发问题,例如死锁、竞态条件等,并提供了相应的解决策略。
50 3
|
1月前
|
监控 Java 开发者
深入理解Java中的线程池实现原理及其性能优化####
本文旨在揭示Java中线程池的核心工作机制,通过剖析其背后的设计思想与实现细节,为读者提供一份详尽的线程池性能优化指南。不同于传统的技术教程,本文将采用一种互动式探索的方式,带领大家从理论到实践,逐步揭开线程池高效管理线程资源的奥秘。无论你是Java并发编程的初学者,还是寻求性能调优技巧的资深开发者,都能在本文中找到有价值的内容。 ####
|
1月前
|
监控 Java 数据库连接
Java线程管理:守护线程与用户线程的区分与应用
在Java多线程编程中,线程可以分为守护线程(Daemon Thread)和用户线程(User Thread)。这两种线程在行为和用途上有着明显的区别,了解它们的差异对于编写高效、稳定的并发程序至关重要。
37 2