[java进阶]——多线程Thread类,处理并发异常的方法(上

简介: [java进阶]——多线程Thread类,处理并发异常的方法

一、理解进程与线程

运行一个程序占用一个进程,程序中的子任务是线程,故一个进程可以有多个线程。

例如银行每一个窗口都在处理业务,但所有窗口存和取的钱都放在该银行保险柜里

🐒当下最火的并发编程

一个线程在运行时是会占用cpu内存的,如果该线程正待等待用户输入数据,那么用户不输入,cpu就要一直被占用,为了提高cpu的利用率,有了并发执行,线程抢占cpu,每个线程被选中执行的概率是随机的,这叫线程调度

拓展个概念:

每个线程被cpu选中执行的概率是随机的,这个过程叫做线程的调度,线程调度器会根据线程的优先级、执行状态、等待时间等因素来决定哪个线程可以被执行,从而实现对CPU资源的有效利用。

4核8线程的意思是有四个独立的核心一个核心有2个线程,每个任务可以在不同的核心上执行,每个任务的一个子任务就可以看作一个线程。

mian函数也是一个线程。

二、Thread类

java把线程相关的属性和方法封装到Thread类里面,可以利用该类创建线程对象

start 开启线程

setname 设置名称

getname 获取名称

sleep 休眠多少毫秒(静态)

currentThread 获取当前线程(静态)

setPriority 设置线程的优先级

setDaemon 设置为守护线程

🐒初步感受进程代码

class MyThread extends Thread{
    @Override
    public void run() {
        while (true){
            System.out.println("我是另一个线程");
            //休眠2秒
            try {
                Thread.sleep(2000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}
public class Test1 {
    public static void main(String[] args) throws InterruptedException {
        MyThread myThread = new MyThread();
        myThread.start();
        while (true){
            Thread.sleep(2000);//休眠两秒
            System.out.println("main线程");
        }
    }
}

main线程和另一个线程交替执行。

三、自定义线程的三种实现方式

3.1创建一个类继承Thread子类

重写里面的run方法 - 线程要处理的任务

创建该类

public class MyThread extends Thread{
    @Override
    public void run() {
        //线程要执行的方法
    }
}
public static void main(String[] args) {
        /*
        * 线程的第一种创建方式thread
        * 1.创建一个类继承thread
        * 2.重写里面的run方法
        * 3.创建该类
        *
        *
        * */
        MyThread t1 = new MyThread();
        MyThread t2 = new MyThread();
    }

3.2定义一个runable接口的实现类

重写run方法

创建runable实现类

据实现类创建Thread类

public class MyRun implements Runnable{
    @Override
    public void run() {
        //线程要执行的方法
    }
}
public static void main(String[] args) {
        /*
        * 线程的第二种实现方式
        * 1.定义一个类实现runable接口
        * 2.创建该接口的实现类
        * 3.创建thread类,把实现类传入
        * */
        MyRun myRun = new MyRun();
        Thread thread = new Thread(myRun);
    }

3.3定义一个类实现callable接口

重写call方法

创建callable实现类 - 任务

创建futuretask对象 -  管理线程结果

创建thread对象 - 创建线程

相关文章
|
6天前
|
缓存 安全 Java
《从头开始学java,一天一个知识点》之:输入与输出:Scanner与System类
你是否也经历过这些崩溃瞬间?三天教程连`i++`和`++i`都说不清,面试时`a==b`与`equals()`区别大脑空白,代码总是莫名报NPE。这个系列就是为你打造的Java「速效救心丸」!每天1分钟,地铁通勤、午休间隙即可学习。直击高频考点和实际开发中的“坑位”,拒绝冗长概念,每篇都有可运行代码示例。涵盖输入输出基础、猜数字游戏、企业编码规范、性能优化技巧、隐藏技能等。助你快速掌握Java核心知识,提升编程能力。点赞、收藏、转发,助力更多小伙伴一起成长!
36 19
|
7天前
|
缓存 安全 Java
《从头开始学java,一天一个知识点》之:字符串处理:String类的核心API
🌱 **《字符串处理:String类的核心API》一分钟速通!** 本文快速介绍Java中String类的3个高频API:`substring`、`indexOf`和`split`,并通过代码示例展示其用法。重点提示:`substring`的结束索引不包含该位置,`split`支持正则表达式。进一步探讨了String不可变性的高效设计原理及企业级编码规范,如避免使用`new String()`、拼接时使用`StringBuilder`等。最后通过互动解密游戏帮助读者巩固知识。 (上一篇:《多维数组与常见操作》 | 下一篇预告:《输入与输出:Scanner与System类》)
37 11
|
10月前
|
安全 Java
深入理解Java并发编程:线程安全与性能优化
【2月更文挑战第22天】在Java并发编程中,线程安全和性能优化是两个重要的主题。本文将深入探讨这两个主题,包括线程安全的基本概念,如何实现线程安全,以及如何在保证线程安全的同时进行性能优化。
75 0
|
10月前
|
存储 安全 Java
深入理解Java并发编程:线程安全与锁机制
【5月更文挑战第31天】在Java并发编程中,线程安全和锁机制是两个核心概念。本文将深入探讨这两个概念,包括它们的定义、实现方式以及在实际开发中的应用。通过对线程安全和锁机制的深入理解,可以帮助我们更好地解决并发编程中的问题,提高程序的性能和稳定性。
|
7月前
|
存储 安全 Java
解锁Java并发编程奥秘:深入剖析Synchronized关键字的同步机制与实现原理,让多线程安全如磐石般稳固!
【8月更文挑战第4天】Java并发编程中,Synchronized关键字是确保多线程环境下数据一致性与线程安全的基础机制。它可通过修饰实例方法、静态方法或代码块来控制对共享资源的独占访问。Synchronized基于Java对象头中的监视器锁实现,通过MonitorEnter/MonitorExit指令管理锁的获取与释放。示例展示了如何使用Synchronized修饰方法以实现线程间的同步,避免数据竞争。掌握其原理对编写高效安全的多线程程序极为关键。
95 1
|
8月前
|
安全 Java 开发者
Java并发编程中的线程安全问题及解决方案探讨
在Java编程中,特别是在并发编程领域,线程安全问题是开发过程中常见且关键的挑战。本文将深入探讨Java中的线程安全性,分析常见的线程安全问题,并介绍相应的解决方案,帮助开发者更好地理解和应对并发环境下的挑战。【7月更文挑战第3天】
139 0
|
9月前
|
安全 Java 开发者
Java并发编程中的线程安全策略
在现代软件开发中,Java语言的并发编程特性使得多线程应用成为可能。然而,随着线程数量的增加,如何确保数据的一致性和系统的稳定性成为开发者面临的挑战。本文将探讨Java并发编程中实现线程安全的几种策略,包括同步机制、volatile关键字的使用、以及java.util.concurrent包提供的工具类,旨在为Java开发者提供一系列实用的方法来应对并发问题。
71 0
|
10月前
|
安全 Java 容器
Java一分钟之-并发编程:线程安全的集合类
【5月更文挑战第19天】Java提供线程安全集合类以解决并发环境中的数据一致性问题。例如,Vector是线程安全但效率低;可以使用Collections.synchronizedXxx将ArrayList或HashMap同步;ConcurrentHashMap是高效线程安全的映射;CopyOnWriteArrayList和CopyOnWriteArraySet适合读多写少场景;LinkedBlockingQueue是生产者-消费者模型中的线程安全队列。注意,过度同步可能影响性能,应尽量减少共享状态并利用并发工具类。
96 2
|
10月前
|
安全 Java
Java中的并发编程:理解并发性与线程安全
Java作为一种广泛应用的编程语言,在并发编程方面具有显著的优势和特点。本文将探讨Java中的并发编程概念,重点关注并发性与线程安全,并提供一些实用的技巧和建议,帮助开发人员更好地理解和应用Java中的并发机制。
|
10月前
|
缓存 安全 Java
Java并发编程中的线程安全问题及解决方法
在Java编程中,线程安全是一个至关重要的问题,特别是在并发编程中。本文将探讨Java并发编程中常见的线程安全问题,包括数据竞争、死锁和内存可见性,并介绍了相应的解决方法,如使用同步锁、并发容器和原子类等技术,以确保多线程环境下程序的正确性和性能。
72 2

热门文章

最新文章