安卓三种线程同步方式:1. Thread+Handler 2. Handler+HandlerThread 3. AnsyncTask

本文介绍了一种在Android应用中使用不同方法实现UI更新的技术,包括使用AsyncTask进行后台任务处理并更新UI,利用HandlerThread执行长时间运行的任务,以及通过简单的Thread结合Handler来达到同样的目的。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public class MainActivity extends AppCompatActivity {
    Handler mChildHandler;
    HandlerThread mHandlerThread;
    Handler mHandler;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //1. AsyncTask
        new ImageAsyncTask().execute();
        /*2. HandlerThread
        mHandler = new Handler();
        mHandlerThread = new HandlerThread("handlerThread");
        mHandlerThread.start();
        mChildHandler = new Handler(mHandlerThread.getLooper());
        mChildHandler.post(new Runnable() {
            @Override
            public void run() {
                try {
                    Thread.sleep(2000);
                    mHandler.post(new Runnable() {
                        @Override
                        public void run() {
                            findViewById(R.id.imageview).setVisibility(View.VISIBLE);
                        }
                    });
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        });*/
        /*3. Thread+Handler
        new ChildThread().start();*/
    }

    @Override
    protected void onResume() {
        super.onResume();

    }

    class ImageAsyncTask extends AsyncTask<String, Integer, Boolean>{

        @Override
        protected Boolean doInBackground(String... params) {
            try {
                Thread.sleep(2000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            return null;
        }

        @Override
        protected void onPostExecute(Boolean aBoolean) {
            findViewById(R.id.imageview).setVisibility(View.VISIBLE);
        }
    }

    class ChildThread extends Thread{
        @Override
        public void run() {
            super.run();
            try {
                sleep(2000);
                mHandler.post(new Runnable() {
                    @Override
                    public void run() {
                        findViewById(R.id.imageview).setVisibility(View.VISIBLE);
                    }
                });
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}
Binder : Outgoing transactions from this process must be FLAG_ONEWAY 07-24 09:23:01.475 1200 1274 E Binder : java.lang.Throwable 07-24 09:23:01.475 1200 1274 E Binder : at android.os.BinderProxy.transact(BinderProxy.java:541) 07-24 09:23:01.475 1200 1274 E Binder : at komect.aisoho.cloudcomputer.IHYPackageDeletedCallback$Stub$Proxy.packageDeleted(IHYPackageDeletedCallback.java:125) 07-24 09:23:01.475 1200 1274 E Binder : at com.android.server.hra.HYManagerService.requestUnInstall(HYManagerService.java:210) 07-24 09:23:01.475 1200 1274 E Binder : at com.android.server.pm.DeletePackageHelper.deletePackageX(DeletePackageHelper.java:359) 07-24 09:23:01.475 1200 1274 E Binder : at com.android.server.pm.DeletePackageHelper.lambda$deletePackageVersionedInternal$4$com-android-server-pm-DeletePackageHelper(DeletePackageHelper.java:785) 07-24 09:23:01.475 1200 1274 E Binder : at com.android.server.pm.DeletePackageHelper$$ExternalSyntheticLambda4.run(Unknown Source:22) 07-24 09:23:01.475 1200 1274 E Binder : at android.os.Handler.handleCallback(Handler.java:942) 07-24 09:23:01.475 1200 1274 E Binder : at android.os.Handler.dispatchMessage(Handler.java:99) 07-24 09:23:01.475 1200 1274 E Binder : at android.os.Looper.loopOnce(Looper.java:201) 07-24 09:23:01.475 1200 1274 E Binder : at android.os.Looper.loop(Looper.java:288) 07-24 09:23:01.475 1200 1274 E Binder : at android.os.HandlerThread.run(HandlerThread.java:67) 07-24 09:23:01.475 1200 1274 E Binder : at com.android.server.ServiceThread.run(ServiceThread.java:44)
07-25
07-31 10:28:12.932 408 526 D EthernetNetworkFactory: Starting Ethernet IpClient(eth0) 07-31 10:28:12.937 408 430 W Watchdog: *** WATCHDOG KILLING SYSTEM PROCESS: Blocked in monitor com.android.server.power.PowerManagerService on foreground thread (android.fg) 07-31 10:28:12.938 408 430 W Watchdog: android.fg annotated stack trace: 07-31 10:28:12.938 408 430 W Watchdog: at com.android.server.power.PowerManagerService.monitor(PowerManagerService.java:3785) 07-31 10:28:12.938 408 430 W Watchdog: - waiting to lock <0x08eacc86> (a java.lang.Object) 07-31 10:28:12.938 408 430 W Watchdog: at com.android.server.Watchdog$HandlerChecker.run(Watchdog.java:247) 07-31 10:28:12.939 408 430 W Watchdog: at android.os.Handler.handleCallback(Handler.java:938) 07-31 10:28:12.939 408 430 W Watchdog: at android.os.Handler.dispatchMessage(Handler.java:99) 07-31 10:28:12.939 408 430 W Watchdog: at android.os.Looper.loop(Looper.java:223) 07-31 10:28:12.939 408 430 W Watchdog: at android.os.HandlerThread.run(HandlerThread.java:67) 07-31 10:28:12.939 685 7715 E IpClient.eth0: ERROR disabling IPv6 failed: android.os.ServiceSpecificException: Remote I/O error (code 121) 07-31 10:28:12.939 408 430 W Watchdog: at com.android.server.ServiceThread.run(ServiceThread.java:44) 07-31 10:28:12.939 408 430 W Watchdog: *** GOODBYE! 07-31 10:28:12.939 408 430 I Process : Sending signal. PID: 408 SIG: 9 07-31 10:28:12.952 685 7715 E IpClient.eth0: ERROR error enabling IPv6 privacy extensions: android.os.ServiceSpecificException: Remote I/O error (code 121) 07-31 10:28:12.952 685 7715 E IpClient.eth0: ERROR onProvisioningFailure(): 5 07-31 10:28:29.650 2686 2686 W adbd : timeout expired while flushing socket, closing
最新发布
08-01
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值