版本 a149d78c1797584121dc4b7ec90fe248b3d691b6
ChingChieh(黃敬傑)
黃敬傑
- 成功大學資訊工程學系108級
- Github: https://github.com/ChingChieh
- gmail: garnett.huang@gmail.com
- 修課: 進階電腦系統理論與實作 (Fall 2018)
作業 Lab
- lab0:
- datalab:
- dict
- 探討 memory pool 和每當需要時才 malloc 那個發生 cache miss 機率較高,以及哪個執行速度較快
- 學習使用 perf 工具來分析程式效能
- 學習使用 linux 畫圖工具 gnuplot
- 共筆
- 期中分組作業
- 期末分組作業
- 複習多執行緒的程式以及 mutex ,測試有 mutex lock 的程式在多執行緒的情況下的正確性
- 了解 lockfree 在多執行緒的情況下如何實作
- 學習利用 valgrind 來 debug 多執行緒的程式
- 共筆
- 知道如何用 bitwise operator 實作出沒有分支的 FizzBuzz 程式嗎?
- 參考老師的 Github
回顧
- 知道 x - y < 0 敘述為何不能寫為 x < y 嗎?
- 假設 x = 1, y = INT_MIN 那便不成立了
- 知道 C 語言規格書如何解釋 ptr++ 和 *ptr++ 行為的差異嗎?
- 規格書寫到 postfix increment 是對 operand 相加一個單位
- 而 ptr++ 則是對 ptr 的資料型態相加一個對應的 byte , *ptr++ 則是對 *ptr 的值相加一個對應的單位
- 知道通訊領域中如何應用 parity bit 嗎?
- 知道 void (*signal(int sig, void (*handler)(int))) (int); 這樣的宣告該如何解讀嗎?
- signal 這個 function 吃兩個參數,分別是一個 integer 和一個 handler 這個 function pointer 指向吃一個 integer 的參數且沒有回傳值的 function ,而這個 signal 會回傳一個 function pointer 指向吃一個 integer 的參數且沒有回傳值的 function
- 知道 Linux 核心 < include/linux/list.h> 裡頭 #define list_for_each_prev(pos, head) for (pos = (head)->prev; pos != (head); pos = pos->prev) 這樣的巨集到底在做什麼?以及 head 使用時需要加小括號,為何?
- 這個 macro 是反方向走訪整個 list , head 使用時要加小括號是因為 macro 會把傳來的東西直接展開,所以有時候可能會因為 precedence 的問題讓後面的 -> 先做了而出錯
- 知道如何用 bit-wise operator 實作 clz / ctz (count leading/tailing zero) 嗎?
- 以 clz 總共 32 bit 來說,技巧就是分成 16 8 4 2 1 1 bit 來檢查,一開始把全部的 bit 先看其中一半是否符合,也就是 31 到 16 bit 是否全部是 0 如果是則讓數字直接左移 16 bits 然後繼續看剩下未檢查的一半 8 bits,如果不符合就不左移然後繼續看剩下未檢查的的一半 8 bits,然後重複以上步驟,最後一定可以檢查完每個bits,當時在 datalab 寫到這題時也是想了很久
- 以 clz 總共 32 bit 來說,技巧就是分成 16 8 4 2 1 1 bit 來檢查,一開始把全部的 bit 先看其中一半是否符合,也就是 31 到 16 bit 是否全部是 0 如果是則讓數字直接左移 16 bits 然後繼續看剩下未檢查的一半 8 bits,如果不符合就不左移然後繼續看剩下未檢查的的一半 8 bits,然後重複以上步驟,最後一定可以檢查完每個bits,當時在 datalab 寫到這題時也是想了很久
- 知道如何寫出時間複雜度和空間複雜度皆為 O(1) 的 abs64 嗎?(沒有分支) 這樣的 abs64 又可用於真實世界哪邊?
- 假設傳進來的數叫 a 先 b = a >> 63,然後 return (a ^ b) - b
期末自評(1-10)
總合這學期所學,相比於還未修這門課的我來說我覺得我寫 c 方面有進步,尤其是對指標的理解,也學到滿多好用的工具及技巧,更重要的是一些心態像是誠實面對自己,以前分組時往往會找比自己厲害很多的人一組因為遇到問題時可能比較快就能解決,但修這堂課時我都是跟程度跟自己差不多的人一組,雖然遇到問題時會花比較多時間,但至少是靠自己解決,但有的時候真的想不到還是會問別人,我覺得我有盡力了但老師的課的資訊量真的很多,我還是很多東西不知道,所以我給自己 8 分