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!
  • 相关阅读:
    gTest&gMock learning
    机器学习 delay learning
    c++ learning
    2017 湘潭邀请赛&JSCPC G&J
    mapreduce&GFS&bigtable learning
    golang learning
    高斩仙的北京历险记
    python learning
    Codeforces Round #448 (Div. 2) B
    python之callable
  • 原文地址:https://www.cnblogs.com/programb/p/14068588.html
Copyright © 2011-2022 走看看