新手学JAVA(十)-多线程----线程的创建和启动

简介:

Java使用Thread类代表线程,所有的线程对象都必须是Thread类或者其子类的实例。每个下次你哼的作用是完成一定的任务,实际上就是执行一段程序流(一段顺序执行的代码)。Java使用线程执行体来代表这段程序流

    在Java线程的创建有三种方式
    

通过继承Thread类创建线程类


步骤如下

  1. 定义Thread类的子类,并重写该类的run()方法,该run()方法的方法体就代表了线程需要完成的任务。因此把run()方法称为线程执行体。
  2. 创建Thread子类的实例,即创建了线程的对象。
  3. 调用线程对象的start()方法来启动线程。

/**
 * 通过继承Thread类创建线程类
 * @author Administrator
 *
 */
public class FirstThread extends Thread{

    private int i;
    
    public void run(){
        for(i=0;i<100;i++){
            System.out.println(getName()+" "+i);
        }
    }
    
    public static void main(String[] args){
        for(int i=0; i<100;i++){
            System.out.println(Thread.currentThread().getName() + " " +i);
            
            if(i==20){
                new FirstThread().start();
                new FirstThread().start();
            }
        
        }
    }
}

    

实现Runnable接口创建线程类


步骤如下:

  1. 定义Runnable接口的实现类,并重写该接口的run()方法,该run()方法体同样是该线程的线程执行体。
  2. 创建Runnable实现类的实例,并以此实例作为Threadtarget来创建Thread对象,该Thread对象才是真正的线程对象。
  3. 调用线程对象的start()方法来启动该线程。
/**
 * 通过实现Runnable接口来创建线程类
 * @author Administrator
 *
 */
public class SecondThread implements Runnable{
    
    private int i;
    
    public void run()
    {
        for(i=0;i<100;i++){
            System.out.println(Thread.currentThread().getName() + " " +i);
            
        }
    }
    
    public static void main(String[] args){
        for(int i=0; i<100;i++){
            System.out.println(Thread.currentThread().getName() + " " +i);
            
            if(i==20){
                SecondThread st=new SecondThread();
                new Thread(st,"新线程1").start();
                new Thread(st,"新线程2").start();
            }
        
        }
    }
}

    

使用Callable和Future创建线程


步骤如下:

  1. 创建Callable实现类的实例。并实现call()方法,该call()方法将作为线程执行体,且该call()方法有返回值,在创建Callable实现类的实例。从Java8开始,可以直接使用Lambda表达式创建Callable对象。
  2. 使用FutureTask类来包装Callable对象,该FutureTask对象封装了该Call对象的Call()方法的返回值。
  3. 使用FutureTask对象作为Thread对象的target创建并启动新线程。
  4. 调用FutureTask对象的get()方法来获得子线程执行结束后的返回值。
import java.util.concurrent.Callable;
import java.util.concurrent.FutureTask;


/**
 * 使用Callable和Future创建线程
 * @author Administrator
 *
 */
public class ThirdThead implements Callable<Integer>{

    
    /**
     * @param args
     */
    public static void main(String[] args) {
        ThirdThead rt=new ThirdThead();
        
        FutureTask<Integer> task= new FutureTask<Integer>(rt);
            
        for(int i=0;i<100;i++){
            System.out.println(Thread.currentThread().getName() + "循环变量i的值: " +i);
            if(i==20){
                new Thread(task,"有返回值的线程").start();
            }
        }
        
        try{
            System.out.println("子线程的返回值:"+task.get());
        }catch(Exception ex){
            ex.printStackTrace();
        }
    }

    @Override
    public Integer call() throws Exception {
        int i=0;
        for(i=0;i<100;i++){
            System.out.println(Thread.currentThread().getName() + "循环变量i的值: " +i);
        }
        return i;
    }

}

    

三种创建方式的对比


    通过继承Thread类或实现Runnable、Callable接口都可以实现多线程。不过实现Runnable和实现Callable的方式基本相同,只不过Callable有返回值,并可以抛出异常。因此把Runnable、Callable归为一类。这种实现方式和继承Thread方式的差别如下:

采用实现Runnable、Callable接口的方式创建多线程优缺点:

  1. 显示只是实现了RunnableCallable接口,还可以实现其他的继承其他的类。
  2. 这种情况下, 多线程可以共享同一个target对象,非常适合多个相同线程来处理同一份资源,从而可以更好的将CPU、代码和数据分开,形成清晰的模型,很好的体现了面向对象的思想。
  3. 劣势:编程比较复杂,而且如果想要访问当前线程的话,必须使用Thread.currentThread()方法。

