ASP源码.NET源码PHP源码JSP源码JAVA源码DELPHI源码PB源码VC源码VB源码Android源码
当前位置:首页 >> 软件工程 >> 多线程多进程 编写多线程程序有几种实现方式?

多线程多进程 编写多线程程序有几种实现方式?

来源:网络整理     时间:2017-11-24     关键词:多线程多进程

本篇文章主要介绍了"多线程多进程 编写多线程程序有几种实现方式?",主要涉及到多线程多进程方面的内容,对于软件工程感兴趣的同学可以参考一下: Java 5以前实现多线程有两种实现方法:一种是继承Thread类;另一种是实现Runnable接口。两种方式都要通过重写run()方法来定义线程的行为,推荐使...

Java 5以前实现多线程有两种实现方法:一种是继承Thread类;另一种是实现Runnable接口。

两种方式都要通过重写run()方法来定义线程的行为,推荐使用后者,因为Java中的继承是单继承,一个类有一个父类,如果继承了Thread类就无法再继承其他类了,显然使用Runnable接口更为灵活

补充:Java 5以后创建线程还有第三种方式:实现Callable接口,该接口中的call方法可以在线程执行结束时产生一个返回值,代码如下所示:

importjava.util.ArrayList;

importjava.util.List;

importjava.util.concurrent.Callable;

importjava.util.concurrent.ExecutorService;

importjava.util.concurrent.Executors;

importjava.util.concurrent.Future;

classMyTask implementsCallable {

    privateintupperBounds;

    publicMyTask(intupperBounds) {

        this.upperBounds = upperBounds;

    }

    @Override

    publicInteger call() throwsException {

        intsum = 0;

        for(inti = 1; i <= upperBounds; i++) {

            sum += i;

        }

        returnsum;

    }

}

classTest {

    publicstaticvoidmain(String[] args) throwsException {

        List<>> list = newArrayList<>();

        ExecutorService service = Executors.newFixedThreadPool(10);

        for(inti = 0; i < 10; i++) {

            list.add(service.submit(newMyTask((int) (Math.random() * 100))));

        }

        intsum = 0;

        for(Future future : list) {

            // while(!future.isDone()) ;

            sum += future.get();

        }

        System.out.println(sum);

    }

}

以上就介绍了多线程多进程 编写多线程程序有几种实现方式?,包括了多线程多进程方面的内容,希望对软件工程有兴趣的朋友有所帮助。

本文网址链接:http://www.codes51.com/article/detail_4506081.html

多线程多进程相关图片

多线程多进程相关文章