zoukankan      html  css  js  c++  java
  • 多线程有几种实现方法?同步有几种实现方法?

    Java5以前,有如下两种:

    第一种:继承Thread类,重写它的run()方法。

    代码如下:

    new Thread()

    {

    public void run()

    {

    //线程执行体

    }

    }.start();

    第二种:实现Runnable接口,并重写它的run()方法。

    代码如下:

    new Thread(new Runnable()

    {

    public void run()

    {

    //线程执行体

    }

    }).start();

    从上面代码不难看出,线程的执行体是一个run()方法,然后程序通过start()方法启动一条线程。

    Java 5开始,Java提供了第三种方式来创建多线程:实现Callable接口,并实现call()方法。Callable接口相当于Runnable接口的增强版,因为Callable接口中定义的call()方法既拥有返回值,也可以声明抛出异常。

    代码如下:

    new Thread(new FutureTask<Object >(new Callable<Object>()

    {

    public Object call() throws Exception

    {

    //线程执行体

    }

    })).start();

    不仅如此,Java 5还提供了线程支持,ExecutorService对象就代表了线程池,如果开发者利用ExecutorService来启动线程,ExecutorService底层会负责管理线程池。此时,开发者只要把Runnable对象传给ExecutorService即可。如下代码:

    ExecutorService pool = Executors.newFixedThreadPool(3)

    pool.execute(new Runnable()

    {

    public void run()

    {

    //线程执行体

    }

    });

    如果执行通过Callable方式实现的线程,则可按如下代码:

    ExecutorService pool = Executors.newFixedThreadPool(3)

    pool.execute(new FutureTask<Object >(new Callable<Object>()

    {

    public Object call() throws Exception

    {

    //线程执行体

    }

    }));

    Java Program!
  • 相关阅读:
    数据库架构的演变
    一个简单的跨库事务问题
    一个优美的架构需要考虑的几个问题
    铁道部新客票系统设计
    详细介绍软件架构设计的三个维度
    单代号网络图
    分库分表带来的完整性和一致性问题
    软件架构设计箴言理解
    设计高并发的电子商店
    mysql之索引补充
  • 原文地址:https://www.cnblogs.com/programb/p/14068588.html
Copyright © 2011-2022 走看看