欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  科技

自建APM线程管理

程序员文章站 2022-06-22 22:45:46
线程调度原理剖析线程调度原理任意时刻,只有一个线程占用CPU,处于运行状态多线程并发:轮流获取CPU使用权JVM负责线程调度:按照特定机制分配CPU使用权线程调度模型分时调度模型:轮流获取、均分CPU时间抢占式调度模型:优先级高的获取,JVM采用android线程调度nice值-process中定义-值越小,优先级越高-默认是THREAD_PRIORITY_DEFAULT,0cgroup更严格的群组调度策略保证前台线程可以获取到更多的cpu注意点线程过多导致CPU频繁...

线程调度原理剖析

线程调度原理

任意时刻,只有一个线程占用CPU,处于运行状态
多线程并发:轮流获取CPU使用权
JVM负责线程调度:按照特定机制分配CPU使用权

线程调度模型

分时调度模型:轮流获取、均分CPU时间
抢占式调度模型:优先级高的获取,JVM采用

android线程调度

nice值
- process中定义
- 值越小,优先级越高
- 默认是THREAD_PRIORITY_DEFAULT,0

cgroup
更严格的群组调度策略
保证前台线程可以获取到更多的cpu

注意点
线程过多导致CPU频繁切换,降低线程运行效率
正确认识任务重要性决定那种优先级
优先级具有继承性

总结

Android线程调度原理剖析

Android异步方式汇总

Thread

最简单、常见的异步方式
不易复用,频繁创建及销毁开销大
复杂场景不易使用

HandlerThread

自带消息循环的线程

  • 串行执行
  • 长时间运行,不断从队列取出任务执行

IntentServsice

继承自Service在内部创建HandlerThread

  • 异步,不占用主线程
  • 优先级比较高,不容易被系统Kill

AsyncTask

Android提供的工具类

  • 无需自己处理线程切换
  • 需要注意版本不一致问题

线程池

Java提供的线程池

  • 易复用,减少频繁创建、销毁时间
  • 功能强大:定时、任务队列、并发数控制等

RxJava

由强大的Scheduler集合提供

  • 不同类型的区分:IO、Computation

异步方式总结

推荐度:从前往后排列
正确场景正确方式
各种方式下的线程优先级

总结

线程优化实战

线程使用准则

1.严禁直接new Thread
2.提供基础线程池提供给各个业务线使用

  • 避免各个业务线各自维护一套线程池,导致线程数过多
    3.根据任务类型选择合适的异步方式
    优先级低,长时间执行,HandlerThread
    定时执行:线程池
    4.创建线程必须要命名
  • 方便定位线程归属
  • 运行期Thread.currentThread().setName修改名字
  1. 关键异步任务监控
  • 异步不等于不耗时
  • AOP的方式来做监控
    6.重视优先级设置
  • Process.setThreadPriority()
  • 可以设置多次

锁定线程创建者

背景

  • 项目变大后收敛线程
  • 项目源码、三方库、aar中都有线程的创建
  • 避免项目恶化的一种监控预防手段

方案
分析

  • 创建线程的位置获取堆栈
  • 所有的异步方式,都会走到new Thread
    Hook手段解决
    找Hook点:
  • 构造函数或者特定方法
  • Thread的构造函数

线程收敛优雅实践

常规方案

  • 根据线程创建堆栈考量合理性,使用统一线程库
  • 各个业务线下掉自己的线程库
    基础库如何使用线程
  • 直接依赖线程库
  • 缺点:线程库更新可能会导致基础库更新
  • 基础库暴露API:setExecutor
  • 初始化的时候注入统一的线程库

统一线程库

  • 区分任务类型:IO、CPU密集型
  • IO密集型任务不消耗CPU,核心池可以很大
  • CPU密集型任务:核心池大小和CPU核心数相关

本文地址:https://blog.csdn.net/ZPCrobot/article/details/109604656