Java中线程的创建方式

一、继承Thread类,重写run方法

public class MyThread{
    public static void main(String[] args) {
        Thread threadDome = new ThreadDome();
        threadDome.start();
    }
}

class ThreadDome extends Thread{
    @Override
    public void run() {
        for (int i = 0; i < 5; i++) {
            try {
                Thread.sleep(500);
            } catch (InterruptedException e) {
                throw new RuntimeException(e);
            }
            System.out.println("i = " + i);
        }
    }
}

二、实现Runnable接口,重写run方法

public class MyThread{   
    public static void main(String[] args) {
        MyRunnable myRunnable = new MyRunnable();
        new Thread(myRunnable).run();
    }
}

class MyRunnable implements Runnable{
    @Override
    public void run() {
        for (int i = 0; i < 5; i++) {
            try {
                Thread.sleep(500);
            } catch (InterruptedException e) {
                throw new RuntimeException(e);
            }
            System.out.println("i = " + i);
        }
    }
}

三、实现Callable接口,重写call方法

public class MyThread{
    public static void main(String[] args) throws ExecutionException, InterruptedException             
     {
        MyCallable myCallable = new MyCallable();
        FutureTask futureTask = new FutureTask(myCallable);
        new Thread(futureTask).start();

        System.out.println(futureTask.get());
    }
}

class MyCallable implements Callable<Integer>{
    @Override
    public Integer call() throws Exception {
        return 10;
    }
}

callable相较于runnable接口,可以拥有返回值,并且runnable中程序出现异常只能通过try...catch进行捕获然后处理,callable可以将异常抛出。

四、使用线程池

1、线程池的实现:

1、FixedThreadPool(定长线程池):只有核心线程,线程数量固定,执行完立即回收,任务队列为链表结果的有界队列,控制线程的最大并发数

    @Test
    public void test() throws ExecutionException, InterruptedException {
        //创建线程池
        ExecutorService pool = Executors.newFixedThreadPool(5);
        //使用线程池
        for (int i = 0; i < 5; i++) {
            Future<Integer> submit = pool.submit(new Callable<Integer>() {
                @Override
                public Integer call() throws Exception {
                    return 10;
                }
            });
            System.out.println(submit.get());
        }
        //关闭线程池
        pool.shutdown();
    }

2、ScheduledThreadPool(定时线程池):核心线程数量固定,非核心线程数量无限,执行完闲置10s后回收,任务队列为延时阻塞队列,执行定时或周期性任务

    @Test
    public void test02() throws ExecutionException, InterruptedException {
        //创建线程池
        ScheduledExecutorService pool = Executors.newScheduledThreadPool(5);
        //使用线程池
        for (int i = 0; i < 5; i++) {
            ScheduledFuture<Integer> schedule = pool.schedule(new Callable<Integer>() {
                @Override
                public Integer call() throws Exception {
                    return 10;
                }
            }, 1, TimeUnit.SECONDS);
            System.out.println(schedule.get());
        }
        //销毁线程池
        pool.shutdown();
    }

3、CachedThreadPool(可缓存线程池):无核心线程,非核心线程数量无限,执行完闲置60s回收,任务队列为不存储元素的阻塞队列,执行大量,耗时少的任务

    @Test
    public void test03() throws ExecutionException, InterruptedException {
        //创建线程池
        ExecutorService pool = Executors.newCachedThreadPool();
        //使用线程池
        for (int i = 0; i < 5; i++) {
            Future<Integer> submit = pool.submit(new Callable<Integer>() {
                @Override
                public Integer call() throws Exception {
                    return 10;
                }
            });
            System.out.println(submit.get());
        }
        //关闭线程池
        pool.shutdown();
    }

4、SingleThreadExecutor(单线程化线程池):只有一个核心线程,无非核心线程,执行完立即回收,任务队列为链表结果的有界队列,不适合做并发但可能引起io阻塞及影响ui线程响应的操作,如数据库操作、文件操作等

