|
-- 會員 / 註冊 --
|
|
|
|
深入解析Android虛擬機 ( 簡體 字) |
作者:鐘世禮 | 類別:1. -> 程式設計 -> 手機程式 -> Android |
譯者: |
出版社:人民郵電出版社 | 3dWoo書號: 45593 詢問書籍請說出此書號!【缺書】 NT售價: 495 元 |
出版日:10/1/2016 |
頁數:595 |
光碟數:0 |
|
站長推薦: |
印刷:黑白印刷 | 語系: ( 簡體 版 ) |
|
加入購物車 │加到我的最愛 (請先登入會員) |
ISBN:9787115423535 |
作者序 | 譯者序 | 前言 | 內容簡介 | 目錄 | 序 |
(簡體書上所述之下載連結耗時費功, 恕不適用在台灣, 若讀者需要請自行嘗試, 恕不保證) |
作者序: |
譯者序: |
前言: |
內容簡介: Android系統從誕生到現在的短短幾年時間里,憑借其易用性和開發的簡潔性,贏得了廣大開發者的支持。在整個Android系統中,Dalvik VM一直是貫穿從底層內核到高層應用開發的核心。本書循序漸進地講解了Android虛擬機系統的基本知識,并剖析了其整個內存系統的進程和運作流程,并對虛擬機系統優化和異常處理的知識進行了詳細講解。本書幾乎涵蓋了Dalvik VM系統的所有主要內容,并且講解方法通俗易懂,特別有利于讀者學習并消化。 本書適合Android初學者、Android底層開發人員、源代碼分析人員和虛擬機開發人員學習,也可以作為大專院校相關專業師生的學習用書和培訓學校的教材。
|
目錄:第1章 獲取并編譯Android源碼 1 1.1 獲取Android源碼 1 1.1.1 在Linux系統獲取Android 源碼 1 1.1.2 在Windows平臺獲取Android 源碼 2 1.1.3 Windows獲取Android L源碼 4 1.2 分析Android源碼結構 6 1.3 編譯Android源碼 8 1.3.1 搭建編譯環境 8 1.3.2 開始編譯 9 1.3.3 在模擬器中運行 10 1.3.4 常見的錯誤分析 10 1.3.5 實踐演練—演示兩種編譯Android程序的方法 11 1.4 編譯Android Kernel 14 1.4.1 獲取Goldfish內核代碼 14 1.4.2 獲取MSM內核代碼 17 1.4.3 獲取OMAP內核代碼 17 1.4.4 編譯Android的Linux內核 17 第2章 Java虛擬機基礎 19 2.1 虛擬機的作用 19 2.2 Java虛擬機概述 20 2.2.1 JVM的數據類型 20 2.2.2 Java虛擬機體系結構 21 2.2.3 JVM的生命周期 25 2.3 JVM的安全性 26 2.3.1 JVM的安全模型 26 2.3.2 沙箱模型的4種組件 27 2.3.3 分析Java的策略機制 28 2.4 網絡移動性 29 2.4.1 現實需要網絡移動性 29 2.4.2 網絡移動性 30 2.5 內存異常和垃圾處理 31 2.5.1 內存分配中的棧和堆 31 2.5.2 運行時的數據區域 33 2.5.3 對象訪問 34 2.5.4 內存泄露 35 2.5.5 JVM的垃圾收集策略 36 2.5.6 垃圾收集器 37 2.6 Java內存模型 37 2.6.1 Java內存模型概述 38 2.6.2 主內存與工作內存 38 2.6.3 內存間交互操作 39 第3章 Dalvik和ART基礎 40 3.1 Dalvik VM和JVM的差異 40 3.2 Dalvik虛擬機的主要特征 41 3.3 Dalvik VM架構 42 3.3.1 Dalvik虛擬機的代碼結構 42 3.3.2 dx工具 44 3.3.3 Dalvik VM的進程管理 44 3.3.4 Android的初始化流程 44 3.4 Dalvik VM控制VM命令詳解 45 3.4.1 基本命令 45 3.4.2 擴展的JNI檢測 45 3.4.3 斷言 46 3.4.4 字節碼校驗和優化 46 3.4.5 Dalvik VM的運行模式 47 3.4.6 死鎖預測 47 3.4.7 dump堆棧追蹤 48 3.4.8 dex文件和校驗 48 3.4.9 產生標志位 48 3.5 ART機制基礎 48 3.5.1 什么是ART模式 48 3.5.2 ART優化機制基礎 50 第4章 分析JNI 52 4.1 JNI的本質 52 4.2 分析Java層 54 4.2.1 加載JNI庫 54 4.2.2 實現掃描工作 55 4.2.3 讀取并保存信息 56 4.2.4 刪除SD卡外的信息 58 4.2.5 直接轉向JNI 58 4.2.6 掃描函數scanFile 59 4.2.7 JNI中的異常處理 59 4.3 分析JNI層 60 4.3.1 將Native對象的指針保存到 Java對象 60 4.3.2 創建Native層的MediaScanner 對象 60 4.4 Native(本地)層 61 4.4.1 注冊JNI函數 61 4.4.2 完成注冊工作 63 4.4.3 動態注冊 64 4.4.4 處理路徑參數 65 4.4.5 掃描文件 66 4.4.6 添加TAG信息 66 4.4.7 總結函數JNI_OnLoad()與函數JNI_OnUnload()的用途 67 4.4.8 Java與JNI基本數據類型 轉換 67 4.4.9 JNIEnv接口 69 4.4.10 JNI中的環境變量 70 第5章 分析內存系統 71 5.1 分析Android的進程通信機制 71 5.1.1 Android的進程間通信(IPC) 機制Binder 71 5.1.2 Service Manager是Binder 機制的上下文管理者 72 5.1.3 Service Manager服務 86 5.2 匿名共享內存子系統詳解 89 5.2.1 基礎數據結構 89 5.2.2 初始化處理 90 5.2.3 打開匿名共享內存設備文件 91 5.2.4 內存映射 93 5.2.5 讀寫操作 94 5.2.6 鎖定和解鎖 95 5.2.7 回收內存塊 100 5.3 C++訪問接口層詳解 101 5.3.1 接口MemoryBase 101 5.3.2 接口MemoryBase 108 5.4 Java訪問接口層詳解 111 第6章 Android程序的生命周期管理 115 6.1 Android程序的生命周期 115 6.1.1 進程和線程 115 6.1.2 進程的類型 116 6.2 Activity的生命周期 116 6.2.1 Activity的幾種狀態 117 6.2.2 分解剖析Activity 117 6.2.3 幾個典型的場景 119 6.2.4 管理Activity的生命周期 119 6.2.5 Activity的實例化與啟動 120 6.2.6 Activity的暫停與繼續 120 6.2.7 Activity的關閉/銷毀與 重新運行 121 6.2.8 Activity的啟動模式 121 6.3 進程與線程 122 6.3.1 進程 122 6.3.2 線程 123 6.3.3 線程安全的方法 123 6.3.4 Android的線程模型 123 6.4 測試生命周期 125 6.5 Service的生命周期 129 6.5.1 Service的基本概念和用途 129 6.5.2 Service的生命周期詳解 129 6.5.3 Service與Activity通信 129 6.6 Android廣播的生命周期 133 6.6.1 Android 的廣播機制 133 6.6.2 編寫廣播程序 133 6.7 ART進程管理 135 第7章 IPC進程通信機制 147 7.1 Binder機制概述 147 7.2 Service Manager是Binder機制的 上下文管理者 148 7.2.1 入口函數 148 7.2.2 打開Binder設備文件 149 7.2.3 創建設備文件 149 7.2.4 管理內存映射地址空間 154 7.2.5 發生通知 156 7.2.6 循環等待 161 7.3 內存映射 162 7.3.1 實現內存分配功能 162 7.3.2 分配物理內存 164 7.3.3 釋放物理頁面 166 7.3.4 分配內核緩沖區 167 7.3.5 釋放內核緩沖區 168 7.3.6 查詢內核緩沖區 170 第8章 init進程詳解 171 8.1 init基礎 171 8.2 分析入口函數 172 8.3 配置文件詳解 174 8.3.1 init.rc簡介 174 8.3.2 分析init.rc的過程 176 8.4 解析service 179 8.4.1 Zygote對應的service action 179 8.4.2 init組織service 180 8.4.3 函數parse_service和parse_line_service 181 8.5 字段on 184 8.5.1 Zygote對應的on action 184 8.5.2 init組織on 185 8.5.3 解析on用到的函數 186 8.6 在init控制service 186 8.6.1 啟動Zygote 186 8.6.2 啟動service 187 8.6.3 4種啟動service的方式 191 8.7 控制屬性服務 194 8.7.1 引入屬性 194 8.7.2 初始化屬性服務 197 8.7.3 啟動屬性服務 197 8.7.4 處理設置屬性的請求 200 第9章 Dalvik VM的進程系統 202 9.1 Zygote(孕育)進程詳解 202 9.1.1 Zygote基礎 202 9.1.2 分析Zygote的啟動過程 203 9.2 System進程詳解 216 9.2.1 啟動System進程前的準備 工作 216 9.2.2 分析SystemServer 217 9.2.3 分析EntropyService 220 9.2.4 分析DropBoxManagerService 222 9.2.5 分析DiskStatsService 227 9.2.6 分析DeviceStorageManager Service 231 9.2.7 分析SamplingProfilerService 233 9.2.8 分析ClipboardService 241 9.3 應用程序進程詳解 247 9.3.1 創建應用程序 247 9.3.2 啟動線程池 256 9.3.3 創建信息循環 257 第10章 Dalvik VM運作流程詳解 259 10.1 Dalvik VM相關的可執行程序 259 10.1.1 dalvikvm、dvz和app_process 簡介 259 10.1.2 對比app_process和dalvikvm的 執行過程 260 10.2 初始化Dalvik虛擬機 262 10.2.1 開始虛擬機的準備工作 262 10.2.2 初始化跟蹤顯示系統 262 10.2.3 初始化垃圾回收器 263 10.2.4 初始化線程列表和主線程 環境參數 263 10.2.5 分配內部操作方法的表格 內存 264 10.2.6 初始化虛擬機的指令碼相關 的內容 264 10.2.7 分配指令寄存器狀態的 內存 264 10.2.8 分配指令寄存器狀態的內存 和最基本用的Java庫 265 10.2.9 初始化使用的Java類庫 線程類 266 10.2.10 初始化虛擬機使用的異常 Java類庫 267 10.2.11 初始化其他對象 268 10.3 啟動Zygote 276 10.3.1 在init.rc中配置Zygote啟動 參數 276 10.3.2 啟動Socket服務端口 276 10.3.3 加載preload-classes 277 10.3.4 加載preload-resources 277 10.3.5 使用folk啟動新進程 278 10.4 啟動SystemServer進程 278 10.4.1 啟動各種系統服務線程 279 10.4.2 啟動第一個Activity 280 10.5 加載class類文件 281 10.5.1 DexFile在內存中的映射 281 10.5.2 ClassObject—Class在 加載后的表現形式 283 10.5.3 加載Class并生成相應 ClassObject的函數 283 10.5.4 加載基本類庫文件 284 10.5.5 加載用戶類文件 284 第11章 DEX文件詳解 285 11.1 DEX文件介紹 285 11.2 DEX文件的格式 285 11.2.1 map_list 286 11.2.2 string_id_item 288 11.2.3 type_id_item 291 11.2.4 proto_id_item 292 11.2.5 ield_id_item 293 11.2.6 method_id_item 293 11.2.7 class_def_item 294 11.3 DEX文件結構 297 11.3.1 文件頭(File Header) 297 11.3.2 魔數字段 298 11.3.3 檢驗碼字段 298 11.3.4 SHA-1簽名字段 300 11.3.5 map_off字段 300 11.3.6 string_ids_size和off字段 301 11.4 DEXFile接口詳解 303 11.4.1 構造函數 303 11.4.2 公共方法 304 11.5 DEX和動態加載類機制 306 11.5.1 類加載機制 306 11.5.2 具體加載 306 11.5.3 代碼加密 308 11.6 動態加載jar和DEX 309 第12章 Dvlik VM內存系統詳解 310 12.1 如何分配內存 310 12.2 內存管理機制詳解 312 12.3 優化Dalvik虛擬機的堆內存分配 326 第13章 Dalvik VM垃圾收集機制 328 13.1 引用計數算法 328 13.2 Mark Sweep算法 328 13.3 和垃圾收集算法有關的函數 330 13.4 垃圾回收的時機 346 13.5 調試信息 347 13.6 Dalvik VM和JVM垃圾收集機制的 區別 348 第14章 Dalvik VM內存優化機制詳解 350 14.1 sp和wp簡介 350 14.1.1 sp基礎 350 14.1.2 wp基礎 351 14.2 智能指針詳解 351 14.2.1 智能指針基礎 352 14.2.2 輕量級指針 353 14.2.3 強指針 355 14.2.4 弱指針 365 第15章 分析Dalvik VM的啟動過程 369 15.1 Dalvik VM啟動流程概覽 369 15.2 Dalvik VM啟動過程詳解 370 15.2.1 創建Dalvik VM實例 370 15.2.2 指定一系列控制選項 371 15.2.3 創建并初始化Dalvik VM 實例 376 15.2.4 創建JNIEnvExt對象 378 15.2.5 設置當前進程和進程組ID 382 15.2.6 注冊Android核心類的JNI 方法 382 15.2.7 創建javaCreateThreadEtc 鉤子 385 第16章 注冊Dalvik VM并創建線程 387 16.1 注冊Dalvik VM的JNI方法 387 16.1.1 設置加載程序 387 16.1.2 加載so文件并驗證 387 16.1.3 獲取描述類 392 16.1.4 注冊JNI方法 392 16.1.5 實現JNI操作 394 16.2 創建Dalvik VM進程 395 16.2.1 分析底層啟動過程 395 16.2.2 創建Dalvik VM進程 395 16.2.3 初始化運行的Dalvik VM 398 16.3 創建Dalvik VM線程 399 16.3.1 檢查狀態值 399 16.3.2 創建線程 399 16.3.3 分析啟動過程 402 16.3.4 清理線程 404 第17章 Dalvik VM異常處理詳解 407 17.1 Java異常處理機制 407 17.1.1 方法調用棧 407 17.1.2 Java提供的異常處理類 409 17.2 Java VM異常處理機制詳解 409 17.2.1 Java語言及虛擬機的異常 處理機制 410 17.2.2 COSIX虛擬機異常處理的 設計與實現 410 17.3 分析Dalvik虛擬機異常處理的 源碼 414 17.3.1 初始化虛擬機使用的異常 Java類庫 414 17.3.2 拋出一個線程異常 415 17.3.3 持續拋出進程 415 17.3.4 找出異常原因 416 17.3.5 找出異常原因 417 17.3.6 清除掛起的異常和等待 初始化的異常 420 17.3.7 包裝“現在等待”異常的 不同例外 420 17.3.8 輸出跟蹤當前異常的錯誤 信息 421 17.3.9 搜索和當前異常相匹配的 方法 421 17.3.10 獲取匹配的捕獲塊 423 17.3.11 進行堆棧跟蹤 424 17.3.12 生成堆棧跟蹤元素 425 17.3.13 將內容添加到堆棧跟蹤 日志中 426 17.3.14 將內容添加到堆棧跟蹤 日志中 427 17.4 常見異常的類型與原因 428 17.4.1 SQLException:操作數據庫 異常類 428 17.4.2 ClassCastException:數據 類型轉換異常 428 17.4.3 NumberFormatException: 字符串轉換為數字類型時 拋出的異常 428 17.5 調用堆棧跟蹤分析異常 429 17.5.1 解決段錯誤 429 17.5.2 跟蹤Android Callback調用 堆棧 431 第18章 JIT編譯 434 18.1 JIT簡介 434 18.1.1 JIT概述 434 18.1.2 Java虛擬機主要的優化 技術 436 18.1.3 Dalvik中JIT的實現 436 18.2 Dalvik VM對JIT的支持 436 18.3 匯編代碼和改動 438 18.3.1 匯編部分代碼 438 18.3.2 對C文件的改動 438 18.4 Dalvik VM中的JIT源碼 439 18.4.1 入口文件 439 18.4.2 核心函數 447 18.4.3 編譯文件 450 18.4.4 BasicBlock處理 458 18.4.5 內存初始化 459 18.4.6 對JIT源碼的總結 462 第19章 Dalvik VM內存優化 463 19.1 Android內存優化的作用 463 19.2 查看Android內存和CPU使用情況 464 19.2.1 利用Android API函數查看 464 19.2.2 直接對Android文件進行 解析查詢 464 19.2.3 通過Runtime類實現 465 19.2.4 使用DDMS工具獲取 465 19.2.5 其他方法 469 19.3 Android的內存泄露 472 19.3.1 什么是內存泄漏 472 19.3.2 為什么會發生內存泄露 473 19.3.3 shallow size、retained size 474 19.3.4 查看Android內存泄露的 工具——MAT 475 19.3.5 查看Android內存泄露的 方法 478 19.3.6 Android(Java)中常見的容易 引起內存泄漏的不良代碼 480 19.4 常見的引起內存泄露的壞習慣 480 19.4.1 查詢數據庫時忘記 關閉游標 481 19.4.2 構造Adapter時不習慣使用 緩存的convertView 481 19.4.3 沒有及時釋放對象的引用 482 19.4.4 不在使用Bitmap對象時調用 recycle()釋放內存 482 19.5 解決內存泄露實踐 483 19.5.1 使用MAT根據heap dump分析Java代碼內存泄漏的根源 483 19.5.2 演練Android中內存泄露 代碼優化及檢測 489 第20章 Dalvik VM性能優化 491 20.1 加載APK/DEX文件優化 491 20.1.1 APK文件介紹 492 20.1.2 DEX文件優化 493 20.1.3 使用類動態加載技術實現 加密優化 493 20.2 SD卡優化 496 20.3 虛擬機優化詳解 497 20.3.1 平臺優化—ARM的流水線 技術 497 20.3.2 Android對C庫優化 501 20.3.3 優化創建的進程 504 20.3.4 渲染優化 504 第21章 分析ART的啟動過程 508 21.1 運行環境的轉換 508 21.2 運行 app_process 進程 509 21.3 準備啟動 512 21.4 創建運行實例 518 21.5 注冊本地JNI函數 519 21.6 啟動守護進程 520 21.7 解析參數 521 21.8 初始化類、方法和域 528 第22章 執行ART主程序 534 22.1 進入main主函數 534 22.2 查找目標類 535 22.2.1 函數LookupClass() 535 22.2.2 函數DefineClass() 537 22.2.3 函數InsertClass() 540 22.2.4 函數LinkClass() 541 22.3 類操作 543 22.4 實現托管操作 544 第23章 安裝APK應用程序 549 23.1 PackageManagerService概述 549
23.2 主函數main 549 23.3 調用初始化函數 550 23.4 創建PackageManagerService服務 553 23.5 掃描并解析 554 23.6 保存解析信息 570 第24章 ART環境安裝APK應用程序 572 24.1 Android安裝APK概述 572 24.2 啟動時安裝 572 24.3 ART安裝 581 24.4 實現dex2oat轉換 586 24.4.1 參數解析 586 24.4.2 創建 OAT文件指針 588 24.4.3 dex2oat準備工作 588 24.4.4 提取classes.dex文件 589 24.4.5 創建OAT文件 594 24.5 APK文件的轉換 595 |
序: |
|