deep performance tuning
3
总安装量
0
周安装量
#61200
全站排名
安装命令
npx skills add https://github.com/fwrite0920/android-skills --skill 'Deep Performance Tuning'
Skill 文档
Deep Performance Tuning (深度æ§è½ä¼å)
Instructions
- ä» å¨æéæµæ°æ®ææç¡®ç¶é¢æ¶ä½¿ç¨
- ä¾ç §ä¸æ¹ç« è顺åºå¥ç¨
- 䏿¬¡åªæ½ä½ä¸ç§ä¼åå¹¶éªè¯ææ
- 宿åå¯¹ç § Quick Checklist
When to Use
- Scenario Dï¼æ§è½é®é¢ææ¥
- Scenario Eï¼åå¸åæ§è½éªè¯
Example Prompts
- “请åè App Startup Optimizationï¼å建 Macrobenchmark æµé”
- “ç¨ Memory Analysis ç« èï¼è§åå ååææµç¨”
- “请ä¾ç § R8/Proguard Optimizationï¼æ£æ¥è§åæ¯å¦å®æ´”
Workflow
- å åå»ºéæµåºåï¼Startup/Memory/UIï¼
- åéä¸å¥ç¨å¯¹åºä¼åææ®µ
- æåç¨ Quick Checklist éªæ¶
Practical Notes (2026)
- Baseline Profile + Macrobenchmark ä½ä¸ºé»è®¤æµç¨
- æ¯æ¬¡åªåä¸é¡¹ä¼å并鿵差å¼
- æ§è½é¨æ§è¦è¿ CI Gate
Minimal Template
ç®æ :
éæµåºå:
ä¼åèå´:
å彿æ :
éªæ¶: Quick Checklist
App Startup Optimization
Macrobenchmark æµé
@LargeTest
@RunWith(AndroidJUnit4::class)
class StartupBenchmark {
@get:Rule
val benchmarkRule = MacrobenchmarkRule()
@Test
fun startupCompilationNone() = startup(CompilationMode.None())
@Test
fun startupCompilationPartial() = startup(CompilationMode.Partial())
private fun startup(compilationMode: CompilationMode) {
benchmarkRule.measureRepeated(
packageName = "com.example.app",
metrics = listOf(StartupTimingMetric()),
compilationMode = compilationMode,
iterations = 5,
startupMode = StartupMode.COLD
) {
pressHome()
startActivityAndWait()
}
}
}
Baseline Profiles
// çæ Baseline Profile
@RunWith(AndroidJUnit4::class)
class BaselineProfileGenerator {
@get:Rule
val rule = BaselineProfileRule()
@Test
fun generate() {
rule.collect("com.example.app") {
pressHome()
startActivityAndWait()
// å
³é®è·¯å¾
device.findObject(By.text("Login")).click()
device.wait(Until.hasObject(By.text("Home")), 5000)
}
}
}
Application onCreate ä¼å
class MyApplication : Application() {
override fun onCreate() {
super.onCreate()
// â 忥åå§å (Block UI)
// Firebase.initialize(this)
// Timber.plant(DebugTree())
// â
å»¶è¿åå§å
AppInitializer.getInstance(this)
.initializeComponent(FirebaseInitializer::class.java)
// â
èæ¯åå§å
ProcessLifecycleOwner.get().lifecycle.addObserver(
object : DefaultLifecycleObserver {
override fun onCreate(owner: LifecycleOwner) {
lifecycleScope.launch(Dispatchers.Default) {
// éå
³é®åå§å
}
}
}
)
}
}
Memory Analysis
Heap Dump åæ
# åå¾ Heap Dump
adb shell am dumpheap com.example.app /data/local/tmp/heap.hprof
adb pull /data/local/tmp/heap.hprof
# ä½¿ç¨ Android Studio Profiler åæ
# æä½¿ç¨ MAT (Memory Analyzer Tool)
LeakCanary 设置
// build.gradle.kts
debugImplementation("com.squareup.leakcanary:leakcanary-android:2.12")
// èªå®ä¹æ¥å
class MyApplication : Application() {
override fun onCreate() {
super.onCreate()
LeakCanary.config = LeakCanary.config.copy(
retainedVisibleThreshold = 3,
objectInspectors = AndroidObjectInspectors.appDefaults
)
}
}
Bitmap å å管ç
// ä½¿ç¨ Coil èªå¨ç®¡ç
AsyncImage(
model = ImageRequest.Builder(LocalContext.current)
.data(imageUrl)
.size(Size.ORIGINAL) // æ ¹æ®éæ±è°æ´
.memoryCachePolicy(CachePolicy.ENABLED)
.build(),
contentDescription = null
)
R8/Proguard Optimization
èªå®ä¹è§å
# ä¿ç Serializable
-keepclassmembers class * implements java.io.Serializable {
static final long serialVersionUID;
private static final java.io.ObjectStreamField[] serialPersistentFields;
!static !transient <fields>;
private void writeObject(java.io.ObjectOutputStream);
private void readObject(java.io.ObjectInputStream);
}
# ä¿ç Retrofit Interface
-keep,allowobfuscation interface * {
@retrofit2.http.* <methods>;
}
# ä¿ç Compose stability
-keep class * {
@androidx.compose.runtime.Stable *;
@androidx.compose.runtime.Immutable *;
}
APK Size åæ
# ä½¿ç¨ bundletool
bundletool build-apks --bundle=app.aab --output=app.apks
bundletool get-size total --apks=app.apks
# Android Studio: Build > Analyze APK
UI Performance
JankStats
class MainActivity : ComponentActivity() {
private lateinit var jankStats: JankStats
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
jankStats = JankStats.createAndTrack(window) { frameData ->
if (frameData.isJank) {
Log.w("Jank", "Frame took ${frameData.frameDurationUiNanos / 1_000_000}ms")
}
}
}
}
Compose Recomposition Tracking
// æå¼ Composition Tracking
@Composable
fun DebugComposable() {
SideEffect {
Log.d("Recomposition", "DebugComposable recomposed")
}
}
// ä½¿ç¨ Layout Inspector æ£æ¥ recomposition count
Quick Checklist
- Startup: Baseline Profiles çæ
- Startup: Application onCreate å»¶è¿åå§å
- Memory: LeakCanary æ æ³æ¼
- APK: R8 è§åå®å
- UI: JankStats æ 严éæå¸§