@Test
    public void test04() throws ExecutionException, InterruptedException {
        //创建线程池
        ExecutorService pool = Executors.newSingleThreadExecutor();
        //使用线程池
        for (int i = 0; i < 5; i++) {
            Future<Integer> submit = pool.submit(new Callable<Integer>() {
                @Override
                public Integer call() throws Exception {
                    return 10;
                }
            });
            System.out.println(submit.get());
        }
        //关闭线程池
        pool.shutdown();
    }

2、excute和submit的区别

excute:只能提交Runable类型任务,会直接抛出异常,可以用try、catch来捕获,和普通线程处理方式一致,excute没有返回值

submit:能提交Runable类型任务也能提交Callable类型任务,会吃掉异常,可通过future的get方法将任务执行时的异常重新抛出,submit有返回值,需要返回值的时候必须使用submit

submit最后的任务也是抛给excute方法,提交任务不需要一个结果的话,直接用excute()提高性能

  • 10
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java 线程创建方式有两种: 1. 继承 Thread 类并重写 run 方法。 2. 实现 Runnable 接口并重写 run 方法。通过将 Runnable 对象传递给 Thread 构造函数,然后调用 start() 方法启动线程。 ### 回答2: Java线程创建方式有以下几种: 1. 继承Thread类:创建一个新的类并继承Thread类,重写父类的run()方法作为线程的入口点,然后创建该类的实例并调用start()方法来启动线程。 2. 实现Runnable接口:创建一个实现Runnable接口的类,该类需要实现run()方法,然后创建该类的实例并将其作为参数传递给Thread类的构造方法,最后调用start()方法来启动线程。 3. 实现Callable接口:Callable接口与Runnable接口类似,但是它的call()方法可以返回一个结果,并且可以抛出异常。创建一个实现Callable接口的类,该类需要实现call()方法,然后创建该类的实例并将其作为参数传递给ExecutorService的submit()方法,最后调用get()方法获取返回结果。 4. 使用Executor框架:Java提供了Executor框架来管理和执行线程。可以通过使用ExecutorService接口及其实现类ThreadPoolExecutor来创建线程池,然后将任务提交给线程池进行执行。 5. 使用ScheduledExecutor框架:ScheduledExecutor框架是Executor框架的扩展,提供了按照时间进行调度的功能。可以使用ScheduledExecutorService接口及其实现类ScheduledThreadPoolExecutor来创建定时任务。 这些是Java常用的线程创建方式,每种方式都有适用的场景,可以根据具体的需求选择合适的方式创建线程。 ### 回答3: Java线程创建方式有两种:继承Thread类和实现Runnable接口。 1. 继承Thread类:创建一个继承自Thread类的子类,并重写其run方法。在run方法定义线程的任务逻辑。然后通过创建子类对象并调用start方法来启动线程。 示例代码如下: ``` public class MyThread extends Thread { @Override public void run() { // 线程任务逻辑 } } // 创建并启动线程 MyThread myThread = new MyThread(); myThread.start(); ``` 2. 实现Runnable接口:创建一个类实现Runnable接口,并实现其run方法。在run方法定义线程的任务逻辑。然后通过创建Runnable接口实现类的对象,并将其作为参数传递给Thread类的构造方法来创建Thread对象。最后调用Thread对象的start方法来启动线程。 示例代码如下: ``` public class MyRunnable implements Runnable { @Override public void run() { // 线程任务逻辑 } } // 创建并启动线程 MyRunnable myRunnable = new MyRunnable(); Thread thread = new Thread(myRunnable); thread.start(); ``` 这两种方式都可以创建线程,但实现Runnable接口的方式更常用,因为它可以避免单继承的限制,并且更符合面向对象的设计原则。同时,实现Runnable接口还能在实例化Thread对象时,可以共享同一个Runnable实例,实现多个线程共享数据的需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值