Java CompletableFuture(1)
  TEZNKK3IfmPf 2023年11月14日 24 0

Java CompletableFuture(1)

 private Long longTimeWork() {
        try {
            //模拟耗时操作,特意阻塞5秒。
            TimeUnit.SECONDS.sleep(5);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        return System.currentTimeMillis();
    }

    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        System.out.println("时间1:" + System.currentTimeMillis());
        CompletableFuture<Long> future = CompletableFuture.supplyAsync(() -> longTimeWork());
        System.out.println("时间2:" + System.currentTimeMillis());
        Future<Long> f = future.whenComplete((v, a) -> {
            System.out.println("时间3:" + System.currentTimeMillis());
            System.out.println("v: " + v);
            System.out.println("a: " + a);
            System.out.println("时间4:" + System.currentTimeMillis());
        });
        System.out.println("时间5:" + System.currentTimeMillis());
    }

输出:

06-12 16:28:23.157 4686-4686/zhangphil.test I/System.out: 时间1:1528792103157
06-12 16:28:23.161 4686-4686/zhangphil.test I/System.out: 时间2:1528792103161
06-12 16:28:23.162 4686-4686/zhangphil.test I/System.out: 时间5:1528792103162
06-12 16:28:28.164 4686-4710/zhangphil.test I/System.out: 时间3:1528792108164
06-12 16:28:28.165 4686-4710/zhangphil.test I/System.out: v: 1528792108164
    a: null
    时间4:1528792108165
【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月14日 0

暂无评论

推荐阅读
  TEZNKK3IfmPf   16天前   38   0   0 java
  TEZNKK3IfmPf   30天前   47   0   0 java
TEZNKK3IfmPf