想象你在另一个城市(子线程)买了礼物,想送给女朋友(UI线程)。直接扔过去会砸伤人(崩溃),必须通过快递站(主线程通信机制)。
想象你在另一个城市(子线程)买了礼物,想送给女朋友(UI线程)。直接扔过去会砸伤人(崩溃),必须通过快递站(主线程通信机制)。以下是安全送礼指南:
方案1:最新快递站-runOnUiThread
适用场景:在Activity/Fragment中快速传递
// 子线程工作new Thread(() -> { String message = fetchMsgFromServer(); // 最新指定快递点 runOnUiThread(() -> { textView.setText(message); // 安全送达 });}).start();
优势:
• 系统自带,随用随取• 自动识别当前Activity生命周期方案2:任意代收点-View.post
适用场景:在任何能拿到View的地方
// 在任意View可达的地方fun updateProgress(progress: Int) { Thread { val current = calculateProgress() // 随便找个View当快递柜 progressBar.post { progressBar.progress = current } }.start()}
隐藏技巧:
• 即使View还没显示也能寄存消息
• 支持延迟投递:view.postDelayed({...}, 1000)
方案3:老牌物流-Handler
适用场景:需要精准控制消息队列
// 创建主线程HandlerHandler mainHandler=new Handler(Looper.getMainLooper());void showNotification(String message) { executorService.execute(() -> { prepareNotification(message); // 精准派送 mainHandler.post(() -> { notificationView.display(message); }); });}
避坑指南:
• 记得在onDestroy时调用mHandler.removeCallbacksAndMessages(null)
• 用postDelayed实现定时刷新:mHandler.postDelayed(updateTask, 5000)
方案4:智能管家-LiveData
适用场景:MVVM架构下的数据驱动UI
// ViewModel中private val _newsLiveData = MutableLiveData>()val newsLiveData: LiveData
> = _newsLiveDatafun loadNews() { viewModelScope.launch(Dispatchers.IO) { val news = repository.fetchNews() _newsLiveData.postValue(news) // 自动切到主线程 }}// Activity中newsViewModel.newsLiveData.observe(this) { news -> adapter.submitList(news) // 安全更新RecyclerView}
优势对比:
方案5:闪电侠-协程
适用场景:Kotlin项目中的异步处理
fun loadComments() { lifecycleScope.launch { val comments = withContext(Dispatchers.IO) { api.getComments(postId) } // 自动切回主线程 binding.commentList.adapter = CommentAdapter(comments) }}
性能对比:
• 传统线程:每次new Thread约消耗1MB内存
• 协程:轻量级,1KB级内存消耗
方案6:万能工-RxJava
适用场景:复杂异步流处理
Observable.fromCallable(() -> db.queryUnreadMsg()) .subscribeOn(Schedulers.io()) .observeOn(AndroidSchedulers.mainThread()) .subscribe(messages -> { badgeView.updateCount(messages.size); });
高阶用法:
// 合并多个数据源Observable.merge(networkData, localData) .filter(msg -> !msg.isDeleted) .debounce(300, TimeUnit.MILLISECONDS) .observeOn(AndroidSchedulers.mainThread()) .subscribe(this::updateUI);
好的线程管理就像优秀的交通管制,让数据在正确的时间走正确的车道!现在就去优化你的代码吧~
