※ 引述《alan23273850 (God of Computer Science)》之銘言:
: 各位板友午安,本魯軟體板首次發文請小力鞭
: 是說最近常和同學討論到整理 code snippet 的重要,也就是功能導向的筆記
: 舉例來說,要測量程式執行的時間,
: 以 C 語言來說,可以是:
: clock_t start = clock();
: ... // code execution
: clock_t end = clock();
: printf("%f\n", (float)(end - start) / CLOCKS_PER_SEC);
: 但如果是以 python 而言,則是:
: import datetime
: before = datetime.datetime.now()
: ... // code execution
: after = datetime.datetime.now()
: print after - before
: 那麼各位工程師不覺得針對不同的功能,把所有語言的 code 整理在一起,
: 未來撰寫程式在翻閱或查閱的時候就更方便,不需要再敲 Google 關鍵字了呢?
: 台大資訊系劉邦鋒教授也有寫過 "由片語學習 C 程式設計" 一書,
: 雖然我沒讀過,不過我猜應該就類似書中那種以功能為導向整理過的感覺。
: 有沒有什麼好用的工具或方法能有條不紊地整理這些 code 呢?
亂入一下,python 其實用 decorator 比較方便,也有人有提供 library
def stopwatch(func):
def with_logging(*args, **kwargs):
start_time = time.time()
try:
return func(*args, **kwargs)
finally:
end_time = time.time()
logger.info("{:36s} :: {:.3f}".format( \
func.__name__, end_time - start_time))
pass
return with_logging
@stopwatch
def my_function():
# do something
pass
==========================================================
至於 cheat sheet 的部分,最好是能被『執行』的程式碼。
因為單純眼睛看可能不太明白,可是跑一次就懂了。
不過,當你在『工作』的場域時,這些常用的工作大致都應該包好了。
也就是當你想要自幹某些東西時,先問一下同事有沒有相似的功能已被實作。
或是你可能打開舊專案,複製一段 code 出來用而已。
這類比較小行數的 cheat sheet 大概只會剩下一些難記的參數。
像是那個我永遠記不住的 ffmpeg 參數,或是建立專案時 gradle 編譯設定。