JDK1.4创建多线程的几种方法

import java.util.concurrent.TimeUnit;
class InnerThread1
{
    private int countDown = 5;
    private Inner inner;

    private class Inner extends Thread
    {
        Inner(String name)
        {
            super(name);
            start();
        }

        public void run()
        {
            try {
                while(true)
                {
                    System.out.println(this);
                    if(--countDown == 0) return ;
                    Thread.sleep(10);
                }
            } catch (Exception e) {
                System.out.println("interrupted");
            }
        }

        public String toString()
        {
            return getName() + ": " + countDown;
        }
    }

    public InnerThread1(String name)
    {
        inner = new Inner(name);
    }
}

//Using an anonymous inner class:
class InnerThread2
{
    private int countDown = 5;
    private Thread t;

    public InnerThread2(String name)
    {
        t = new Thread(name){
            @Override
            public void run() {
                try {
                    while(true)
                    {
                        System.out.println(this);
                        if(--countDown == 0) return ;
                        Thread.sleep(10);
                    }
                } catch (Exception e) {
                    System.out.println("sleep() interrupted");
                }
            }

            @Override
            public String toString() {
                return getName() + ": " + countDown;
            }
        };
        t.start();
    }
}

//Using a named Runnable implementation:
class InnerRunnable1
{
    private int countDown = 5;
    private Inner inner;

    private class Inner implements Runnable
    {
        Thread t;
        Inner(String name)
        {
            t = new Thread(this,name);
            t.start();
        }

        @Override
        public void run() {
            try {
                while(true)
                {
                    System.out.println(this);
                    if(--countDown == 0) return ;
                    TimeUnit.MILLISECONDS.sleep(10);
                }
            } catch (Exception e) {
                System.out.println("sleep() interrupted");
            }
        }

        @Override
        public String toString() {
            return t.getName() + ": " + countDown;
        }
    }

    public InnerRunnable1(String name)
    {
        inner = new Inner(name);
    }
}

//Using an anonymous Runnable implementation:
class InnerRunnable2
{
    private int countDown = 5;
    private Thread t;

    public InnerRunnable2(String name)
    {
        t = new Thread(new Runnable(){
            @Override
            public void run() {
                try {
                    while(true)
                    {
                        System.out.println(this);
                        if(--countDown == 0) return ;
                        TimeUnit.MILLISECONDS.sleep(10);
                    }
                } catch (Exception e) {
                    System.out.println("sleep() interrupted");
                }
            }

            @Override
            public String toString() {
                return Thread.currentThread().getName() + 
                        ":" + countDown;
            }
        },name);
        t.start();
    }
}

//A separate method to run some code as a task:
class ThreadMethod
{
    private int countDown = 5;
    private Thread t;
    private String name;

    public ThreadMethod(String name)
    {
        this.name = name;
    }

    public void runTask()
    {
        if(t == null)
        {
            t = new Thread(name)
            {
                @Override
                public void run() {
                    try {
                        while(true)
                        {
                            System.out.println(this);
                            if(--countDown == 0) return ;
                            Thread.sleep(10);
                        }
                    } catch (Exception e) {
                        System.out.println("sleep() interrupted");
                    }
                }

                @Override
                public String toString() {
                    return getName() + ": " + countDown;
                }
            };
            t.start();
        }
    }
}

public class ThreadVariations {

    public static void main(String[] args) {
        new InnerThread1("InnerThread1");
        new InnerThread2("InnerThread2");
        new InnerRunnable1("InnerRunnable1");
        new InnerRunnable2("InnerRunnable2");
        new ThreadMethod("ThreadMethod").runTask();
    }
}
//InnerThread1: 5
//InnerThread2: 5
//InnerRunnable1: 5
//InnerRunnable2:5
//ThreadMethod: 5
//InnerThread1: 4
//InnerThread2: 4
//ThreadMethod: 4
//InnerRunnable1: 4
//InnerRunnable2:4
//InnerThread1: 3
//InnerThread2: 3
//InnerRunnable1: 3
//ThreadMethod: 3
//InnerRunnable2:3
//InnerThread1: 2
//InnerThread2: 2
//ThreadMethod: 2
//InnerRunnable1: 2
//InnerRunnable2:2
//InnerThread1: 1
//InnerThread2: 1
//ThreadMethod: 1
//InnerRunnable1: 1
//InnerRunnable2:1
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在Python中,有两种常用的创建线程的方式: 1. 使用threading模块创建线程。可以通过创建Thread对象并将一个函数作为目标来创建线程。例如: ``` import threading def my_function(): # 代码块 my_thread = threading.Thread(target=my_function) my_thread.start() ``` 2. 继承Thread类创建线程。可以创建一个新的类,继承Thread类,并实现run()方法来定义线程的行为。例如: ``` import threading class MyThread(threading.Thread): def run(self): # 代码块 my_thread = MyThread() my_thread.start() ``` ### 回答2: 创建线程的方式有三种:使用继承Thread类的方式、实现Runnable接口的方式和使用Executor框架的方式。 第一种方式是通过继承Thread类来创建线程。首先定义一个继承自Thread类的子类,然后重写run()方法,在run()方法中编写线程的逻辑代码。通过子类的实例化对象调用start()方法启动线程。这种方式创建线程较为简单,但是由于Java只支持单继承,所以当一个类已经继承了其他类时,无法使用这种方式创建线程。 第二种方式是通过实现Runnable接口来创建线程。定义一个实现了Runnable接口的类,实现类重写run()方法,在run()方法中编写线程的逻辑代码。然后通过实例化一个Thread对象,将实现类的对象作为参数传入Thread的构造方法中,并调用Thread的start()方法启动线程。这种方式避免了Java单继承的限制,并且线程与任务的分离,解耦更好,所以在实际开发中更常使用这种方式创建线程。 第三种方式是使用Executor框架来创建线程。Executor框架是JDK提供的一种用于管理和调度线程的框架。通过创建一个ExecutorService对象,然后使用线程池的方式来创建线程。可以使用Executors类的静态方法创建不同类型的线程池。这种方式可以实现线程的池化管理,可以灵活控制线程的数量,并且可以提供更好的性能和资源的管理。 ### 回答3: 创建线程的方式有三种: 1. 继承Thread类:通过定义一个类继承自Thread类,重写run方法,在run方法中实现线程的具体逻辑。通过创建该类的对象,可以启动新的线程。 2. 实现Runnable接口:定义一个类实现Runnable接口,实现接口中的run方法,在run方法中实现线程的具体逻辑。通过创建该类的对象,并将其作为参数传递给Thread类的构造方法,并调用线程对象的start方法,启动新的线程。 3. 使用Executor框架:使用Java提供的Executor框架,通过调用ExecutorService的方法,可以创建并管理线程池。通过提交实现Runnable接口或Callable接口的任务给线程池,框架会自动创建新的线程并执行任务。 这三种方式各有优缺点,继承Thread类方式比较简单,但耦合性较高,不便于复用;实现Runnable接口方式可以实现资源共享,适用于多个线程共享一个资源的场景;使用Executor框架则可以更方便地管理线程和任务,提供更多的控制和灵活性。 在选择创建线程的方式时,需要根据具体的应用场景和需求来选择最合适的方式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值