首页 Java java教程 Java多线程编程的方法总结(附示例)

Java多线程编程的方法总结(附示例)

Sep 27, 2018 pm 02:38 PM
java多线程

本篇文章给大家带来的内容是关于Java多线程的实现方法总结(附示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

1.什么时候使用多线程编程

一个任务在正常情况下是按顺序执行的,但是如果当前任务里有多个相似进程块(例如for,while语句),我们就可以考虑把这些代码块抽出来并行运行,无需阻塞

2.实现多线程的几种方式

一种是继承Thread类重写run方法,另一种是实现Runnable接口重写run方法

启动多线程很多情况下是为了处理并发进程,此时对于部分实时性要求不是那么高的业务需求,我们还可以通过实现队列的方式,异步实现。

3.举例

继承Thread

/**
 * 
* @ClassName: ThreadByEx  
* @Description: TODO
* @author Mr.jqCheng
* @date 2018年9月26日  
* */public class ThreadByEx extends Thread{

    @Override    public void run() {        // TODO Auto-generated method stub
        System.out.println("我是继承线程");
    }

}
登录后复制

实现Runnable

/**
 * 
* @ClassName: ThreadByRunnable  
* @Description: TODO
* @author Mr.jqCheng
* @date 2018年9月26日  
* */public class ThreadByRunnable implements Runnable{    /*public ThreadByRunnable() {
        this.run();
        // TODO Auto-generated constructor stub
    }*/

    public void run() {        // TODO Auto-generated method stub
        System.out.println("我是实现进程");
    }

}
登录后复制

测试:

/**
 * 
* @ClassName: Test  
* @Description: TODO
* @author Mr.jqCheng
* @date 2018年9月26日  
* */public class Test {    public static void main(String[] args) {        // 继承Thread启动的方法
        ThreadByEx t1 = new ThreadByEx();
        t1.start();// 启动线程        // 实现Runnable启动线程的方法
        ThreadByRunnable r = new ThreadByRunnable();
        Thread t2 = new Thread(r);
        t2.start();// 启动线程        //new ThreadByRunnable();    }

}
登录后复制

运行结果:

我是继承线程
我是实现进程

ok,简单的多线程实现方式完成了,在调用start()的时候,该进程已经进入可执行状态,等待系统执行。

线程处理的几个常用方法:

void interrupt():向线程发送中断请求,线程的中断状态将会被设置为true,如果当前线程被一个sleep调用阻塞,那么将会抛出interrupedException异常。

static boolean interrupted():测试当前线程(当前正在执行命令的这个线程)是否被中断。注意这是个静态方法,调用这个方法会产生一个副作用那就是它会将当前线程的中断状态重置为false。

boolean isInterrupted():判断线程是否被中断,这个方法的调用不会产生副作用即不改变线程的当前中断状态。

static Thread currentThread() : 返回代表当前执行线程的Thread对象。

守护进程

用来服务于不是服务进程的其他所有当前进程下的所有线程

实现deamon.setDaemon(true)就行,要在线程开启之前启用

举例

package com.orange.util;
/**
 * 
 * @ClassName: Test
 * @Description: TODO
 * @author Mr.jqCheng
 * @date 2018年9月26日
 *
 */
public class Test {
    public static void main(String[] args) {
        Thread deamon2 = new Thread(new DaemonRunner2(), "otherRunner");
        deamon2.start();// 启动线程
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        Thread deamon = new Thread(new DaemonRunner(), "DaemonRunner");
        // 设置为守护线程
        deamon.setDaemon(true);
        deamon.start();// 启动线程
    }
    static class DaemonRunner implements Runnable {
        public void run() {
            // TODO Auto-generated method stub
            try {
                Thread.sleep(300);
                Thread t = Thread.currentThread();
                System.out.println(t);
            } catch (Exception e) {
                e.printStackTrace();
            } finally {
                System.out.println("进入守护线程,说明现在还有其他线程在执行");
            }
        }
    }
    static class DaemonRunner2 implements Runnable {
        public void run() {
            // TODO Auto-generated method stub
            try {
                Thread.sleep(1500);
                System.out.println("我是其他线程");
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
}
登录后复制

执行结果:

Thread[DaemonRunner,5,main]
进入守护线程,说明现在还有其他线程在执行
我是其他线程

首先,先启动其他线程,需要耗时1500ms,同时,主线程耗时1000ms后,开始进入守护线程,此时其它线程还在运行,到了守护线程,耗时300ms,其他线程仍在执行,继续往下,守护线程执行完毕

但是如果我把守护线程的300ms改成500ms,会发生什么事呢?

出现过两种情况,毕竟在临界值

1.我是其他线程

2.Thread[DaemonRunner,5,main]
进入守护线程,说明现在还有其他线程在执行
我是其他线程

以上是Java多线程编程的方法总结(附示例)的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

详解Java中volatile关键字的使用场景及其作用 详解Java中volatile关键字的使用场景及其作用 Jan 30, 2024 am 10:01 AM

Java中volatile关键字的作用及应用场景详解一、volatile关键字的作用在Java中,volatile关键字用于标识一个变量在多个线程之间可见,即保证可见性。具体来说,当一个变量被声明为volatile时,任何对该变量的修改都会立即被其他线程所知晓。二、volatile关键字的应用场景状态标志volatile关键字适用于一些状态标志的场景,例如一

文件读取多线程加速性能的Java开发优化方法 文件读取多线程加速性能的Java开发优化方法 Jun 30, 2023 pm 10:54 PM

Java开发中,文件读取是一个非常常见且重要的操作。随着业务的增长,文件的大小和数量也不断增加。为了提高文件读取的速度,我们可以采用多线程的方式来并行读取文件。本文将介绍如何在Java开发中优化文件读取多线程加速性能。首先,在进行文件读取前,我们需要先确定文件的大小和数量。根据文件的大小和数量,我们可以合理地设定线程的数量。过多的线程数量可能会导致资源浪费,

Java多线程环境下的异常处理 Java多线程环境下的异常处理 May 01, 2024 pm 06:45 PM

多线程环境下异常处理的要点:捕捉异常:每个线程使用try-catch块捕捉异常。处理异常:在catch块中打印错误信息或执行错误处理逻辑。终止线程:无法恢复时,调用Thread.stop()终止线程。UncaughtExceptionHandler:处理未捕获异常,需要实现该接口并指定给线程。实战案例:线程池中的异常处理,使用UncaughtExceptionHandler来处理未捕获异常。

探索java多线程的工作原理和特点 探索java多线程的工作原理和特点 Feb 21, 2024 pm 03:39 PM

探索Java多线程的工作原理和特点引言:在现代计算机系统中,多线程已成为一种常见的并发处理方式。Java作为一门强大的编程语言,提供了丰富的多线程机制,使得程序员可以更好地利用计算机的多核处理器、提高程序运行效率。本文将探索Java多线程的工作原理和特点,并通过具体的代码示例来说明。一、多线程的基本概念多线程是指在一个程序中同时执行多个线程,每个线程处理不同

Java多线程性能优化指南 Java多线程性能优化指南 Apr 11, 2024 am 11:36 AM

Java多线程性能优化指南提供了五个关键优化点:减少线程创建和销毁开销避免不当的锁争用使用非阻塞数据结构利用Happens-Before关系考虑无锁并行算法

Java多线程调试技术揭秘 Java多线程调试技术揭秘 Apr 12, 2024 am 08:15 AM

多线程调试技术解答:1.多线程代码调试的挑战:线程之间的交互导致复杂且难以跟踪的行为。2.Java多线程调试技术:逐行调试线程转储(jstack)监视器进入和退出事件线程本地变量3.实战案例:使用线程转储发现死锁,使用监视器事件确定死锁原因。4.结论:Java提供的多线程调试技术可以有效解决与线程安全、死锁和争用相关的问题。

Java中的多线程安全问题——java.lang.ThreadDeath的解决方法 Java中的多线程安全问题——java.lang.ThreadDeath的解决方法 Jun 25, 2023 am 11:22 AM

Java是一种广泛应用于现代软件开发的编程语言,其多线程编程能力也是其最大的优点之一。然而,由于多线程带来的并发访问问题,Java中常常会出现多线程安全问题。其中,java.lang.ThreadDeath就是一种典型的多线程安全问题。本文将介绍java.lang.ThreadDeath的原因以及解决方法。一、java.lang.ThreadDeath的原因

Java多线程并发锁详解 Java多线程并发锁详解 Apr 11, 2024 pm 04:21 PM

Java并发锁机制可确保多线程环境下,共享资源仅由一个线程访问。其类型包括悲观锁(获取锁再访问)和乐观锁(访问后检查冲突)。Java提供了ReentrantLock(互斥锁)、Semaphore(信号量)和ReadWriteLock(读写锁)等内置并发锁类。使用这些锁可以确保共享资源的线程安全访问,如确保多个线程同时访问共享变量counter时仅有一个线程更新其值。

See all articles