• 一手遮天 Android


    项目地址 https://github.com/webabcd/AndroidDemo
    作者 webabcd

    一手遮天 Android - 锁和并发处理: CyclicBarrier 屏障

    示例如下:

    /concurrent/CyclicBarrierDemo1.java

    /**
     * CyclicBarrier - 屏障(当所有参与者都到达屏障后,屏障解除)
     *     CyclicBarrier(int parties, Runnable barrierAction) - 实例化 CyclicBarrier,指定参与者的数量,以及屏障解除后需要执行的 Runnable barrierAction
     *     int await(), int await(long timeout, TimeUnit unit) - 此参与者到达屏障后,阻塞并等待所有参与者都到达屏障。返回值为此参与者到达屏障时的排名索引
     *     getParties() - 获取参与者的数量
     *     reset() - 重置屏障
     *     isBroken() - 屏障是否是 broken 状态(比如有的参与者线程被 interrupted 了或者屏障被 reset 了,那么屏障的状态就会被置为 broken 状态)
     */
    
    package com.webabcd.androiddemo.concurrent;
    
    import android.os.SystemClock;
    import androidx.appcompat.app.AppCompatActivity;
    import android.os.Bundle;
    import android.widget.TextView;
    
    import com.webabcd.androiddemo.R;
    
    import java.util.Random;
    import java.util.concurrent.BrokenBarrierException;
    import java.util.concurrent.CyclicBarrier;
    import java.util.concurrent.TimeUnit;
    import java.util.concurrent.TimeoutException;
    
    public class CyclicBarrierDemo1 extends AppCompatActivity {
    
        private TextView _textView1;
    
        private CyclicBarrier _cyclicBarrier;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_concurrent_cyclicbarrierdemo1);
    
            _textView1 = (TextView) findViewById(R.id.textView1);
    
            sample();
        }
    
        private void sample() {
            final Random random = new Random();
            for (int i = 0; i < 5; i++) {
                Thread thread = new Thread(new Runnable() {
                    @Override
                    public void run() {
                        writeMessage(String.format("%s ready", Thread.currentThread().getName()));
                        SystemClock.sleep(random.nextInt(3000));
    
                        try {
                            // 此参与者已经到达屏障了,阻塞并等待所有参与者都到达屏障
                            // 返回值为当前参与者到达屏障时的排名索引
                            int arrivalIndex = _cyclicBarrier.await(5000, TimeUnit.MILLISECONDS);
                            writeMessage(String.format("%s completed(arrivalIndex:%d)", Thread.currentThread().getName(), arrivalIndex));
                        } catch (InterruptedException e) {
                            // 在阻塞过程中,如果此线程被 interrupted 了则抛出此异常
                        } catch (BrokenBarrierException e) {
                            // 在阻塞过程中,如果其他线程被 interrupted 了或者 CyclicBarrier 被 reset 了则抛出此异常
                        } catch (TimeoutException e) {
                            // 在阻塞过程中,如果超时了则抛出此异常
                        }
                    }
                });
                thread.setName("thread" + i);
                thread.setDaemon(true);
                thread.start();
            }
    
            // 指定一共有 5 个参与者,屏障解除后在第一个到达屏障的参与者所在线程执行指定的 Runnable
            _cyclicBarrier  = new CyclicBarrier(5, new Runnable() {
                @Override
                public void run() {
                    writeMessage(String.format("所有参与者都到达屏障了,在第一个到达屏障的参与者所在线程执此 Runnable(%s)", Thread.currentThread().getName()));
                }
            });
        }
    
        private void writeMessage(final String message) {
            runOnUiThread(new Runnable() {
                @Override
                public void run() {
                    _textView1.append(String.format("%s
    ", message));
                }
            });
        }
    }
    
    

    /layout/activity_concurrent_cyclicbarrierdemo1.xml

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">
    
        <TextView
            android:id="@+id/textView1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />
    
    </LinearLayout>
    
    

    项目地址 https://github.com/webabcd/AndroidDemo
    作者 webabcd

  • 相关阅读:
    计算机视觉的常用测试数据集和源码
    Demo:基于 Flink SQL 构建流式应用
    102万行代码,1270 个问题,Flink 新版发布了什么?
    bilibili 实时平台的架构与实践
    阿里云2020上云采购季来啦!降本增效1亿补贴!
    阿里云助力宁波市教育局“甬上云校”停课不停学
    Quick BI新版本功能解读系列之-V3.5
    百万TPS高吞吐、秒级低延迟,阿里​搜索离线平台如何实现?
    五分钟学会使用 go modules(含在家办公使用技巧)
    OAM 深入解读:OAM 为云原生应用带来哪些价值?
  • 原文地址:https://www.cnblogs.com/webabcd/p/android_concurrent_CyclicBarrierDemo1.html
Copyright © 2020-2023  润新知