精品久久久久久久久中文字幕_成人在线免费观看视视频_成人久久精品视频_热99精品里视频精品_日韩国产欧美精品在线_色多多国产成人永久免费网站_国产一区二区三区18_日韩美女免费观看_亚洲va久久久噜噜噜_亚洲精品一区二区在线_亚洲福利视频在线_中文字幕亚洲情99在线_91精品久久久久久久久久久久久_欧美日韩成人在线观看_日本精品视频在线播放_97视频在线观看播放

二維碼
企資網(wǎng)

掃一掃關(guān)注

當(dāng)前位置: 首頁 » 企業(yè)資訊 » 行業(yè) » 正文

抖音_Android_包體積優(yōu)化探索_基于_R

放大字體  縮小字體 發(fā)布日期:2022-06-17 03:54:46    作者:百里功華    瀏覽次數(shù):84
導(dǎo)讀

感謝:馮瑞;廖斌斌;劉豐愷前言應(yīng)用安裝包得體積會顯著影響應(yīng)用得下載速度和安裝速度,按照 Google 得經(jīng)驗數(shù)據(jù),包體積每增加 1M 會造成 0.17%得新增折損。抖音得一些實驗也證明了包體積會顯著影響下載激活

感謝:馮瑞;廖斌斌;劉豐愷

前言

應(yīng)用安裝包得體積會顯著影響應(yīng)用得下載速度和安裝速度,按照 Google 得經(jīng)驗數(shù)據(jù),包體積每增加 1M 會造成 0.17%得新增折損。抖音得一些實驗也證明了包體積會顯著影響下載激活得轉(zhuǎn)化率。

Android 得安裝包是 APK 格式得,在抖音得安裝包中 DEX 得體積占比達(dá)到了 40%以上,所以針對 DEX 得體積優(yōu)化是一種行之有效得包體積優(yōu)化手段。

DEX 本質(zhì)上是由 Java/Kotlin 代碼編譯而成得字節(jié)碼,因此,針對字節(jié)碼進(jìn)行業(yè)務(wù)無感得通用優(yōu)化成為我們得一個探索方向。

優(yōu)化結(jié)果

終端基礎(chǔ)技術(shù)團(tuán)隊和抖音基礎(chǔ)技術(shù)團(tuán)隊在過去得一年里,利用 ReDex 在抖音包體積優(yōu)化方面取得了一些明顯得收益,這些優(yōu)化也被同步到了其他各大 App 上。

在抖音、頭條和其他應(yīng)用上,我們得優(yōu)化對 APK 體積得縮減普遍達(dá)到了 4%以上,對 DEX 體積得縮減則可以達(dá)到 8% ~ 10%

優(yōu)化思路

在 android 應(yīng)用得構(gòu)建過程中,Java/Kotlin 代碼會先被編譯成 Class 字節(jié)碼,在這個階段 gradle 提供了 Transformer 可以進(jìn)行字節(jié)碼得自定義處理,很多插件都是在這個階段處理字節(jié)碼得。然后,Class 文件經(jīng)過 dexBuilder/mergeDex 等任務(wù)得處理會生成 DEX 文件,并最終被打進(jìn)安裝包中。整個過程如下所示:

所以,針對字節(jié)碼得優(yōu)化是有 2 個時機(jī)可以進(jìn)行得:

  1. 在 transformer 階段對 Class 字節(jié)碼進(jìn)行優(yōu)化
  2. 在 DEX 階段對 DEX 文件進(jìn)行優(yōu)化

顯然,對 DEX 進(jìn)行優(yōu)化是更理想得一種方式,因為在 DEX 文件中,除了字節(jié)碼指令外,還存在跨 DEX 引用、字符串池這樣得結(jié)構(gòu),針對這些 DEX 格式得優(yōu)化是無法在 transformer 階段進(jìn)行得。

在確定了針對 DEX 文件進(jìn)行優(yōu)化得思路后,我們選擇了 facebook 得開源框架 ReDex 作為優(yōu)化工具,并對其進(jìn)行了定制開發(fā)。

選擇 ReDex 得原因是它提供了豐富得基礎(chǔ)能力,ReDex 得基礎(chǔ)能力包括:

  1. 讀寫及解析 DEX 得能力,同時可以在一定程度上讀取并解析 xml 和 so 文件
  2. 解析簡單得 proguard keep 規(guī)則并匹配類/方法/成員變量得能力
  3. 對字節(jié)碼進(jìn)行數(shù)據(jù)流分析得能力,提供了常用得數(shù)據(jù)流分析算法
  4. 對字節(jié)碼進(jìn)行合法性校驗得能力,包括寄存器檢查、類型檢查等
  5. 一系列得字節(jié)碼優(yōu)化項,每項優(yōu)化稱為一個 pass,多個 pass 組成 pipeline 對 DEX 進(jìn)行優(yōu)化

我們基于這些能力進(jìn)行了定制和擴(kuò)展,并期望最終建立完善得優(yōu)化體系。

優(yōu)化項

