但開發人員行走于Unix之間,依然有四樣東西要熟練。
一、VI
雖然Unix上的文本編輯器已經越來越好用,但不在Console前面,網速也不夠連XWindows的時候,還是要依賴VI。
回想VI的時代背景,發現VI對開發人員已經周到得離譜了,熱鍵多到你雙手不離鍵盤就能完成大半編輯工作。
建議自己制作一張自己認為有用,但又經常忘記的命令的sheet,拿出考試的力氣把它背熟。
二、文本處理
開發人員在Unix下干得最多的除了Make和除Bug外,大概就是處理日志文件、業務文件進行查錯和統計了。
只會more和grep是不夠的,開發老手會把awk,sed,grep,sort,unique,wc這些文本處理命令,通過管道玩具式的拆卸拼裝,最后完成一件原本以為非編寫大段代碼不可的工作。周到的參數設定,讓人再一次感嘆那個簡單的年代,復雜到極致的設計.......怪不得《Unix 編程藝術》的作者有那么驕傲的自覺。
比如車東的每月訪問TOP10 統計腳本:
- awk -F '/t' 將2004_2.txt訪問紀錄文件,用TAB分割,打印第4列
- grep chedong.com/tech 只列出chedong.com/tech筆記目錄下的文檔;
- sort 排序
- uniq -c 匯總計數
- sort -rn 按數值排序
-
head -10 TOP 10
三、Bash Shell 編程
編程是開發人員的天賦技能,不論什么語言,看看參考手冊應該就能上手。見
Bash新手指南中文版
四、Make與AutoMake
用過Java的Ant后,想起Make就覺得很煩,很厭倦。總歸還是會的,見
GNU Make 3.8.0 中文手冊
不過即使make已經精通到變態,每個人寫出來的MakeFile還是千奇百怪,再看看開源項目們個個都是automake+autoconf,我們自己也長進一點吧。
大家先編寫MakeFile.am,auotomake后變成MakeFile.in,用戶./configure 后就能生成最終的MakeFile。
MakeFile.am 生成的MakeFile既能跨越平臺,又是標準的寫法,最重要的是,編寫MakeFile.am的工作量比MakeFile少多了,只要簡單的定義要目標文件,先要處理的子目錄,需要的源文件,INCLUDES文件與庫文件就可以了。
另外,ACE里還貢獻了一個更厲害的
MPC(Makefile, Project, and Workspace Creator )
,自動的生成MakeFile.am或者VC的項目文件。
入門:
使用AutoMake輕松生成Makefile
進階:
例解 autoconf 和 automake 生成 Makefile 文件
附錄A:我的VI易忘命令手冊
上下左右:
ctrl+u/d 上下半屏,ctrl+f/b,上下一屏
H/G屏幕頭/末 ,0/$ 行首行末
增刪改:
yy/dd 復制/刪除 一行,p/P:將yy/dd的內容paste出來
I/A 在行首/末添加, o/O 開新行,d0/d$ 刪除到行首,行末
u:undo
查:
? 向前查找, n/N 重復上一次查找
附錄B: 文本處理命令小結
awk:
處理結構化的文本(每行以固定符號分成若干列),提取打印某些字段,如:
ls -l|awk '{print $1}' --將ls-l結果的第一列打印出來
awk -F":" '{print $1" "$6}' /etc/passwd ,將以:分割的/etc/passwd文件的第1,6列打印出來,中間以空格分開
詳見IBM的教程:
http://www-128.ibm.com/developerworks/cn/linux/shell/awk/awk-1/index.html
(共3篇)
grep:
過濾,大家用得最多的命令,支持正則表達式。參數有:
-i忽略大小寫,-n顯示line number,-c 統計在每個文件的出現次數,-l只顯示符合的文件的名字。
sed:
替換,如:
sed -e '1,10s/foo/bar/g' myfile2.txt 將1到10行的文本中的foo 替換成bar,s代表替換,g代表全局替換
支持正則的替換字符串,可以只替換某個范圍內的內容。
用法不算簡單,詳見IBM的
http://www.ibm.com/developerworks/cn/linux/shell/sed/sed-1/index.html
(共三章)
sort:
排序,參數有:
-r逆序, -n 數字比較 ,-M 日歷比較 Feb,Dec,-f 忽略大小寫
同樣支持結構化文件,如
sort -t : -k 1,1 /etc/passwd,以: 分割,只按第1列排序
sort -t : -k 1,1 -k2.2,3.4 /etc/passwd ,以:分割,先按第1列排序,再按第2列的第二個字符到第3列的第4個字符排序。
uniq:
去除重復行。
除了正常用法外,還有-u (唯一)和 -d (重復)兩個參數,只顯示唯一的和重復的行。
wc:
統計。
-l 行,-m 字符,-w 單詞
PS:以下文字不算字數
一個多月沒有更新博客了,因為公司里調了新部門,很多東西要學習。太久沒試過華麗的在上班時間,在工作中,在同事們身上學到這么多東西了,很是開心。
下周開始爆發更新。
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061
微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元