采用继承Thread类的方式创建多线程优缺点:

  1. 优势:编写简单,如果需要访问当前线程,不需要用Thread.currentThread()方法,直接使用this即可获取当前线程。
  2. 劣势:因为线程已经继承了Thread类,所以不能再继承其他父类。

    
    
    综上分析:推荐使用实现Runnable接口、Callable接口的方式来实现多线程。

相关文章
|
9天前
|
存储 Java 数据库连接
java多线程之线程通信
java多线程之线程通信
|
9天前
|
安全 Java 开发者
深入理解Java并发编程:线程安全与性能优化
【4月更文挑战第9天】本文将深入探讨Java并发编程的核心概念,包括线程安全和性能优化。我们将详细解析Java中的同步机制,包括synchronized关键字、Lock接口以及并发集合等,并探讨它们如何影响程序的性能。此外,我们还将讨论Java内存模型,以及它如何影响并发程序的行为。最后,我们将提供一些实用的并发编程技巧和最佳实践,帮助开发者编写出既线程安全又高效的Java程序。
22 3
|
9天前
|
算法 Java 开发者
Java中的多线程编程:概念、实现与性能优化
【4月更文挑战第9天】在Java编程中,多线程是一种强大的工具,它允许开发者创建并发执行的程序,提高系统的响应性和吞吐量。本文将深入探讨Java多线程的核心概念,包括线程的生命周期、线程同步机制以及线程池的使用。接着,我们将展示如何通过继承Thread类和实现Runnable接口来创建线程,并讨论各自的优缺点。此外,文章还将介绍高级主题,如死锁的预防、避免和检测,以及如何使用并发集合和原子变量来提高多线程程序的性能和安全性。最后,我们将提供一些实用的性能优化技巧,帮助开发者编写出更高效、更稳定的多线程应用程序。
|
7天前
|
安全 算法 Java
深入理解Java并发编程:线程安全与性能优化
【4月更文挑战第11天】 在Java中,高效的并发编程是提升应用性能和响应能力的关键。本文将探讨Java并发的核心概念,包括线程安全、锁机制、线程池以及并发集合等,同时提供实用的编程技巧和最佳实践,帮助开发者在保证线程安全的前提下,优化程序性能。我们将通过分析常见的并发问题,如竞态条件、死锁,以及如何利用现代Java并发工具来避免这些问题,从而构建更加健壮和高效的多线程应用程序。
|
1天前
|
存储 安全 Java
Java中的容器,线程安全和线程不安全
Java中的容器,线程安全和线程不安全
7 1
|
3天前
|
设计模式 运维 安全
深入理解Java并发编程:线程安全与性能优化
【4月更文挑战第15天】在Java开发中,多线程编程是提升应用程序性能和响应能力的关键手段。然而,它伴随着诸多挑战,尤其是在保证线程安全的同时如何避免性能瓶颈。本文将探讨Java并发编程的核心概念,包括同步机制、锁优化、线程池使用以及并发集合等,旨在为开发者提供实用的线程安全策略和性能优化技巧。通过实例分析和最佳实践的分享,我们的目标是帮助读者构建既高效又可靠的多线程应用。
|
4天前
|
Java 程序员 编译器
Java中的线程同步与锁优化策略
【4月更文挑战第14天】在多线程编程中,线程同步是确保数据一致性和程序正确性的关键。Java提供了多种机制来实现线程同步,其中最常用的是synchronized关键字和Lock接口。本文将深入探讨Java中的线程同步问题,并分析如何通过锁优化策略提高程序性能。我们将首先介绍线程同步的基本概念,然后详细讨论synchronized和Lock的使用及优缺点,最后探讨一些锁优化技巧,如锁粗化、锁消除和读写锁等。
|
6天前
|
Java
探秘jstack:解决Java应用线程问题的利器
探秘jstack:解决Java应用线程问题的利器
14 1
探秘jstack:解决Java应用线程问题的利器
|
6天前
|
Java 调度 开发者
Java 21时代的标志:虚拟线程带来的并发编程新境界
Java 21时代的标志:虚拟线程带来的并发编程新境界
14 0
|
8天前
|
监控 安全 Java
深入理解Java并发编程:线程安全与性能优化
【4月更文挑战第10天】 在Java开发中,并发编程是提升应用性能和响应能力的关键手段。然而,线程安全问题和性能调优常常成为开发者面临的挑战。本文将通过分析Java并发模型的核心原理,探讨如何平衡线程安全与系统性能。我们将介绍关键的同步机制,包括synchronized关键字、显式锁(Lock)以及并发集合等,并讨论它们在不同场景下的优势与局限。同时,文章将提供实用的代码示例和性能测试方法,帮助开发者在保证线程安全的前提下,实现高效的并发处理。

热门文章

最新文章