资讯专栏INFORMATION COLUMN

Java多线程由易到难

Mertens / 1063人阅读

摘要:线程可以驱动任务,因此你需要一种描述任务的方式,这可以由接口来提供。线程调度没有顺序的,由决定。首先会按照需要创建足够多的线程来执行任务。这个程序将在中的所有任务完成之后尽快退出。就像是线程数量为的。

线程可以驱动任务,因此你需要一种描述任务的方式,这可以由Runnable接口来提供。要想定义任务,只需实现Runnable接口并编写run方法,使得该任务可以执行你的命令。

    
public class LiftOff implements Runnable {

    protected int countDown = 10;
    private static int taskCount = 0;
    
    //id可以用来区分任务的多个实例
    private final int id = taskCount++;
    
    public LiftOff(){
        System.out.println("调用了无参的构造函数");  
    }
    
    public LiftOff(int countDown){
        this.countDown = countDown;
        System.out.println("调用了有参的构造函数
"+  
                 "参数内容为:"+countDown);  
    }
    
    public String status(){
        
        return "#" + id + "(" + (countDown > 0 ? countDown : "Liftoff!") + "),";
        
    }

    @Override
    public void run() {
        
        while(countDown-- > 0){
            System.out.println(status());
            
            //使当前线程从执行状态(运行状态)变为可执行态(就绪状态)。
            //cpu会从众多的可执行态里选择,也就是说,
            //当前也就是刚刚的那个线程还是有可能会被再次执行到的,
            //并不是说一定会执行其他线程而该线程在下一次中不会执行到了。
            Thread.yield();
        }
        
    }
    
    public static void main(String[] args) {
        LiftOff test1 = new LiftOff();
        test1.run();
        System.out.println("
");
        LiftOff test2 = new LiftOff(5);
        test2.run();
    }


}

将Runnable对象转变为工作任务的传统方式是把它提交给一个Thread构造器,
Thread构造器只需要一个Runnable对象。调用Thread对象的start()方法为该线程执行必需的初始化操作,
然后调用Runnable的run()方法,以便在这个新线程中启动该任务。因为main()方法和LiftOff.run()是由不同
的线程执行的,因此程序同时运行两个方法。

线程调度没有顺序的,由CPU决定。

接下来通过java.util.concurrent包中的执行器(Executor)将为你管理Thread对象,从而简化了并发编程。

1:CachedThreadPool首先会按照需要创建足够多的线程来执行任务(Task)。随着程序执行的过程,有的线程执行完了任务,可以被重新循环使用时,才不再创建新的线程来执行任务

对shutdown()方法的调用可以防止新任务被提交给这个Executor,当前线程(即驱动main()的线程)将
继续运行在shutdown()被调用之前提交的所有任务。这个程序将在Executor中的所有任务完成之后尽快退出。

2:FixedThreadPool模式会使用一个优先固定数目的线程来处理若干数目的任务。规定数目的线程处理所有任务,一旦有线程处理完了任务就会被用来处理新的任务(如果有的话)。

最好把3换成Runtime.getRuntime().availableProcessors(),这样能更大程度利用你的电脑CPU处理。

3:SingleThreadExecutor就像是线程数量为1的FixedThreadPool。如果多个任务被提交给SingleThreadExecutor的话,那么这些任务会被保存在一个队列中,并且会按照任务提交的顺序,一个先执行完成再执行另外一个线程。SingleThreadExecutor模式可以保证只有一个任务会被执行。这种特点可以被用来处理共享资源的问题而不需要考虑同步的问题。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/69844.html

相关文章

  • 2016年最值得学习的五大开源项目

    摘要:是学习动画很好的项目,项目代码量比较少,也很适合新手学习。遵循了谷歌材料设计,加入了一些以上的新特性,阅读体验绝不逊色于官方的。架构项目地址由谷歌工程师开发,展示的材料设计,项目代码量大,但是结构清晰,还是很好理解的。 1.Material Animations 演示View的平移、缩放动画,activity进入和退出动画,界面间元素共享。是学习动画很好的项目,项目代码量比较少,也很适...

    RichardXG 评论0 收藏0
  • 3年软件测试经验突显迷茫...不知道我这种测试人员是不是被淘汰?​​

    这两天和朋友谈到软件测试的发展:这一行的变化确实蛮大,从开始最基础的功能测试,到现在自动化、性能、安全乃至于以后可能出现的大数据测试、AI测试岗位需求逐渐增多。我也在软件测试这行摸爬滚打了十年了,正好有朋友问我:如何快速成为互联网时代优秀的测试工程师呢?趁着最近终于有了些闲余时间,遂总结了下自动化测试的成长线路图和职业必备技能,希望可以帮助各位少走弯路、破茧成蝶、迈向成功。 下面我来分享下自动化测...

    fasss 评论0 收藏0

发表评论

0条评论

Mertens

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<