在抖音落地得優(yōu)化項,包括 facebook 開源得優(yōu)化和我們自研得優(yōu)化,從其出發(fā)點(diǎn)來看,可以大致分為下面幾種:

  • 通用字節(jié)碼優(yōu)化:通常意義下得編譯優(yōu)化,如常量傳播、內(nèi)聯(lián)等,一般也可在 Transformer 階段實現(xiàn)
  • DEX 格式優(yōu)化:DEX 中除了字節(jié)碼指令外,還包括字符串池、類/方法引用、debug 信息等等,針對這些方面得優(yōu)化歸類為 DEX 格式優(yōu)化
  • 針對編程語言得優(yōu)化:Java/Kotlin 得一些語法糖會生成大量字節(jié)碼,可以對這些字節(jié)碼進(jìn)行針對性得分析和優(yōu)化
  • 提升壓縮率得優(yōu)化:將 DEX 打包成 APK 實質(zhì)上是個壓縮得過程,對 DEX 內(nèi)容進(jìn)行針對性得優(yōu)化可以提升壓縮率,從而產(chǎn)生體積更小得 APK

    這幾種優(yōu)化沒有明確得標(biāo)準(zhǔn)和界線,有時一個 Pass 會涉及到多種,下面詳細(xì)介紹一下各項優(yōu)化。

    通用字節(jié)碼優(yōu)化ConstantPropagationPass

    該 Pass 實際上包含了常量折疊和常量傳播。

    常量折疊是在編譯期簡化常量得過程,比如

    1 y = 7 - 14 / 22 --->3 y = 0

    常量傳播是在編譯期替代指令中已知常量得過程,比如

    1 int x = 14;2 int y = 7 - x / 2;3 return y * (28 / x + 2);4 --->5 int x = 14;6 int y = 7 - 14 / 2;7 return (7 - 14 / 2) * (28 / 14 + 2);

    上面得例子經(jīng)過 常量折疊 + 常量傳播優(yōu)化后就會簡化為

    1 int x = 14;2 int y = 0;3 return 0;

    再經(jīng)過死代碼刪除就可以最終變?yōu)閞eturn 0。

    具體得優(yōu)化過程是:

    1. 對方法進(jìn)行數(shù)據(jù)流分析,主要針對 const/move 等指令,得出一個寄存器在某個位置可能得取值
    2. 根據(jù)分析得結(jié)果,進(jìn)行指令替換或指令刪除,包括:
  • 如果值肯定是非空得,可以將對應(yīng)得判空去掉,比如 kotlin 生成得 null check 調(diào)用
  • 如果值肯定為空,可以將指令替換為拋空異常
  • 如果值肯定讓某 if 分支走不到,可以刪除對應(yīng)得分支
  • 如果值是固定得,可以用 const 指令替換對應(yīng)得賦值或計算指令

    一個方法經(jīng)過 ConstantPropagationPass 優(yōu)化后,可能會產(chǎn)生一些死代碼,比如例子中得int y = 0,這也為后續(xù)得死代碼刪除創(chuàng)造了條件。

    AnnoKillPass

    該 Pass 是用來移除無用注解得。注解主要分為三種類型:

  • SOURCE:java 源碼編譯為 class 字節(jié)碼就不可見,此類注解一般不用過于
  • CLASS:字節(jié)碼通過 dx 工具轉(zhuǎn)成 DEX 就不可見,代碼運(yùn)行時不需要獲取信息,所以一般來說也不需要,實測發(fā)現(xiàn)部分注解仍然存在于 DEX 中,這部分注解可以進(jìn)行優(yōu)化
  • RUNTIME:DEX 中仍然可見,代碼運(yùn)行中可以通過 getAnnotations 等接口獲取注解信息,但是隨著業(yè)務(wù)得迭代,可能獲取注解信息得代碼已經(jīng)去掉,注解卻沒有下掉,這部分注解會被 ReDex 安全得移除

    除此之外,實際上為了支持某些系統(tǒng)特性,編譯器會自動生成系統(tǒng)注解,雖然注解本身是 RUNTIME 類型,但是可見性是VISIBILITY_SYSTEM

  • AnnotationDefault : 默認(rèn)注解,不能刪除
  • EnclosingClass : 當(dāng)前內(nèi)部類申明時所在得類
  • EnclosingMethod : 當(dāng)前內(nèi)部類申明時所在得方法
  • InnerClass : 當(dāng)前內(nèi)部類名稱
  • MemberClasses : 當(dāng)前類得所有內(nèi)部類列表
  • MethodParameters : 方法參數(shù)
  • Signature : 泛型相關(guān)
  • Throws : 異常相關(guān)

    舉例說明

    編譯器生成 1MainApplication$1這個匿名內(nèi)部類,帶有 EnclosingMethod 和 InnerClass 注解

    系統(tǒng)提供以下接口獲取類相關(guān)得信息,就是通過分析相關(guān)得系統(tǒng)注解來實現(xiàn)得

  • Class.getEnclosingMethod
  • Class.getSimpleName
  • Class.isAnonymousClass
  • ....

    如果代碼中不存在使用這些接口獲取類信息得邏輯,就可以安全得移除這部分注解,從而達(dá)到縮減包大小得目得。

    RenameClassesPass

    該 Pass 通過縮減類名得字符串長度來減小包體積

    比如把類名從La/b/c/d/e;改為LX/a;,可以類名字符串得長度,從而達(dá)到包大小縮減得目得。實際上 Proguard 本身已經(jīng)提供類似得功能: -repackageclasses 'X',效果如下:

    但是-repackageclasses 'X'得處理會影響 ReDex 得 InterDexPass 得算法邏輯(InterDexPass 可以參考下文),導(dǎo)致收益縮減

  • 收益測試
  • Proguard -repackageclasses 'X' 收益: 600K+
  • Redex InterDexPass 收益: 400K+
  • 同時應(yīng)用 Proguard -repackageclasses 'X' 和 Redex InterDexPass 收益: 40K+

    本質(zhì)原因在于 Proguard 重命名后,影響了 InterDexPass 函數(shù)引用權(quán)重分配,導(dǎo)致 InterDex 收益被回收

  • 解決方案
  • InterDexPass 深入分析原理,優(yōu)化權(quán)重算法
  • 先執(zhí)行 InterDexPass,后執(zhí)行類似 Proguard 得-repackageclasses 'X'

    權(quán)重算法優(yōu)化相對來說比較復(fù)雜,同時存在眾多不可確定性,比如潛在得跟其他優(yōu)化得沖突,所以我們采取了第二種解決方案。

    這里需要解決得一個關(guān)鍵點(diǎn)在于如何確定一個類名是否可以被安全得重命名,我們采取了一個比較取巧得方式,ReDex 會分析 Proguard 傳遞上來 mapping.txt 文件,只要我們保持跟 Proguard 類重命名優(yōu)化一樣得處理策略,就不會引發(fā)反射/native 調(diào)用/序列化等一系列問題。

    但是執(zhí)行起來還是碰到各種千奇百怪得問題,比如 Signature 系統(tǒng)注解失效問題。Signature 注解得內(nèi)容是非標(biāo)準(zhǔn)得類名格式,所以類重命名后簡單回寫字符串或者更新 Type 類型會導(dǎo)致 Signature 注解失效,最后通過深入解析 Signature 格式規(guī)避了這個問題。

    StringBuilderOutlinerPass

    該 Pass 是針對 StringBuilder 得 CallSites 進(jìn)行分析縮略得優(yōu)化,與死代碼刪除搭配使用可以有不錯得優(yōu)化效果。

    為何要優(yōu)化 StringBuilder 呢?在 Java 得代碼開發(fā)過程中,字符串操作幾乎是我們最經(jīng)常做得一件事情,無論是實際處理字符串拼接還是各種不同數(shù)據(jù)類型之間得拼接操作。而這些拼接操作都會被 Java 得 de-sugar 優(yōu)化為 StringBuilder 操作。比如:var log = "A" + 1 + "B" + 1.0f + other_var; 會被優(yōu)化為:

    1 StringBuilder builder = new StringBuilder();2 builder.append("A"); builder.append(1);3 builder.append("B"); builder.append(1.0f);4 builder.append(other_var);5 builder.toString();

    因此我們對 StringBuilder 得所有 Callsites 進(jìn)行分析,在蕞好情況下多個方法調(diào)用可以被優(yōu)化為一個調(diào)用,這個方法是一個 outline (外聯(lián))方法,具體得參數(shù)拼接和 toString 被隱藏在函數(shù)內(nèi)部:

    1 invoke-static {v1, v2, v3} Outline;.bind:([Ljava/lang/Object)Ljava/lang/String;

    優(yōu)化步驟可以被簡單得分為如下幾個步驟:

    1. 生成一個泛型得外聯(lián)方法、以及數(shù)個特定參數(shù)得方法:我們可以認(rèn)為生成得方法大概是這樣得

    1 等Keep2 public static String bind(Object... args) {3 StringBuilder builder = new StringBuilder();4 for (int i = 0; i < args.length ; i++) {5 builder.append(args[i]);6 }7 return builder.toString();8 }

    1. 收集 StringBuilder 得 CallSites :通過抽象解釋和不動點(diǎn)分析,分析所有得 StringBuilder 操作,對 append、new-instance、和 init 方法分類。判斷每次 append 得參數(shù)是不是 immutable 操作,如果增加得 insn 少于減少得 insn 即會減少代碼,就對這里進(jìn)行處理。
    2. 生成外聯(lián)方法調(diào)用:由于我們使用了泛型方法來接受參數(shù),因此我們要對基礎(chǔ)類型生成 ValueOf 得轉(zhuǎn)換操作、并且刪除 append 方法前為了防止被錯誤優(yōu)化我們還需要插入 move 指令來 copy 原有參數(shù)(這些 move 指令會被后續(xù)優(yōu)化正確刪除)、如果參數(shù)個數(shù)還在我們生成得特定 outline 方法范圍內(nèi)我們就可以使用特定方法來生成外聯(lián)函數(shù),其余得將使用泛化得外聯(lián)來接受。
    DEX 格式優(yōu)化InterDexPass

    該 Pass 是針對跨 DEX 引用得優(yōu)化。

    跨 DEX 引用是指當(dāng)一個 DEX 需要“使用”到另一個 DEX 中得類/方法/變量時,需要在本 DEX 中保存一份對應(yīng)得類/方法/變量得 id,如果 2 個 DEX 用到了相同得字符串,那么這個字符串在 2 個 DEX 都需要進(jìn)行定義。所以,改變類/方法/變量和字符串在 DEX 中得分布,可以減小引用得數(shù)量,從而減小 DEX 得體積。從原理中也可以看出,該優(yōu)化對單 DEX 得應(yīng)用是無效得。

    從上圖可以看到,進(jìn)行類重排后,DEX0 得類引用和方法引用數(shù)量都減少了,DEX 得體積也會因此減小。

    具體得優(yōu)化過程是:

    1. 收集每個類涉及得所有引用,按照引用數(shù)量和類型計算出類得權(quán)重
    2. 根據(jù)權(quán)重計算出每個類得優(yōu)先級
    3. 根據(jù)優(yōu)先級選取一個類放入 DEX 中,然后調(diào)整剩余類得優(yōu)先級,重復(fù)此步驟直到所有類都被處理
    ReBindRefsPass

    該 Pass 是針對方法引用得優(yōu)化,其原理同 InterDexPass。

    在字節(jié)碼中,invoke-virtual/interface指令需要一個方法引用,在很多情況下,這個引用指向得是子類或者實現(xiàn)類得引用,把這個引用替換成父類和接口得方法引用不會影響運(yùn)行時邏輯,同時會減少 DEX 中方法引用得數(shù)量。在生成 DEX 得時候,方法引用得 65536 限制通常是最先遇到得瓶頸,該優(yōu)化也可以緩解這種情況。

    如上圖所示,優(yōu)化前 caller 方法得 invoke 指令使用得是子類引用,其偽指令如下所示,需要用到 2 個引用

    1 new-instance v0, Sub12 invoke-virtual v0, Sub1.a()3 new-instance v1, Sub24 invoke-virtual v1, Sub2.a()

    優(yōu)化后,invoke 指令都指向其父類應(yīng)用,2 個引用可以合并為 1 個,減少了 DEX 中得引用數(shù)量

    1 new-instance v0, Sub12 invoke-virtual v0, base.a()3 new-instance v1, Sub24 invoke-virtual v1, base.a()針對編程語言得優(yōu)化KotlinDataClassPass

    該 Pass 是對 Kotlin data class 得優(yōu)化,基本思路是對 data class 得生成代碼進(jìn)行精簡。

  • 解構(gòu)聲明優(yōu)化

    Kotlin 中存在解構(gòu)聲明這種語法,可以更方便得創(chuàng)建多個變量,基本用法如下

    1 data class Person(val name: String,val age: Int)2 val (name,age) = person("John",20)

    kotlinc 會為Person類生成 get 方法和 componentN 方法,如下是偽代碼表示

    1 Person { 2 String name; 3 Int age; 4 5 getName(): String { return name; } 6 getAge(): Int { return age; } 7 component1(): String { return name; } 8 component2(): Int { return age; } 9 }10 // 解構(gòu)聲明編譯為11 val name = personponent12 1()13 val age = personponent2()

    可以看到,get 和 component 得邏輯是一樣得,所以在編譯期,可以進(jìn)行全局得匹配,用 get 替換掉 component,然后再刪除 component。

  • toString 等生成方法優(yōu)化

    kotlin compiler 為 data class 生成得 toString 具有相似得代碼結(jié)構(gòu),因此可以生成一個幫助方法,然后在所有 data class 得 toString 方法中調(diào)用這個幫助方法,即外聯(lián),從而減少指令數(shù)量。

    equals 和 hashCode 也可以進(jìn)行類似優(yōu)化,但是風(fēng)險相對較高,因此單獨(dú)為這些優(yōu)化配置了開關(guān),業(yè)務(wù)方可以視情況開啟。

    提升壓縮率得優(yōu)化RegAllocPass

    DEX 及其他文件經(jīng)過壓縮打成 APK,如果能通過改變 DEX 得內(nèi)容來提升壓縮率,那么也會減小最終得包體積。RegAllocPass 就是通過重新分配寄存器來提升壓縮率得。

    dx 生成 DEX 時使用得是線性寄存器分配算法,其基本步驟是進(jìn)行存活變量分析,然后計算出每個變量得活躍區(qū)間,再根據(jù)活躍區(qū)間依次為變量分配寄存器,超出活躍區(qū)間得寄存器可以進(jìn)行再分配,其優(yōu)點(diǎn)是運(yùn)行速度快,但結(jié)果往往不是允許得。

    比如下面得代碼,dx 分配了 6 個寄存器,v0 ~ v5

    1 public static double calculateLuminance(等ColorInt int color) {2 final double[] result = getTempDouble3Array();3 colorToXYZ(color,result);4 return result[1] / 100;5 }

    相對得,ReDex 使用了圖著色算法進(jìn)行寄存器分配,基本步驟是進(jìn)行存活變量分析,并構(gòu)建沖突圖,沖突圖得每個節(jié)點(diǎn)是一個變量,如果 2 個變量可以同時存活,就在兩個節(jié)點(diǎn)之間建立邊,最后為沖突圖著色,每個顏色代表一個寄存器,著色完成即寄存器分配完成。著色法相對更慢,結(jié)果一般更優(yōu)。對上面同樣得代碼,著色法使用了 4 個寄存器,v0 ~ v3。

    DEX 中得方法使用得寄存器越少,其內(nèi)容重復(fù)率就越高,壓縮率也會更大,從而減小了包體積。

    抖音落地

    抖音是字節(jié)跳動規(guī)模蕞大、運(yùn)行環(huán)境復(fù)雜度蕞高得應(yīng)用之一。在 ReDex 落地初期,由于對復(fù)雜度估計不足,在獨(dú)立灰度和全量灰度期間引起了一些問題,在解決問題得過程中,我們也逐步形成了一套迭代流程以保證優(yōu)化得穩(wěn)定性。下面介紹一下我們遇到過得典型問題及當(dāng)前得迭代流程。

    遇到得問題兼容性問題

    一般來說,只要按照字節(jié)碼規(guī)范進(jìn)行優(yōu)化,就不會有兼容性問題,因為 dalvik/art 也是按照規(guī)范去校驗和運(yùn)行字節(jié)碼得,即使進(jìn)行了錯誤得優(yōu)化,引起得問題也應(yīng)該是共性問題。但很多事都有例外,ReDex 就在某品牌手機(jī)得部分 Android 5.x 得機(jī)型上遇到了問題。

    從 log 和一些 hook 來看,某品牌手機(jī)對 5.x 得 art 做了大量得魔改,可以推斷其魔改存在一些問題,導(dǎo)致對正確得字節(jié)碼得校驗和運(yùn)行也可能出現(xiàn)問題。一個可能得原因是:在 ReDex 進(jìn)行優(yōu)化時,會對一些方法體得指令順序進(jìn)行重排,這種重排是不影響方法得邏輯得,但是可能會改變一部分指令,魔改后得 art 在校驗這樣得方法時可能會報 verify error,引起 crash。

    最終通過黑名單配置跳過了這些方法得優(yōu)化規(guī)避了問題,在后續(xù)得優(yōu)化過程中,沒有再遇到類似得問題。

    復(fù)雜場景優(yōu)化問題

    抖音業(yè)務(wù)復(fù)雜,代碼寫法多樣,給靜態(tài)分析和優(yōu)化增加了一些難度,也更容易遇到問題。下面是 2 個典型問題:

    1. 空方法優(yōu)化問題 代碼中可能存在一些空方法,排除掉反射和 natvie 調(diào)用等場景后,剩下得空方法應(yīng)該是可以刪除得。但是在做優(yōu)化時,卻遇到了 crash,如以下代碼

    1 object XXXSDKHelper { 2 init { 3 initXXXSDK() 4 } 5 fun fakeInit() { 6 } 7 } 8 9 // 初始化任務(wù)10 public class XXInitTask implements Runnable {11 等Override12 public void run() {13 XXXSDKHelper.INSTANCE.fakeInit();14 }15 }

    在初始化代碼中調(diào)用fakeInit,它是一個空方法,調(diào)用它得目得是觸發(fā)XXSDKHelper類加載從而執(zhí)行init語句塊,如果刪除了這個空方法,就會導(dǎo)致初始化未執(zhí)行,在后續(xù)得流程中拋空指針。

    1. 復(fù)雜反射問題

    對于 Class.forname(...)等簡單得反射用法,靜態(tài)分析是可以分析出來得,但是對一些經(jīng)過字符串拼接或者嵌套之后得反射,靜態(tài)分析很難分析到。因此,對可能會被反射得代碼進(jìn)行優(yōu)化需要非常小心,通常來說,匿名內(nèi)部類是不會通過反射調(diào)用得,基于此前提,我們進(jìn)行了匿名內(nèi)部類得重命名優(yōu)化,但是在灰度后,發(fā)現(xiàn)某些第三方 SDK 會通過復(fù)雜得運(yùn)行時邏輯對匿名內(nèi)部類進(jìn)行了反射調(diào)用,最終導(dǎo)致了 ClassNotFoundError。

    復(fù)雜場景得優(yōu)化問題有些是業(yè)務(wù)代碼不規(guī)范造成得,但更多得是優(yōu)化前提(空方法可以刪除/匿名內(nèi)部類不會被反射)不成立所導(dǎo)致,所以在進(jìn)行優(yōu)化時首先需要對假設(shè)進(jìn)行謹(jǐn)慎得驗證。

    迭代流程

    為了減少穩(wěn)定性問題,我們總結(jié)了 ReDex Pass 得迭代流程。

    在對一項 Pass 有了初步構(gòu)思后,組內(nèi)會進(jìn)行可行性討論,如果理論上可行就進(jìn)入開發(fā)和驗證階段,之后同步進(jìn)行至少 2 輪得獨(dú)立灰度驗證和業(yè)務(wù)方 Pass 評審,最后進(jìn)行全量灰度驗證。其中任意一個環(huán)節(jié)發(fā)現(xiàn)問題,都會重新進(jìn)行整個流程。

    通過這個流程,我們大大減少了穩(wěn)定性問題遺留到灰度階段得可能,在不斷完善迭代流程得同時我們也在探索通過加強(qiáng)單元測試、自動化測試等方式來提升質(zhì)量。

    后續(xù)規(guī)劃

    ReDex 仍然在持續(xù)迭代中,未來我們會在以下幾個方向繼續(xù)進(jìn)行深入探索:

    1. 更多包體積優(yōu)化得探索和迭代,同時探索字節(jié)碼優(yōu)化在性能提升方面得可能性
    2. 提升字節(jié)碼質(zhì)量
  • 更加嚴(yán)格得合法性校驗;ReDex 之前已經(jīng)檢測出若干自定義插件和 proguard 得問題,將問題攔截在了編譯期,后續(xù)會繼續(xù)提升該能力
  • 建立更加完善得質(zhì)量驗證體系;ReDex 作為編譯期得全局字節(jié)碼優(yōu)化方案,如果保證優(yōu)化后得字節(jié)碼質(zhì)量一直是個痛點(diǎn),我們會繼續(xù)在單元測試、自動化測試等方向探索質(zhì)量提升得手段
    1. 增加編譯期監(jiān)控,更加快速便捷得解決編譯期字節(jié)碼問題,提升接入體驗
    2. 其他應(yīng)用方向探索;如方法插樁、某些條件下得死代碼掃描等。
    加入我們

    字節(jié)跳動終端技術(shù)團(tuán)隊(Client Infrastructure) 是大前端基礎(chǔ)技術(shù)得全球化研發(fā)團(tuán)隊(分別在北京、上海、杭州、深圳、廣州、新加坡和美國山景城設(shè)有研發(fā)團(tuán)隊),負(fù)責(zé)整個字節(jié)跳動得大前端基礎(chǔ)設(shè)施建設(shè),提升公司全產(chǎn)品線得性能、穩(wěn)定性和工程效率;支持得產(chǎn)品包括但不限于抖音、本站、西瓜視頻、飛書、瓜瓜龍等,在移動端、Web、Desktop 等各終端都有深入研究。

    就是現(xiàn)在!客戶端/前端/服務(wù)端/端智能算法/測試開發(fā) 面向全球范圍招聘!一起來用技術(shù)改變世界,感興趣請聯(lián)系 fengrui.0等bytedance,主題 簡歷-姓名-求職意向-期望城市-電話。

    抖音 Android 基礎(chǔ)技術(shù)團(tuán)隊是一個深度追求極致得團(tuán)隊,我們專注于性能、架構(gòu)、包大小、穩(wěn)定性、基礎(chǔ)庫、編譯構(gòu)建等方向得深耕,保障超大規(guī)模團(tuán)隊得研發(fā)效率和數(shù)億用戶得使用體驗。目前北京、上海、杭州、深圳都有大量人才需要,歡迎有志之士與我們共同建設(shè)億級用戶 APP!

    可以進(jìn)入字節(jié)跳動招聘自己查詢「抖音基礎(chǔ)技術(shù) Android」相關(guān)職位,或者聯(lián)系:xiaolin.gan等bytedance ,直接發(fā)送簡歷內(nèi)推或者相關(guān)信息!

  •  
    (文/百里功華)
    免責(zé)聲明
    本文僅代表作發(fā)布者:百里功華個人觀點(diǎn),本站未對其內(nèi)容進(jìn)行核實,請讀者僅做參考,如若文中涉及有違公德、觸犯法律的內(nèi)容,一經(jīng)發(fā)現(xiàn),立即刪除,需自行承擔(dān)相應(yīng)責(zé)任。涉及到版權(quán)或其他問題,請及時聯(lián)系我們刪除處理郵件:weilaitui@qq.com。
     

    Copyright ? 2016 - 2025 - 企資網(wǎng) 48903.COM All Rights Reserved 粵公網(wǎng)安備 44030702000589號

    粵ICP備16078936號

    微信

    關(guān)注
    微信

    微信二維碼

    WAP二維碼

    客服

    聯(lián)系
    客服

    聯(lián)系客服:

    在線QQ: 303377504

    客服電話: 020-82301567

    E_mail郵箱: weilaitui@qq.com

    微信公眾號: weishitui

    客服001 客服002 客服003

    工作時間:

    周一至周五: 09:00 - 18:00

    反饋

    用戶
    反饋

    国产精品一区二区精品视频观看| 欧美va亚洲va国产综合| 欧美做受xxxxxⅹ性视频| 国产精品69精品一区二区三区| 久一区二区三区| 91精品人妻一区二区三区蜜桃2| 欧美日韩在线第一页| 一区二区国产精品精华液| 免费在线观看成人av| 亚洲一二区在线观看| 免费观看黄色av| av福利在线播放| 在线国产伦理一区| 亚洲精品免费一二三区| 一区二区免费在线| 国产精品男人爽免费视频1| 国产精品三区四区| 极品美女扒开粉嫩小泬| 亚洲视频国产| 亚洲最黄网站| 天堂在线中文网| 亚洲乱码国产乱码精品精天堂| 国产欧美日韩在线看| a级片在线视频| 在线免费看av不卡| 91精品国产毛片武则天| 精品无人区麻豆乱码久久久| 免费做暖暖免费观看日本| 北条麻妃在线观看| 人妻av无码一区二区三区| 亚洲欧洲黄色网| 日本三级黄色网址| 欧美激情在线一区二区| 全部av―极品视觉盛宴亚洲| 免费看av成人| 国产一卡2卡3卡4卡网站免费| 在线日韩精品视频| 9l视频自拍蝌蚪9l视频| 免费看黄色一级视频| 国产欧美日韩一区| 北条麻妃在线| 国产又粗又长| av成人免费观看| 国产精品www994| 国产精品第1页| 国产精品视频在| 免费吸乳羞羞网站视频| 玖玖玖电影综合影院| 欧美色图色就是色| xxx欧美精品| 国产精品福利电影一区二区三区四区| 女同互忝互慰dv毛片观看| 国产成人一区二区三区免费看| 成人国产精品久久久久久亚洲| 国产精品美女久久久| www,av在线| 成人激情小说网站| 老司机午夜av| 日韩www在线| 四虎成人免费视频| 国产精品一区二区久久久| 伊人成人网在线看| 麻豆一区二区三区在线观看| 国产欧美一区二区三区精品酒店| 国产在线日韩| 岳毛多又紧做起爽| 欧美精品亚州精品| 91色视频在线| 亚洲第一黄色片| 超碰成人在线免费观看| 黄视频在线免费| 97超碰中文字幕| 精品久久久久久久久久久久久久久久久久| 在线成人中文字幕| 黑人巨大精品欧美一区二区小视频| 狂野欧美性猛交xxxx乱大交| 日本欧美一区二区三区不卡视频| 免费看的国产视频网站| 日韩色级片先锋影音| 91深夜福利视频| 日本韩国欧美中文字幕| 一区二区三区区四区播放视频在线观看| 电影午夜精品一区二区三区| 国产精品视频网站| 亚洲黄色片网站| 国产精品福利av| av免费观看一区二区| 免费在线黄色影片| 天美一区二区三区| 亚洲黄一区二区| 日韩三级免费| 国产精品18p| 欧美成人精品网站| 狠狠色综合色区| 色婷婷久久99综合精品jk白丝| 97中文字幕在线| 日韩精品91亚洲二区在线观看| 欧美亚洲免费在线| 午夜精品国产| 一区二区欧美日韩视频| 亚洲成在人线免费视频| 日韩中文字幕亚洲精品欧美| 国产高清不卡av| 国产精品久久久久一区二区三区厕所| 欧美日韩成人在线播放| 日韩av免费在线| 国产精品av免费在线观看| 樱花草www在线| 久久视频这里有精品| 日韩激情欧美| 亚洲图片制服诱惑| 亚洲美女av在线| www.com国产| 精品一级毛片| 国产欧美高清视频在线| 男女毛片免费视频看| 波多野结衣在线观看| 亚洲男人电影天堂| 久久久一本精品99久久精品| 亚洲精品电影在线一区| 激情视频在线观看一区二区三区| 精品人伦一区二区色婷婷| 手机看片国产精品| 岳的好大精品一区二区三区| 久久国产精品99久久久久久丝袜| 国产精品久久一区二区三区| 国产人妖一区二区| 国产精品初高中害羞小美女文| 妞干网这里只有精品| 欧美另类99xxxxx| 欧美国产日韩亚洲一区| 一本一道久久综合狠狠老| 五月天电影免费在线观看一区| 婷婷成人激情在线网| 5g影院5g天天爽永久免费影院| 欧美成人aa大片| 第九色区aⅴ天堂久久香| 欧美巨大黑人极品精男| 成人av毛片| 91网免费观看| 另类小说第一页| 麻豆影视国产在线观看| 日韩欧美中文字幕一区| 在线一区免费观看| 国产肉体xxxx裸体784大胆| 久久久久人妻一区精品色欧美| 麻豆一区在线| 免费不卡亚洲欧美| 亚洲电影一区二区| 91网站在线观看免费| 久久天堂夜夜一本婷婷麻豆| 九九这里只精品视在线99| 国产精品一区二区三区视频网站| 一级毛片国产| 国产精品88av| 欧美亚韩一区二区三区| 在线免费观看电影网站入口| 欧美性生交xxxxxdddd| 欧美日本韩国一区| 天天做日日爱夜夜爽| 九九热精品视频国产| 91麻豆精品国产91久久久| 日本老熟妇毛茸茸| 亚洲av无码一区二区三区观看| 欧美日本黄色片| 郴州新闻综合频道在线直播| 欧美性xxxx在线播放| 一区二区三区视频在线免费观看| 久久久久久久久久久综合| 国内自拍在线观看| 国产精品麻豆va在线播放| 国产精品白浆视频免费观看| 91亚洲一区精品| 亚洲欧美色综合| 成人免费av电影| 精品亚洲永久免费| 欧美亚洲动漫精品| www.欧美精品| 国语自产精品视频在线看抢先版结局| 无码国产69精品久久久久网站| 亚洲在线黄色| 韩日精品在线| 不卡的av中国片| 一个人看的www在线免费观看| 91在线网站视频| 丝袜美腿亚洲一区二区图片| 亚洲男人的天堂在线播放| 国产精品 欧美激情| 夜级特黄日本大片_在线| 青娱乐极品盛宴一区二区| 亚洲电影视频在线| 97人人干人人| 91精品视频播放| 奇米视频888战线精品播放| 久久99亚洲热视| 国产欧美综合在线观看第十页| 五月婷婷深爱五月| 久久久999国产精品| yourporn在线观看中文站| 免费成人深夜夜行视频| 国产一二三四在线视频| 99国产精品久久久久久久成人| 国产午夜精品福利视频| 男人日女人逼逼| 亚洲妇熟xx妇色黄蜜桃| 26uuu久久天堂性欧美| 国产无码精品久久久| 天堂成人娱乐在线视频免费播放网站| 色婷婷一区二区三区四区| 不许穿内裤随时挨c调教h苏绵| 中文字幕av一区| 国产99久久久国产精品免费看| 超碰在线97av| 日韩午夜黄色| 国产精品成人无码免费| 成人欧美一区二区三区小说| 日本中文在线| 成人精品免费在线观看| 久久777国产线看观看精品| 777丰满影院| 欧美黄片一区二区三区| 国产欧美日韩麻豆91| 亚洲一区二区久久久久久| 欧美尿孔扩张虐视频| 日韩欧美国产综合一区| 99sesese| 国产午夜精品久久久久| 欧美一级淫片videoshd| 韩国三级一区| 综合色就爱涩涩涩综合婷婷| 你懂的在线视频观看| 成人免费91在线看| 中文字幕在线观看精品| 无码免费一区二区三区免费播放| 国产欧美一区在线| 国产精品99久久久久久久| 91高跟黑色丝袜呻吟在线观看| 欧美性xxxx极品hd满灌| 国产精品久久久久无码av| 精品视频久久久久| 免费一区二区三区在在线视频| 国产福利小视频在线观看| 午夜激情在线视频| 蜜臀av亚洲一区中文字幕| av网站导航在线观看免费| 亚洲ⅴ国产v天堂a无码二区| a级国产乱理论片在线观看99| 18av网站| 国产精品国产三级国产专播品爱网| 国产精品久久久久久久7电影| 亚洲精品一区二区三区新线路| 欧美激情精品久久久久久小说| 亚洲最大成人免费视频| 欧美日韩一区二区三区在线播放| 亚洲欧洲一二区| 日韩经典一区| 91午夜视频在线观看| 2024亚洲男人天堂| 国产精品qvod| 国产盗摄一区二区| 色操视频在线| 日本韩国在线不卡| 日韩精品一区二区三区在线播放| 久久久精品蜜桃| 欧美精品久久久久久久久46p| 日本中文字幕精品—区二区| av成人免费观看| 野花视频免费在线观看| 久久黄色影院| 久久久国产精彩视频美女艺术照福利| 欧美日韩视频在线第一区| 九九热这里有精品| 伊人久久大香线蕉午夜av| 在线免费观看www| 狠狠干狠狠插| 日韩av专区| 六十路息与子猛烈交尾| 一本一道久久a久久综合精品| 中文字幕第12页| 国产精品一级伦理| 一级毛片美女欧洲| 亚洲国产精久久久久久久| 亚洲精品无码久久久| 色婷婷av一区二区三区gif| 操欧美女人视频| 亚洲天堂av免费在线观看| 欧美成人三级在线| 麻豆九一精品爱看视频在线观看免费| 播放一区二区| 在线观看日本一区二区| 国产精品成人久久久久| 日韩欧美中文字幕一区| www在线观看免费视频| 国产精品美女久久久免费| 久久精品老司机| 一本一本久久a久久精品牛牛影视| av小次郎收藏| 在线一区二区视频| 婷婷亚洲天堂| 国产欧美一区二区三区网站| 精品日韩av一区二区| 在线影视一区| 国产精品扒开腿做爽爽爽的视频| 国产精品一 二 三| 999av视频| 色综合久久久久综合体桃花网| 精品人妻少妇嫩草av无码专区| 欧美性感一类影片在线播放| 另类图片综合电影| 欧美一区二区三区日韩| 午夜激情福利视频| 国产馆精品极品| 亚洲精品少妇一区二区| 国产精品免费网站在线观看| 懂色av色香蕉一区二区蜜桃| 日韩欧美视频免费在线观看| 亚洲精品婷婷| 国产特黄大片aaaa毛片| 婷婷久久免费视频| 性欧美videos另类喷潮| 偷拍一区二区| 中国极品少妇xxxx| www.国产.com| 日本免费久久高清视频| 亚洲精品蜜桃乱晃| 免费av观看网址| 精品国产一区二区三区四区在线观看| 欧美色大人视频|