源碼編譯日誌分析
❶ 如何閱讀源代碼
", 除了閱讀代碼以外, 沒有更好的方法.7.在尋找bug時, 請從問題的表現形式到問題的根源來分析代碼. 不要沿著不相關的路徑(誤入歧途).8.我們要充分利用調試器|編譯器給出的警告或輸出的符號代碼|系統調用跟蹤器|資料庫結構化查詢語言的日誌機制|包轉儲工具和Windows的消息偵查程序, 定出的bug的位置.9.對於那些大型且組織良好的系統, 您只需要最低限度地了解它的全部功能, 就能夠對它做出修改.10.當向系統中增加新功能時, 首先的任務就是找到實現類似特性的代碼, 將它作為待實現功能的模板.11.從特性的功能描述到代碼的實現, 可以按照字元串消息, 或使用關鍵詞來搜索代碼.12.在移植代碼或修改介面時, 您可以通過編譯器直接定位出問題涉及的范圍, 從而減少代碼閱讀的工作量.13.進行重構時, 您從一個能夠正常工作的系統開始做起, 希望確保結束時系統能夠正常工作. 一套恰當的測試用例(test case)可以幫助您滿足此項約束.14.閱讀代碼尋找重構機會時, 先從系統的構架開始, 然後逐步細化, 能夠獲得最大的效益.15.代碼的可重用性是一個很誘人, 但難以理解與分離, 可以試著尋找粒度更大一些的包, 甚至其他代碼.16.在復查軟體系統時, 要注意, 系統是由很多部分組成的, 不僅僅只是執行語句. 還要注意分析以下內容: 文件和目錄結構|生成和配置過程|用戶界面和系統的文檔.18.可以將軟體復查作為一個學習|講授|援之以手和接受幫助的機會.++++++++++++++++++++第二章: 基本編程元素++++++++++++++++++++19.第一次分析一個程序時, main是一個好的起始點.20.層疊if-else if-...-else序列可以看作是由互斥選擇項組成的選擇結構.21.有時, 要想了解程序在某一方面的功能, 運行它可能比閱讀源代碼更為恰當.22.在分析重要的程序時, 最好首先識別出重要的組成部分.23.了解局部的命名約定, 利用它們來猜測變數和函數的功能用途.24.當基於猜測修改代碼時, 您應該設計能夠驗證最初假設的過程. 這個過程可能包括用編譯器進行檢查|引入斷言|或者執行適當的測試用例.25.理解了代碼的某一部分, 可能幫助你理解餘下的代碼.26.解決困難的代碼要從容易的部分入手.27.要養成遇到庫元素就去閱讀相關文檔的習慣; 這將會增強您閱讀和編寫代碼的能力.28.代碼閱讀有許多可選擇的策略: 自底向上和自頂向下的分析|應用試探法和檢查注釋和外部文檔, 應該依據問題的需要嘗試所有這些方法.29.for (i=0; i30.涉及兩項不等測試(其中一項包括相等條件)的比較表達式可以看作是區間成員測試.31.我們經常可以將表達式應用在樣本數據上, 藉以了解它的含義.32.使用De Morgan法則簡化復雜的邏輯表達式.33.在閱讀邏輯乘表達式時, 問題可以認為正在分析的表達式以左的表達式均為true; 在閱讀邏輯和表達式時, 類似地, 可以認為正在分析的表達式以左的表達式均為false.34.重新組織您控制的代碼, 使之更為易讀.35.將使用條件運行符?梢醞ü�付�-w選項, 讓diff忽略空白差異, 避免由於更改了縮進層次而引入的噪音.43.do循環的循環體至少執行一次.44.執行算術運算時, 當b=2n-1時, 可以將a&b理解為a%(b+1).45.將an理解為a/k, k=2n.47.每次只分析一個控制結構, 將它的內容看作是一個黑盒.48.將每個控制結構的控製表達式看作是它所包含代碼的斷言.49.return, goto, break和continue語句, 還有異常, 都會影響結構化的執行流程. 由於這些語句一般都會終止或重新開始正在進行的循環,因此要單獨推理它們的行為.50.用復雜循環的變式和不變式, 對循環進行推理.51.使用保持含義不變的變換重新安排代碼, 簡化代碼的推理工作.+++++++++++++++++++第三章: 高級C數據類型+++++++++++++++++++52.了解特定語言構造所服務的功能之後, 就能夠更好地理解使用它們的代碼.53.識別並歸類使用指針的理由.54.在C程序中, 指針一般用來構造鏈式數據結構|動態分配的數據結構|實現引用調用|訪問和迭代數據元素|傳遞數組參數|引用函數|作為其他值的別名|代表字元串|以及直接訪問系統內存.55.以引用傳遞的參數可以用來返回函數的結果, 或者避免參數復制帶來的開銷.56.指向數組元素地址的指針, 可以訪問位於特定索引位置的元素.57.指向數組元素的指針和相應的數組索引, 作用在二者上的運算具有相同的語義.58.使用全局或static局部變數的函數大多數情況都不可重入(reentrant).59.字元指針不同於字元數組.60.識別和歸類應用結構或共用體的每種理由.61.C語言中的結構將多個數據元素集合在一起, 使得它們可以作為一個整體來使用, 用來從函數中返回多個數據元素|構造鏈式數據結構|映射數據在硬體設備|網路鏈接和存儲介質上的組織方式|實現抽象數據類型|以及以面向對象的方式編程.62.共用體在C程序中主要用於優化存儲空間的利用|實現多態|以及訪問數據不同的內部表達方式.63.一個指針, 在初始化為指向N個元素的存儲空間之後, 就可以作為N個元素的數組來使用.64.動態分配的內在塊可以電焊工地釋放, 或在程序結束時釋放, 或由垃圾回收器來完成回收; 在棧上分配的內存塊當分配它的函數退出後釋放.65.C程序使用typedef聲明促進抽象, 並增強代碼的易讀性, 從而防範可移植性問題, 並模擬C++和java的類聲明行為.66.可以將typedef聲明理解成變數定義: 變數的名稱就是類型的名稱; 變數的類型就是與該名稱對應的類型.+++++++++++++++第四章: C數據結構+++++++++++++++67.根據底層的抽象數據類型理解顯式的數據結構操作.68.C語言中, 一般使用內建的數組類型實現向量, 不再對底層實現進行抽象.69.N個元素的數組可以被序列for (i=0; i70.表達式sizeof(x)總會得到用memset或memcpy處理數組x(不是指針)所需的正確位元組數.71.區間一般用區間內的第一個元素和區間後的第一個元素來表示.72.不對稱區間中元素的數目等於高位邊界與低位邊界的差.73.當不對稱區間的高位邊界等於低位邊界時, 區間為空.74.不對稱區間中的低位邊界代表區間的第一個元素; 高位邊界代表區間外的第一個元素.75.結構的數組常常表示由記錄和欄位組成的表.76.指向結構的指針常常表示訪問底層記錄和欄位的游標.77.動態分配的矩陣一般存儲為指向數組列的指針或指向元素指針的指針; 這兩種類型都可以按照二維數組進行訪問.78.以數組形式存儲的動態分配矩陣, 用自定義訪問函數定位它們的元素.79.抽象數據類型為底層實現元素的使用(或誤用)方式提供一種信心的量度.80.數組用從0開始的順序整數為鍵, 組織查找表.81.數組經常用來對控制結構進行高效編碼, 簡化程序的邏輯.82.通過在數組中每個位置存儲一個數據元素和一個函數指針(指向處理數據元素的函數), 可以將代碼與數據關聯起來.83.數組可以通過存儲供程序內的抽象機(abstract machine)或虛擬機(virtual machine)使用的數據或代碼, 控製程序的運作.84.可以將表達式sizeof(x) / sizeof(x[0])理解為數組x中元素的個數.85.如果結構中含有指向結構自身|名為next的元素, 一般說來, 該結構定義的是單向鏈表的結點.86.指向鏈表結點的持久性(如全局|靜態或在堆上分配)指針常常表示鏈表的頭部.87.包含指向自身的next和prev指針的結構可能是雙向鏈表的結點.88.理解復雜數據結構的指針操作可以將數據元素畫為方框|指針畫為箭頭.89.遞歸數據結構經常用遞歸演算法來處理.90.重要的數據結構操作演算法一般用函數參數或模板參數來參數化.91.圖的結點常常順序地存儲在數組中, 鏈接到鏈表中, 或通過圖的邊鏈接起來.92.圖中的邊一般不是隱式地通過指針, 就是顯式地作為獨立的結構來表示.93.圖的邊經常存儲為動態分配的數組或鏈表, 在這兩種情況下, 邊都錨定在圖的結點上.94.在無向圖中, 表達數據時應該將所有的結點看作是等同的, 類似地, 進行處理任務的代碼也不應該基於它們的方向來區分邊.95.在非連通圖中, 執行遍歷代碼應該能夠接通孤立的子圖.96.處理包含迴路的圖時, 遍歷代碼應該避免在處理圖的迴路進入循環.97.復雜的圖結構中, 可能隱藏著其他類型的獨立結構.+++++++++++++++++第五章: 高級控制流程+++++++++++++++++98.採用遞歸定義的演算法和數據結構經常用遞歸的函數定義來實現.99.推理遞歸函數時, 要從基準落伍測試開始, 並認證每次遞歸調用如何逐漸接近非遞歸基準範例代碼.100.簡單的語言常常使用一系列遵循該語言語法結構的函數進行語法分析.101.推理互遞歸函數時, 要基於底層概念的遞歸定義.102.尾遞歸調用等同於一個回到函數開始處的循環.103.將throws子句從方法的定義中移除, 然後運行Java編譯器對類的源代碼進行編譯, 就可以容易地找到那些可能隱式地生成異常的方法.104.在多處理器計算機上運行的代碼常常圍繞進程或線程進行組織.105.工作群並行模型用於在多個處理器間分配工作, 或者創建一個任務池, 然後將大量需要處理標准化的工作進行分配.106.基於線程的管理者/工人並行模型一般將耗時的或阻塞的操作分配給工人子任務, 從而維護中心任務的響應性.107.基於進程的管理者/工人並行模型一般用來重用現有的程序, 或用定義良好的介面組織和分離粗粒度的系統模塊集合, 組織和優化編譯過程, 或是用來實現應用程序各種特性的按需載入.212.大型的|分布式的系統經常實現為許多互相協作的進程.213.對於基於文本的數據儲存庫, 可以通過瀏覽存儲在其中的數據, 破譯出它的結構.214.可以通過查詢數據字典中的表, 或使用資料庫專有的sql命令, 比如show table, 來分析關系型資料庫的模式.215.識別出重用的構架元素後, 可以查找其最初的描述, 了解正確地使用這種構架的方式, 以及可能出現的誤用.216.要詳細分析建立在某種框架之上的應用程序, 行動的最佳路線就是從研究框架自身開始.217.在閱讀向導生成的代碼時, 不要期望太高, 否則您會感到失望.218.學習幾個基本的設計模式之後, 您會發現, 您查看代碼構架的方式會發生改變: 您的視野和詞彙將會擴展到能夠識別和描述許多通用的形式.219.頻繁使用的一些模式, 但並不顯式地指出它們的名稱, 這是由於構架性設計的重用經常先於模式的形成.220.請試著按照底層模式來理解構架, 即使代碼中並沒有明確地提及模式.221.大多數解釋器都遵循類似的處理構架, 圍繞一個狀態機進行構建, 狀態機的操作依賴於解釋器的當前狀態|程序指令和程序狀態.222.多數情況下, 參考構架只是為應用程序域指定一種概念性的結構, 具體的實現並非必須遵照這種結構.+++++++++++++++++第十章: 代碼閱讀工具+++++++++++++++++223.詞彙工具可以高效地在一個大代碼文件中或者跨多個文件查找某種模式.224.使用程序編輯器和正則表達式查找命令, 瀏覽龐大的源代碼文件.225.以只讀方式瀏覽源代碼文件.226.使用正則表達式 ^function name 可以找出函數的定義.227.使用正則表達式的字元類, 可以查找名稱遵循特定模式的變數.228.使用正則表達式的否定字元類, 可以避免非積極匹配.229.使用正則表達式 symbol-1. *symbol-2, 可以查找出現在同一行的符號.230.使用編輯器的 tags 功能, 可以快速地找出實體的定義.231.可以用特定的 tag 創建工具, 增加編輯器的瀏覽功能.232.使用編輯器的大綱視圖, 可以獲得源代碼結構的鳥瞰圖.233.使用您的編輯器來檢測源代碼中圓括弧|方括弧和花括弧的匹配.234.使用 grep 跨多個文件查找代碼模式.235.使用 grep 定位符號的聲明|定義和應用.236.當您不能精確地表述要查找的內容時, 請使用關鍵單詞的詞干對程序的源代碼進行查找.237.用 grep 過濾其他工具生成的輸出, 分離出您要查找的項.238.將 grep 的輸出輸送到其他工具, 使復雜處理任務自動化.239.通過對 grep 的輸出進行流編輯, 重用代碼查找的結果.240.通過選取與噪音模式不匹配的輸出行(grep-v), 過濾虛假的 grep 輸出.241.使用 fgrep 在源代碼中查找字元串列表.242.查找注釋, 或標識符大小寫不敏感的語言編寫的代碼時, 要使用大小寫不敏感的模式匹配(grep -i).243.使用 grep –n 命令行開關, 可以創建與給定正則表達式匹配的文件和行號的檢查表.244.可以使用 diff 比較文件或程序不同版本之間的差別.245.在運行 diff 命令時, 可以使用 diff –b, 使文件比較演算法忽略結尾的空格, 用–w 忽略所有空白區域的差異, 用–i 使文件比較對大小寫不敏感.246.不要對創建自己的代碼閱讀工具心存畏懼.247.在構建自己的代碼閱讀工具時: 要充分利用現代快速原型語言所提供的能力; 從簡單開始, 根據需要逐漸改進; 使用利用代碼詞彙結構的各種試探法; 要允許一些輸出噪音或寂靜(無關輸出或缺失輸出); 使用其他工具對輸入進行預處理, 或者對輸出進行後期處理.248.要使編譯器成為您的: 指定恰當級別的編譯器警告, 並小心地評估生成的結果.249.使用C預處理器理清那些濫用預處理器特性的程序.250.要徹底地了解編譯器如何處理特定的代碼塊, 需要查看生成的符號(匯編)代碼.251.通過分析相應目標文件中的符號, 可以清晰地了解源文件的輸入和輸出.252.使用源代碼瀏覽器瀏覽大型的代碼集合以及對象類型.253.要抵制住按照您的編碼規范對外部代碼進行美化的誘惑; 不必要的編排更改會創建不同的代碼, 並妨礙工作的組織.254.優美列印程序和編輯器語法著色可以使得程序的源代碼為易讀.255.cdecl 程序可以將難以理解的C和C++類型聲明轉換成純英語(反之亦然).256.實際運行程序, 往往可以更深刻地理解程序的動作.257.系統調用|事件和數據包跟蹤程序可以增進對程序動作的理解.258.執行剖析器可以找出需要著重優化的代碼, 驗證輸入數據的覆蓋性, 以及分析演算法的動作.259.通過檢查從未執行的代碼行, 可以找出測試覆蓋的弱點, 並據此修正測試數據.260.要探究程序動態動作時的每個細節, 需要在調試器中運作它.261.將您覺得難以理解的代碼列印到紙上.262.可以繪制圖示來描繪代碼的動作.263.可以試著向別人介紹您在閱讀的代碼, 這樣做一般會增進您對代碼的理解.264.理解復雜的演算法或巧妙的數據結構, 要選擇一個安靜的環境, 然後聚精會神地考慮, 不要藉助於任何計算機化或自動化的幫助.+++++++++++++++++++++第十一章: 一個完整的例子+++++++++++++++++++++265.模仿軟體的功能時, 要依照相似實體的線路(類|函數|模
❷ 怎麼知道android源碼編譯成功
直接連上手機,如果能安裝運行就沒問題,如果是單純的編譯,那就看日誌
❸ Android studio 如何為下載下來的開源源碼,快速添加 log用來查看運行流程
在開發中,我們經常需要在Github上找一些開源項目用於自己的項目中,然而經常由於看不到其運行效果導致不斷的「試錯」,因此一般來說,本人在使用一個開源項目之前會將其下載並運行到手機上看效果。一方面可以准確判斷出是否適合自己的項目,另一方面可以根據項目需求做一定的修改。
1、 找到項目地址,點擊DownloadZIP,下載完成後,解壓到本地磁碟。如圖1所示
圖5
6、將項目導入AS,下載項目其餘需要的組件,編譯安裝,大功告成!
❹ Android用NDK和整套源碼下編譯JNI的不同
NDK:
1、包含頭文件
#include <android/log.h>
2、Android.mk中包含庫
LOCAL_LDLIBS += -L$(SYSROOT)/usr/lib -llog
上面這個一定要,不然出現error: undefined reference to '__android_log_print'
LOCAL_SHARED_LIBRARIES := libdl\
liblog\ #經測試在Eclipse中用NDK編譯可有可無,沒啥用!但在源碼中就必須是他,所以都加上吧!
libpre_AppUpgrade\
libpre_AppArea\
3、在你的jni文件中定義
#define LOGD() __android_log_print(ANDROID_LOG_DEBUG,LOG_TAG,__VA_ARGS__) // 定義LOGD類型
#define LOGI() __android_log_print(ANDROID_LOG_INFO,LOG_TAG,__VA_ARGS__) // 定義LOGI類型
#define LOGW() __android_log_print(ANDROID_LOG_WARN,LOG_TAG,__VA_ARGS__) // 定義LOGW類型
#define LOGE() __android_log_print(ANDROID_LOG_ERROR,LOG_TAG,__VA_ARGS__) // 定義LOGE類型
#define LOGF() __android_log_print(ANDROID_LOG_FATAL,LOG_TAG,__VA_ARGS__) // 定義LOGF類型
adnroid4.2源碼中已經將LOGD等都加了一個頭,
#define ALOGD() __android_log_print(ANDROID_LOG_DEBUG,LOG_TAG,__VA_ARGS__) // 定義LOGD類型
#define ALOGI() __android_log_print(ANDROID_LOG_INFO,LOG_TAG,__VA_ARGS__) // 定義LOGI類型
#define ALOGW() __android_log_print(ANDROID_LOG_WARN,LOG_TAG,__VA_ARGS__) // 定義LOGW類型
#define ALOGE() __android_log_print(ANDROID_LOG_ERROR,LOG_TAG,__VA_ARGS__) // 定義LOGE類型
#define ALOGF() __android_log_print(ANDROID_LOG_FATAL,LOG_TAG,__VA_ARGS__) // 定義LOGF類型
注意如果你不想在每一個jni文件中都定義上述宏,投機方法即可以定義在:D:\android-ndk-r9d\platforms\android-19\arch-arm\usr\include\android\log.h中!當然這種編譯也只能在你本機上使用啦~
源碼開發:
1、Android.mk中包含庫
LOCAL_LDLIBS += -L$(SYSROOT)/usr/lib -llog
LOCAL_SHARED_LIBRARIES := libdl\
liblog\ //源碼中開發一定的加上
libpre_AppUpgrade\
libpre_AppArea\
2、包含頭文件#include <utils/Log.h>
3、注意在使用時記得包含庫的頭文件
轉載
❺ linux下怎麼查看源碼包的安裝日誌記錄,編譯的時候我沒有將其重定向,這些信息會不會記錄在系統日誌
一般安裝的信息會自動保存在/var/log/dpkg.log跟dpkg.log1文件中,你vi一下就知道了。
一般信息都會保存在/var/log/目錄下,好多類別的信息都在
❻ 求助:我想做個web日誌分析的程序(java)
這是導師給同學開的一個畢業設計課題。
個人感覺挺簡單的。
自己配置個web伺服器,iis吧。
設置以下log參數,看看日誌信息,作字元串處理,建議用正則表達式
❼ linux中編譯源碼時./configure出錯,求解。圖為config.log中的內容。
檢查你的系統安裝。
-lgcc 都能失敗,要麼是你的開發環境裝的有問題,要麼就是你的整個系統已經混亂。
❽ hadoop框架下的網路日誌分析系統設計 源代碼 求各位大蝦幫幫忙 我實在是沒辦法了
maprece比較麻煩,hive很簡單
❾ 如何在android源代碼中列印出日誌
1:在編譯so文件的c或cpp文件之前中加入以下代碼,就可以在android中的log顯示日誌內容
#include
#define LOG_TAG "show infomation"
#define LOGW(a ) __android_log_write(ANDROID_LOG_WARN,LOG_TAG,a)
2:就可以在c或cpp中加入LOWG(str) 就可以在android中的log中顯示列印的內容
3.這樣寫完以後,如果直接編譯,就會報 __android_log_write 方法undefined.
怎麼回事呢?關鍵是在設置編譯選項上面。
在Android.mk文件里,可以指定一個LOCAL_LDLIBS的參數。如果不指定,那麼編譯的時候,只會引入默認的幾個重要的lib,比如libc之類的。
如果要用log,那就要把 liblog給引進來。
網上很多的寫法是 LOCAL_LDLIBS := -llog ,這在build static lib的時候沒什麼問題。如果是build shared lib,就會報個 cannot find -llog的錯誤。意思是找不到liblog.so這個庫文件。
因此需要改成 LOCAL_LDLIBS := -L$(SYSROOT)/usr/lib -llog 才可以正常編譯。
其中-L參數是指定了搜索lib的路徑。
下面是一個android.mk的內容的例子:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := TestNdkNetwork
LOCAL_SRC_FILES := HttpConnection.cpp
LOCAL_LDLIBS := -L$(SYSROOT)/usr/lib -llog
include $(BUILD_SHARED_LIBRARY)
❿ 源碼安裝postfix 啟動的時候日誌 報的錯,請問是哪裡出問題了。.第一次架設postfix...請多多指教。。。
解答如下:
其實沒有必要源碼安裝。如果非要這樣升級最新的,下面是之前操作過程,參考:
1,一般情況是停止和卸載Sendmail。再來安裝。
2,其次根據我之前在Centos上安裝經驗,因系統默認安裝了Postfix。你安裝源碼的話,如果卸載
比如用yum -y remove postfix這樣會將Crontab一起卸載。而且後面折騰不上。
所以,源碼安裝我選擇是在現有基礎上安裝升級。命令如下:
cdpostfix-src
make-fMakefile.initmakefiles
'CCARGS=-DHAS_MYSQL-I/usr/local/mysql/include-DUSE_TLS
-DUSE_SASL_AUTH-DDEF_SERVER_SASL_TYPE="dovecot"'
'AUXLIBS=-L/usr/local/mysql/lib-lmysqlclient
-lz-lm-lssl-lcrypto'
####interactive,updateandnon-interactiveinstallpostfix
make&&shpostfix-install-non-interactivetempdir=/tmp||exit1
#################################################
你現在的問題,用下面的三段嘗試一下:如果不行可以用yum -y install postfix 然後再下載最新的Postfix包,加上上面的內容肯定可以。裡面參數是配合Mysql和Dovecot。並且整個安裝是成功的。
# /etc/init.d/sendmail stop
# mkfifo /var/spool/postfix/public/pickup
# /etc/init.d/postfix restart