看來讀者圈中做單片機,RTOS的不少。盡管火哥目前從事Linux/Android方面的嵌入式開發工作,但是讀書的時候也有5年左右單片機裸機和RTOS經驗,之前面試也拿過一些做單片機stm32開發的offer,所以今天分享一些關于單片機是否要轉嵌入式Linux的一些觀點。
一、你真的決定要轉嵌入式Linux嗎?
要不要從單片機轉嵌入式Linux是一個影響到職業發展的嚴肅決策,火哥不能幫你拿主意,只能幫你列出利弊,你需要根據自身的各種環境(比如所在城市Linux嵌入式相關崗位多嗎?是否決定背井離鄉去北上深發展等等)做出最有利的決策。火哥的觀點并不是Linux嵌入式絕對比單片機開發職業發展好,只是根據自身的一些經歷,給出一些看法。
1. 單片機開發相對于Linux嵌入式最大的劣勢在于基層的打工崗位平均薪資偏低。我想這是大部分單片機工程師想轉嵌入式Linux的最主要的原因。技術本身各有優劣,但是就基層打工而言,在同一座城市,就打工而言,單片機的薪資比嵌入式Linux低30%到50%。也許很多有會拿某些做單片機的高薪的老板(比如野火的火哥,周立功等)或者一些公司高管的薪資和做嵌入式Linux打工的工程師對比,證明單片機也可以拿高收入。
但是他們都犯了田忌賽馬的錯誤,拿別人的上等馬和你的中等馬對比,火哥認為這種田忌賽馬的比較非常不切實際,基層打工的就應該和基層打工的這個水平的對比。目前火哥調查到情況來看,在深圳的基層就業市場,單片機(含RTOS)開發的起步薪資在6K-7K, 一般人到15K就是高薪,很難突破。20K以上的單片機offer也有,但是很少,最多也見過25K的單片機offer,但是那都是有名企,名校或者其他業務背景換來的,一般人真拿不到。嵌入式Linux/Android這塊,薪資相對高不少,起步價12K很正常,工作2年一般都能突破15K,3-5年突破20K甚至到25K也是很多的,5年以上去一線土豪大廠(華為、OPPO、VIVO等)可以到30K,如果在手機大廠做到模塊owner專家,突破40K也是可以有,但是在往上就有點難了。
整體來看,同檔次的基層打工者,嵌入式Linux薪資比單片機開發還是高不少,單片機15K就會遇到瓶頸,突破20K就很難了,嵌入式Linux突破20K并不是難事,到25K以上才遇到瓶頸。
2. 你所在的城市嵌入式Linux崗位多嗎?我覺得這是影響你做決定的另一個大問題。我們學嵌入式Linux這門技術,絕大部分人是為了從事相關的工作,而不是陶冶情操。但是根據火哥統計來看,嵌入式Linux的普遍薪資雖然高于單片機,但是就業崗位并沒有單片機那么多。深圳目測是嵌入式Linux就業機會最多的城市,但是單片機機會看起來似乎更多,在深圳,單片機和Linux崗位數量對比大概6比4。
從嵌入式Linux城市的崗位數量來看,依次是深圳 》 上海 》 北京 》 成都 = 杭州 = 蘇州 》 東莞(華為加持)》= 珠海 》= 南京 = 廣州 = 武漢 = 西安 = 福州 = 廈門 》 佛山 = 長沙 = 天津 = 合肥 》 其它,
在其它城市我就很少了解到做嵌入式Linux開發相關的崗位。所以如果你要考慮轉行,首先考慮是否愿意背景離鄉去以上幾個城市工作。否則哪怕你學了牛逼的Linux技術,可能也會在當地找不到對口不得不繼續從事單片機開發。
3. 單片機雖然待遇較低,但是就業機會更多,對大齡求職者相對友好。這點其實并不矛盾,做單片機各行各業的小公司特別多 (當然像格力,美的這種傳統家電大廠也有,但是華為、商湯等新興高科技大廠很少招單片機),業務多種多樣,需要的人更多,但是一般小廠可能資金并不充裕,給不起人才高價,加上單片機開發門檻較低(不考慮產品穩定性,EMC等有工作經驗自然會知道的概念,僅指學習使用單片機干活編程的培養門檻), 培養周期比較短(大二學生一個暑假的功夫),所以導致中低端能干活的人還是挺多,拉低平均薪資。
但這就像富士康一樣,招人多,但抱怨缺人,老板就是不想把待遇提上去,要控制成本,這是缺人但是待遇低之間一種永遠存在的矛盾。但是對大齡求職者來說,由于單片機崗位實在是多,很多小廠真的很難以高的性價比招到優秀的人,在小廠也沒有HR插手做人力資源規劃,年齡梯隊建設,反而在年齡上卡的不嚴,大齡求職者只要薪資不挑,也能找到一份工作,所以相對于做Linux的大廠,對年齡問題比較寬容一些(可能由于單片機有點歷史了,大齡從業者也多)。
4. 單片機也有一些較高薪職位。在單片機工程師眼中,20k以上就算是高薪,以這個為標準,火哥也見過一些較高薪的職位,但是這里面有些特殊的要求。某家做智能門鎖STM32 RTOS的公司給火哥開過20K的offer,主要是因為公司希望招的技術人員都有985 211以上學歷背景,這樣溝通起來可能觀念比較一致,所以薪資能給到20k。另外還有一家明星獨角獸創業公司給過25K的單片機offer, 但是前提要求是能在Linux環境下開發單片機,而且面試難度較高,本來25K要價超出他們預期了,他們不愿意給這么多,后來火哥吊著他們一個星期,謊稱拿到華為同等價格的offer,他們才最終答應給25K的offer。剩下火哥還了解到有年薪80w的單片機高級工程師(掌握某些行業特殊的認證標準)。
但是整體來說,單片機較高薪的offer確實不容易拿到,而且拿到也不僅僅是因為你的單片機技術好,解bug能力強,而是因為你的背景,學歷,有其它offer抬價,掌握特殊的業務競爭力等等(關于嵌入式業務競爭力可以讀讀火哥上一篇關于嵌入式競爭力的文章),
這些特殊業務和文憑,背景都不是能靠當下自己砸時間努力看書學習寫代碼就能輕易獲取的。如果能單單靠自己砸時間努力就能獲取的技術就不是啥門檻性的技術。
列舉了以上這幾點,要不要從單片機開發轉嵌入式Linux相信你也應該可以下決定了。
二、 單片機和嵌入式Linux開發到底有什么異同
1. 單片機轉嵌入式Linux保留的優勢主要在于熟練的C語言編程能力以及豐富的底層軟件與硬件接口的調試經驗。因為Linux內核本身就是C語言編寫的,Linux底層應用程序大部分也是C語言的,一般有單片機開發經驗的,C語言應該不是問題,所以在切換的過程中,不需要考慮語言的切換,當然如果沒有系統學過數據結構(火哥認為數據結構是熟悉C語言必不可少的內容,哪怕單片機也要懂數據結構),可能需要補補,另外有uCOS FreeRTOS這類的實時操作系統開發經驗就更好,至少在看大規模C語言代碼的時候不害怕(其實懂uCOS內核也不代表能馬上掌握Linux內核,Linux內核真的復雜太多,設計理念也很不一樣)。另外豐富的單片機底層調試與寄存器配置經驗,可能幫助你在學習Linux嵌入式開發的時候能快速定位底層的一些問題,節約一些時間。
2. 單片機轉Linux嵌入式需要熟悉一套風格迥異的開發環境。對于大部分單片機工程師而言,都是在Windows上用IDE環境開發單片機程序為主(不排除有些公司已經使用Linux開發單片機了),Ubuntu這類Linux系統接觸比較少,所以你們要越過的第一關并不是Linux內核源碼,而是如何使用Ubuntu這種Linux系統。因為在Debian Ubuntu CentOS 等各種Linux系統做軟件開發,主要都是通過命令行操作,而不是鼠標界面點擊。并且Linux系統里面的應用軟件不像Windows里面的IDE這樣給你集成好了,點擊就能用,Linux里面很多Makefile之類的編譯腳本以及Samba, SSH Server等各種服務,arm-linux-gcc等各種編譯鏈接工具,就像IDE軟件里面的各個組件,需要自己重新組裝使用,并且用的時候可能有各種環境甚至編譯問題(開源軟件猛糙快就是這樣),需要自己折騰花費不少時間。
所以對于Linux入門者,哪怕你有豐富的單片機C語言經驗,折騰起來也挺耗時間,需要克服心理的障礙。
Linux系統開發環境就像一匹不聽話的烈馬,馴服他才能發揮出它的價值,而Windows系統開發環境更像一匹聽話的普通馬。
3. 嵌入式Linux開發代碼的掌控程度遠低于單片機開發,單片機轉Linux需要適應如何在這種低掌控度的不安全感中進行開發。做單片機開發,包括RTOS, 一般代碼量最多幾萬行,哪怕不是每行代碼都讀過,也基本能夠精確掌控每個模塊,大概哪里出了bug,作為開發者很容易定位。而做嵌入式Linux開發,單獨Linux內核就有幾百萬甚至上千萬行,還不包括各種你不熟悉的應用層的開源庫,這導致大部分代碼都不可能掌控。嵌入式Linux的開發模式就是在這種大部分代碼都不是你開發的,你也掌控不了大部分代碼的情況下開發驅動或者應用,你經常會不熟悉的東西需要各種搜索問人,這種開發模式,會把人置于一種不安之谷當中,很多你使用的函數你并不知道它的實現細節,可能工作機制都只是略懂。在這種模式下開發需要很好的搜索,溝通,團隊協作能力,不能再像單片機那樣一個人全局掌控,蒙著頭開發了,這種不可掌控的不安全感是單片機工程師往Linux嵌入式工程師發展過程中最需要適應的。
4. 嵌入式Linux開發需要有大局觀,不用迷失在細節的叢林找不到方向和出口。
很多單片機工程師有個思維習慣,編程時喜歡細摳到每個寄存器的工作原理,每個功能的實現細節邏輯,每個if else都不放過。這在Linux嵌入式學習中將非常耗費時間,事倍功半的做法。注重細節固然好,但是當系統龐大到一種程度的時候,過于注重細節的人,往往很難駕馭這個系統。我看到很多初學者,每個寄存器,鏈接腳本的每種寫法都要去糾結很久,芯片啟動方式更上生搬硬套把2440的啟動流程作為芯片啟動的唯一真理,處處往其他芯片套。殊不知很多東西都是人為約定的一些習慣性做法,每家公司的芯片有自己的特點,流程是死的,人是活的。
掌握大局觀,讓自己迅速熟悉整個系統的知識,很多細節上習慣性的東西自然而然就明白了,對整個系統的掌控力度就高了,遇到具體阻礙你前進的細節問題,再去嘗試處理。掌控并不意味著你知道每行代碼每個寄存器的意思,但是你能讓整個系統按照你的想法去運行。
三、 單片機轉嵌入式Linux大概需要學哪些基本的知識
吹了這么多水,到了真正上干貨的時候了,從單片機轉Linux嵌入式到底需要學些啥。如果沒有這一段,火哥真怕你下定轉行決心之后,馬上拿起一本Linux內核架構與實現的書,以為像學uCOS等RTOS系統一樣,都是C語言代碼,然后看得云里霧里,從入門到放棄。其實火哥在剛學習Linux嵌入式的,也犯過類似的錯誤,因而總結了一些經驗教訓。
1. 你需要花一定時間熟悉如何使用Linux系統進行編程開發。相信很多童鞋都是從小使用Windows電腦長大的,在學計算機編程之前,應該沒有接觸過Ubuntu等Linux系統,而這個系統又不像Windows那樣點點鼠標就聽話,需要各種命令行操作。而且系統里面有各種服務和應用工具需要你自己按照需求去配置。所以學習嵌入式Linux開發不是急于鉆進Linux內核代碼的海洋中,而是先用好Linux系統。你可以參考《鳥哥的Linux私房菜》等Linux系統如何安裝使用等書籍,學會使用命令行。
但是火哥認為學習要有目標性,如果對著《鳥哥的Linux私房菜》一頁一頁每個命令學下去,看幾天就會枯草乏味了,所以火哥建議由單片機開發經驗的童鞋,第一個目標就是在Linux系統上如何搭建你的單片機開發板交叉環境,編譯出一個裸機的Led點燈的程序(不需要跑Linux內核),并通過開發板產商提供的工具燒寫。
這件事情并不難,網上已經有很多如何在Linux系統下交叉編譯單片機程序的文章,尤其是stm32系列的,你可以參考別人的文章做一遍,在這過程中你將會熟悉各種常用的命令,shell, arm-linux-gcc交叉編譯工具鏈,Makefile(可以單獨參考陳皓的文章)等Linux編程環境相關的知識,從而開始進入Linux的世界。
2. 你需要知道嵌入式Linux系統是怎么跑起來的,一般由哪些組成部分。相信大部分人轉行嵌入式Linux開發并不是為了在Linux系統上開發單片機程序,而是想做Linux驅動或者應用開發。在走完入門第一步之后,就不要太糾結那些編譯,鏈接腳本那些文件格式怎么寫,而是盡快把精力專注到Linux系統開發。學習嵌入式Linux系統開發,首先就得知道一個Linux系統如何跑起來,如何把一個Linux系統環境在開發板上搭起來。這牽涉到bootrom, bootloader, uboot, dts, Linux內核,cmdline, rootfs等一系列組件,以及nand啟動,nor啟動等各種不同的方式,知道一個Linux嵌入式系統如何工作,再進一步修改添加自己的驅動和應用。
這里有很多實踐性的東西,可能需要視頻資料帶你跑一遍,才能快速入門,火哥之前看的是韋東山老師的嵌入式Linux視頻,總共有一二三四期等,有免費試看,也有付費的,直接X寶聯系賣家可以了解,火哥就不貼廣告鏈接了。另外還有其它視頻,火哥沒有看過的,就不隨便推薦了,在嵌入式Linux學習這塊,理論性的知識需要慢慢看書,但是實踐性的知識還是需要視頻資料帶你操作快速入門,看書和實踐循環漸進。
3. 你可以嘗試做一些簡單的Linux應用和驅動開發了。走完了前面兩個步驟,相信你對嵌入式Linux開發有一定專業性認識了。在嵌入式Linux學習這塊,火哥更傾向于在做中學,60%實踐+40%理論。因為嵌入式Linux里面很多系統環境相關的東西,并不是書本上那種嚴格的理論公式,通過看書很難找到規律,而且在Linux內核里面有一整套GNU(GNU是啥意思自己搜)世界的行話,那些寫Linux內核,驅動書籍的技術專家不可能所有行話都給你解釋,所有在沒有使用和開發經驗的前提下就直接打開《Unix環境高級編程》、《Linux設備驅動程序》等大牛的經典書籍,容易讓你云里霧里。火哥建議是,跟著一個視頻教程,比如韋東山老師的嵌入式Linux視頻,從0開始寫一個簡單驅動和應用,讓自己寫的驅動和應用代碼跑起來,點亮1個Led燈,先不用管Linux驅動中你調用的那些初始化,注冊等框架函數如何實現。通過實踐的過程,熟悉整個代碼的運行環境以及Linux開發中的各種行話(系統調用,vfs等等)。
這也是讓你一步一步取得學習正反饋,提升成就感和學習信心的方法。其實Linux驅動開發本身并不難(難度不會超過你復變函數課本上的公式),也并不神秘,只不過它一整套行話術語,容易讓初學者云里霧里,熟悉這套行話,擺脫恐懼心理,一個智商正常的普通本科生應該是能夠掌握的。
4. 你需要補充一些計算機的理論知識。據火哥了解,大部分單片機工程師都是電子、通信、自動化、機械等專業出身,很少計算機專業的。這些專業的童鞋,相對會缺乏計算機專業的基本理論知識,如數據結構,操作系統,計算機組成原理,計算機網絡,算法,編譯鏈接的基本原理,數據庫等等。
補充理論知識是一個長期的過程(可能需要2-3年),并不是要等到計算機的專業理論都學完才可以去找工作,你可以一邊補充基礎知識一邊面試一邊找工作,同時檢驗自己的基礎知識。這些基礎知識不但能提高你的技術功底,也能幫你通過筆試面試,決定你能否在一線城市突破20K的薪水。
在有了計算機科班的基礎知識,以及有一定Linux驅動開發經驗之后,Linux內核的學習是有必要的,但是入門的初學者不用急于進入Linux內核源碼,內核這塊東西還是挺多的挺艱深的,得花時間邊看書邊看代碼慢慢啃,沒法速成,但是Linux內核功底還是能夠提高你的薪資競爭力。
四、 給有工作經驗的轉行者的建議
1. 有工作的轉行者,你的優勢是有保底的工作和收入,劣勢是沒有足夠的學習時間自由。有了當前的工作飯碗,不用急著找新工作,你可以保持一個良好的心態,不驕不躁,可以邊學習邊騎驢找馬,找到合適的工作。當然有工作的人,時間上并不自由,如果你想學的新東西和你當前工作內容并不直接相關,火哥建議你可以先選擇一份加班少的工作,這樣可以騰出下班后的業余時間來學習嵌入式Linux的新知識。
有工作的人,有了一些小積蓄,缺的是時間,那么在學習上可以適當買一些性價比高的付費視頻,加快入門和學習進度,節約寶貴的時間,這也是用金錢換時間。一般情況下,不需要學精通才出去找工作,學到可以self correct(這個詞來源于一個TED關于如何快速自學的演講), 能夠干一些活的狀態,就可以出去面試找相關的工作了,Linux嵌入式學習以通用基礎知識為主,驅動里面的音視頻,通信協議相關的業務上的知識可以找到相關的工作再補充。
2. 如何在只有單片機經驗,沒有Linux開發經驗的情況下,如何通過社招嵌入式Linux開發工作?這個對于社招看中相關工作背景的求職者是個頭疼的問題,火哥有以下幾點建議:
首先,看看公司是否有Linux相關的部門和開發計劃,可以主動嘗試內部轉崗。
第二,看看能不能建議公司技術負責人把單片機開發的環境遷移到Linux系統上,在Linux系統環境上開發單片機,這樣至少你在工作中有使用Linux系統的機會。
第三,可以先嘗試面一些在Linux環境下開發單片機的公司,面試后詢問面試官是否在Linux環境下開發單片機,如果是,可以先加入用Linux開發單片機的公司繼續做一段時間單片機,順便再工作中熟悉一下Linux.
第四,嘗試一下面試真正做Linux系統開發的公司一些Bootloader或者固件開發相關的崗位,因為Bootloader和存儲控制器,電管管理等固件代碼和單片機裸機rtos開發有很多相關性,甚至ARM SOC里面就有單片機核以及相關的固件,用于控制wifi,存儲,電源休眠喚醒等相關的功能,這樣能保證你能夠在新工作中有一定輸出貢獻,而不是完全的學習者。
第四,嘗試面試一些流動性高,離職率高的真正做Linux公司。這樣的公司一個詞形容:“缺人”。火哥之前在珠海某IC原廠工作,由于珠海相關的從業者基數少,應屆畢業生很多也不愿意來小城市發展,再加上公司近年業績不好,離職率高,導致公司缺人,并且很難招到人,所以后來放開招人標準,愿意培養只有單片機經驗,沒有Linux經驗社招者。
當然現在火哥在的深圳知名大廠,由于從業人口基數大,公司品牌和待遇都很有競爭力,競爭較為激烈,雖然號稱缺人(其實是招人太挑剔了),但是一般不會給沒有Linux經驗的求職者機會。
最后,在學習Linux嵌入式的過程中,遇到的問題和寫的代碼,最好有技術博客和GitHub記錄下來,把相關鏈接貼在簡歷上,這也是像面試官證明你真的對嵌入式Linux有一定了解,面試官看完你的博客和GitHub,才能對你的技術水平有進一步了解,決定是否給你機會。
看來讀者圈中做單片機,RTOS的不少。盡管火哥目前從事Linux/Android方面的嵌入式開發工作,但是讀書的時候也有5年左右單片機裸機和RTOS經驗,之前面試也拿過一些做單片機stm32開發的offer,所以今天分享一些關于單片機是否要轉嵌入式Linux的一些觀點。
一、你真的決定要轉嵌入式Linux嗎?
要不要從單片機轉嵌入式Linux是一個影響到職業發展的嚴肅決策,火哥不能幫你拿主意,只能幫你列出利弊,你需要根據自身的各種環境(比如所在城市Linux嵌入式相關崗位多嗎?是否決定背井離鄉去北上深發展等等)做出最有利的決策。火哥的觀點并不是Linux嵌入式絕對比單片機開發職業發展好,只是根據自身的一些經歷,給出一些看法。
1. 單片機開發相對于Linux嵌入式最大的劣勢在于基層的打工崗位平均薪資偏低。我想這是大部分單片機工程師想轉嵌入式Linux的最主要的原因。技術本身各有優劣,但是就基層打工而言,在同一座城市,就打工而言,單片機的薪資比嵌入式Linux低30%到50%。也許很多有會拿某些做單片機的高薪的老板(比如野火的火哥,周立功等)或者一些公司高管的薪資和做嵌入式Linux打工的工程師對比,證明單片機也可以拿高收入。
但是他們都犯了田忌賽馬的錯誤,拿別人的上等馬和你的中等馬對比,火哥認為這種田忌賽馬的比較非常不切實際,基層打工的就應該和基層打工的這個水平的對比。目前火哥調查到情況來看,在深圳的基層就業市場,單片機(含RTOS)開發的起步薪資在6K-7K, 一般人到15K就是高薪,很難突破。20K以上的單片機offer也有,但是很少,最多也見過25K的單片機offer,但是那都是有名企,名校或者其他業務背景換來的,一般人真拿不到。嵌入式Linux/Android這塊,薪資相對高不少,起步價12K很正常,工作2年一般都能突破15K,3-5年突破20K甚至到25K也是很多的,5年以上去一線土豪大廠(華為、OPPO、VIVO等)可以到30K,如果在手機大廠做到模塊owner專家,突破40K也是可以有,但是在往上就有點難了。
整體來看,同檔次的基層打工者,嵌入式Linux薪資比單片機開發還是高不少,單片機15K就會遇到瓶頸,突破20K就很難了,嵌入式Linux突破20K并不是難事,到25K以上才遇到瓶頸。
2. 你所在的城市嵌入式Linux崗位多嗎?我覺得這是影響你做決定的另一個大問題。我們學嵌入式Linux這門技術,絕大部分人是為了從事相關的工作,而不是陶冶情操。但是根據火哥統計來看,嵌入式Linux的普遍薪資雖然高于單片機,但是就業崗位并沒有單片機那么多。深圳目測是嵌入式Linux就業機會最多的城市,但是單片機機會看起來似乎更多,在深圳,單片機和Linux崗位數量對比大概6比4。
從嵌入式Linux城市的崗位數量來看,依次是深圳 》 上海 》 北京 》 成都 = 杭州 = 蘇州 》 東莞(華為加持)》= 珠海 》= 南京 = 廣州 = 武漢 = 西安 = 福州 = 廈門 》 佛山 = 長沙 = 天津 = 合肥 》 其它,
在其它城市我就很少了解到做嵌入式Linux開發相關的崗位。所以如果你要考慮轉行,首先考慮是否愿意背景離鄉去以上幾個城市工作。否則哪怕你學了牛逼的Linux技術,可能也會在當地找不到對口不得不繼續從事單片機開發。
3. 單片機雖然待遇較低,但是就業機會更多,對大齡求職者相對友好。這點其實并不矛盾,做單片機各行各業的小公司特別多 (當然像格力,美的這種傳統家電大廠也有,但是華為、商湯等新興高科技大廠很少招單片機),業務多種多樣,需要的人更多,但是一般小廠可能資金并不充裕,給不起人才高價,加上單片機開發門檻較低(不考慮產品穩定性,EMC等有工作經驗自然會知道的概念,僅指學習使用單片機干活編程的培養門檻), 培養周期比較短(大二學生一個暑假的功夫),所以導致中低端能干活的人還是挺多,拉低平均薪資。
但這就像富士康一樣,招人多,但抱怨缺人,老板就是不想把待遇提上去,要控制成本,這是缺人但是待遇低之間一種永遠存在的矛盾。但是對大齡求職者來說,由于單片機崗位實在是多,很多小廠真的很難以高的性價比招到優秀的人,在小廠也沒有HR插手做人力資源規劃,年齡梯隊建設,反而在年齡上卡的不嚴,大齡求職者只要薪資不挑,也能找到一份工作,所以相對于做Linux的大廠,對年齡問題比較寬容一些(可能由于單片機有點歷史了,大齡從業者也多)。
4. 單片機也有一些較高薪職位。在單片機工程師眼中,20k以上就算是高薪,以這個為標準,火哥也見過一些較高薪的職位,但是這里面有些特殊的要求。某家做智能門鎖STM32 RTOS的公司給火哥開過20K的offer,主要是因為公司希望招的技術人員都有985 211以上學歷背景,這樣溝通起來可能觀念比較一致,所以薪資能給到20k。另外還有一家明星獨角獸創業公司給過25K的單片機offer, 但是前提要求是能在Linux環境下開發單片機,而且面試難度較高,本來25K要價超出他們預期了,他們不愿意給這么多,后來火哥吊著他們一個星期,謊稱拿到華為同等價格的offer,他們才最終答應給25K的offer。剩下火哥還了解到有年薪80w的單片機高級工程師(掌握某些行業特殊的認證標準)。
但是整體來說,單片機較高薪的offer確實不容易拿到,而且拿到也不僅僅是因為你的單片機技術好,解bug能力強,而是因為你的背景,學歷,有其它offer抬價,掌握特殊的業務競爭力等等(關于嵌入式業務競爭力可以讀讀火哥上一篇關于嵌入式競爭力的文章),
這些特殊業務和文憑,背景都不是能靠當下自己砸時間努力看書學習寫代碼就能輕易獲取的。如果能單單靠自己砸時間努力就能獲取的技術就不是啥門檻性的技術。
列舉了以上這幾點,要不要從單片機開發轉嵌入式Linux相信你也應該可以下決定了。
二、 單片機和嵌入式Linux開發到底有什么異同
1. 單片機轉嵌入式Linux保留的優勢主要在于熟練的C語言編程能力以及豐富的底層軟件與硬件接口的調試經驗。因為Linux內核本身就是C語言編寫的,Linux底層應用程序大部分也是C語言的,一般有單片機開發經驗的,C語言應該不是問題,所以在切換的過程中,不需要考慮語言的切換,當然如果沒有系統學過數據結構(火哥認為數據結構是熟悉C語言必不可少的內容,哪怕單片機也要懂數據結構),可能需要補補,另外有uCOS FreeRTOS這類的實時操作系統開發經驗就更好,至少在看大規模C語言代碼的時候不害怕(其實懂uCOS內核也不代表能馬上掌握Linux內核,Linux內核真的復雜太多,設計理念也很不一樣)。另外豐富的單片機底層調試與寄存器配置經驗,可能幫助你在學習Linux嵌入式開發的時候能快速定位底層的一些問題,節約一些時間。
2. 單片機轉Linux嵌入式需要熟悉一套風格迥異的開發環境。對于大部分單片機工程師而言,都是在Windows上用IDE環境開發單片機程序為主(不排除有些公司已經使用Linux開發單片機了),Ubuntu這類Linux系統接觸比較少,所以你們要越過的第一關并不是Linux內核源碼,而是如何使用Ubuntu這種Linux系統。因為在Debian Ubuntu CentOS 等各種Linux系統做軟件開發,主要都是通過命令行操作,而不是鼠標界面點擊。并且Linux系統里面的應用軟件不像Windows里面的IDE這樣給你集成好了,點擊就能用,Linux里面很多Makefile之類的編譯腳本以及Samba, SSH Server等各種服務,arm-linux-gcc等各種編譯鏈接工具,就像IDE軟件里面的各個組件,需要自己重新組裝使用,并且用的時候可能有各種環境甚至編譯問題(開源軟件猛糙快就是這樣),需要自己折騰花費不少時間。
所以對于Linux入門者,哪怕你有豐富的單片機C語言經驗,折騰起來也挺耗時間,需要克服心理的障礙。
Linux系統開發環境就像一匹不聽話的烈馬,馴服他才能發揮出它的價值,而Windows系統開發環境更像一匹聽話的普通馬。
3. 嵌入式Linux開發代碼的掌控程度遠低于單片機開發,單片機轉Linux需要適應如何在這種低掌控度的不安全感中進行開發。做單片機開發,包括RTOS, 一般代碼量最多幾萬行,哪怕不是每行代碼都讀過,也基本能夠精確掌控每個模塊,大概哪里出了bug,作為開發者很容易定位。而做嵌入式Linux開發,單獨Linux內核就有幾百萬甚至上千萬行,還不包括各種你不熟悉的應用層的開源庫,這導致大部分代碼都不可能掌控。嵌入式Linux的開發模式就是在這種大部分代碼都不是你開發的,你也掌控不了大部分代碼的情況下開發驅動或者應用,你經常會不熟悉的東西需要各種搜索問人,這種開發模式,會把人置于一種不安之谷當中,很多你使用的函數你并不知道它的實現細節,可能工作機制都只是略懂。在這種模式下開發需要很好的搜索,溝通,團隊協作能力,不能再像單片機那樣一個人全局掌控,蒙著頭開發了,這種不可掌控的不安全感是單片機工程師往Linux嵌入式工程師發展過程中最需要適應的。
4. 嵌入式Linux開發需要有大局觀,不用迷失在細節的叢林找不到方向和出口。
很多單片機工程師有個思維習慣,編程時喜歡細摳到每個寄存器的工作原理,每個功能的實現細節邏輯,每個if else都不放過。這在Linux嵌入式學習中將非常耗費時間,事倍功半的做法。注重細節固然好,但是當系統龐大到一種程度的時候,過于注重細節的人,往往很難駕馭這個系統。我看到很多初學者,每個寄存器,鏈接腳本的每種寫法都要去糾結很久,芯片啟動方式更上生搬硬套把2440的啟動流程作為芯片啟動的唯一真理,處處往其他芯片套。殊不知很多東西都是人為約定的一些習慣性做法,每家公司的芯片有自己的特點,流程是死的,人是活的。
掌握大局觀,讓自己迅速熟悉整個系統的知識,很多細節上習慣性的東西自然而然就明白了,對整個系統的掌控力度就高了,遇到具體阻礙你前進的細節問題,再去嘗試處理。掌控并不意味著你知道每行代碼每個寄存器的意思,但是你能讓整個系統按照你的想法去運行。
三、 單片機轉嵌入式Linux大概需要學哪些基本的知識
吹了這么多水,到了真正上干貨的時候了,從單片機轉Linux嵌入式到底需要學些啥。如果沒有這一段,火哥真怕你下定轉行決心之后,馬上拿起一本Linux內核架構與實現的書,以為像學uCOS等RTOS系統一樣,都是C語言代碼,然后看得云里霧里,從入門到放棄。其實火哥在剛學習Linux嵌入式的,也犯過類似的錯誤,因而總結了一些經驗教訓。
1. 你需要花一定時間熟悉如何使用Linux系統進行編程開發。相信很多童鞋都是從小使用Windows電腦長大的,在學計算機編程之前,應該沒有接觸過Ubuntu等Linux系統,而這個系統又不像Windows那樣點點鼠標就聽話,需要各種命令行操作。而且系統里面有各種服務和應用工具需要你自己按照需求去配置。所以學習嵌入式Linux開發不是急于鉆進Linux內核代碼的海洋中,而是先用好Linux系統。你可以參考《鳥哥的Linux私房菜》等Linux系統如何安裝使用等書籍,學會使用命令行。
但是火哥認為學習要有目標性,如果對著《鳥哥的Linux私房菜》一頁一頁每個命令學下去,看幾天就會枯草乏味了,所以火哥建議由單片機開發經驗的童鞋,第一個目標就是在Linux系統上如何搭建你的單片機開發板交叉環境,編譯出一個裸機的Led點燈的程序(不需要跑Linux內核),并通過開發板產商提供的工具燒寫。
這件事情并不難,網上已經有很多如何在Linux系統下交叉編譯單片機程序的文章,尤其是stm32系列的,你可以參考別人的文章做一遍,在這過程中你將會熟悉各種常用的命令,shell, arm-linux-gcc交叉編譯工具鏈,Makefile(可以單獨參考陳皓的文章)等Linux編程環境相關的知識,從而開始進入Linux的世界。
2. 你需要知道嵌入式Linux系統是怎么跑起來的,一般由哪些組成部分。相信大部分人轉行嵌入式Linux開發并不是為了在Linux系統上開發單片機程序,而是想做Linux驅動或者應用開發。在走完入門第一步之后,就不要太糾結那些編譯,鏈接腳本那些文件格式怎么寫,而是盡快把精力專注到Linux系統開發。學習嵌入式Linux系統開發,首先就得知道一個Linux系統如何跑起來,如何把一個Linux系統環境在開發板上搭起來。這牽涉到bootrom, bootloader, uboot, dts, Linux內核,cmdline, rootfs等一系列組件,以及nand啟動,nor啟動等各種不同的方式,知道一個Linux嵌入式系統如何工作,再進一步修改添加自己的驅動和應用。
這里有很多實踐性的東西,可能需要視頻資料帶你跑一遍,才能快速入門,火哥之前看的是韋東山老師的嵌入式Linux視頻,總共有一二三四期等,有免費試看,也有付費的,直接X寶聯系賣家可以了解,火哥就不貼廣告鏈接了。另外還有其它視頻,火哥沒有看過的,就不隨便推薦了,在嵌入式Linux學習這塊,理論性的知識需要慢慢看書,但是實踐性的知識還是需要視頻資料帶你操作快速入門,看書和實踐循環漸進。
3. 你可以嘗試做一些簡單的Linux應用和驅動開發了。走完了前面兩個步驟,相信你對嵌入式Linux開發有一定專業性認識了。在嵌入式Linux學習這塊,火哥更傾向于在做中學,60%實踐+40%理論。因為嵌入式Linux里面很多系統環境相關的東西,并不是書本上那種嚴格的理論公式,通過看書很難找到規律,而且在Linux內核里面有一整套GNU(GNU是啥意思自己搜)世界的行話,那些寫Linux內核,驅動書籍的技術專家不可能所有行話都給你解釋,所有在沒有使用和開發經驗的前提下就直接打開《Unix環境高級編程》、《Linux設備驅動程序》等大牛的經典書籍,容易讓你云里霧里。火哥建議是,跟著一個視頻教程,比如韋東山老師的嵌入式Linux視頻,從0開始寫一個簡單驅動和應用,讓自己寫的驅動和應用代碼跑起來,點亮1個Led燈,先不用管Linux驅動中你調用的那些初始化,注冊等框架函數如何實現。通過實踐的過程,熟悉整個代碼的運行環境以及Linux開發中的各種行話(系統調用,vfs等等)。
這也是讓你一步一步取得學習正反饋,提升成就感和學習信心的方法。其實Linux驅動開發本身并不難(難度不會超過你復變函數課本上的公式),也并不神秘,只不過它一整套行話術語,容易讓初學者云里霧里,熟悉這套行話,擺脫恐懼心理,一個智商正常的普通本科生應該是能夠掌握的。
4. 你需要補充一些計算機的理論知識。據火哥了解,大部分單片機工程師都是電子、通信、自動化、機械等專業出身,很少計算機專業的。這些專業的童鞋,相對會缺乏計算機專業的基本理論知識,如數據結構,操作系統,計算機組成原理,計算機網絡,算法,編譯鏈接的基本原理,數據庫等等。
補充理論知識是一個長期的過程(可能需要2-3年),并不是要等到計算機的專業理論都學完才可以去找工作,你可以一邊補充基礎知識一邊面試一邊找工作,同時檢驗自己的基礎知識。這些基礎知識不但能提高你的技術功底,也能幫你通過筆試面試,決定你能否在一線城市突破20K的薪水。
在有了計算機科班的基礎知識,以及有一定Linux驅動開發經驗之后,Linux內核的學習是有必要的,但是入門的初學者不用急于進入Linux內核源碼,內核這塊東西還是挺多的挺艱深的,得花時間邊看書邊看代碼慢慢啃,沒法速成,但是Linux內核功底還是能夠提高你的薪資競爭力。
四、 給有工作經驗的轉行者的建議
1. 有工作的轉行者,你的優勢是有保底的工作和收入,劣勢是沒有足夠的學習時間自由。有了當前的工作飯碗,不用急著找新工作,你可以保持一個良好的心態,不驕不躁,可以邊學習邊騎驢找馬,找到合適的工作。當然有工作的人,時間上并不自由,如果你想學的新東西和你當前工作內容并不直接相關,火哥建議你可以先選擇一份加班少的工作,這樣可以騰出下班后的業余時間來學習嵌入式Linux的新知識。
有工作的人,有了一些小積蓄,缺的是時間,那么在學習上可以適當買一些性價比高的付費視頻,加快入門和學習進度,節約寶貴的時間,這也是用金錢換時間。一般情況下,不需要學精通才出去找工作,學到可以self correct(這個詞來源于一個TED關于如何快速自學的演講), 能夠干一些活的狀態,就可以出去面試找相關的工作了,Linux嵌入式學習以通用基礎知識為主,驅動里面的音視頻,通信協議相關的業務上的知識可以找到相關的工作再補充。
2. 如何在只有單片機經驗,沒有Linux開發經驗的情況下,如何通過社招嵌入式Linux開發工作?這個對于社招看中相關工作背景的求職者是個頭疼的問題,火哥有以下幾點建議:
首先,看看公司是否有Linux相關的部門和開發計劃,可以主動嘗試內部轉崗。
第二,看看能不能建議公司技術負責人把單片機開發的環境遷移到Linux系統上,在Linux系統環境上開發單片機,這樣至少你在工作中有使用Linux系統的機會。
第三,可以先嘗試面一些在Linux環境下開發單片機的公司,面試后詢問面試官是否在Linux環境下開發單片機,如果是,可以先加入用Linux開發單片機的公司繼續做一段時間單片機,順便再工作中熟悉一下Linux.
第四,嘗試一下面試真正做Linux系統開發的公司一些Bootloader或者固件開發相關的崗位,因為Bootloader和存儲控制器,電管管理等固件代碼和單片機裸機rtos開發有很多相關性,甚至ARM SOC里面就有單片機核以及相關的固件,用于控制wifi,存儲,電源休眠喚醒等相關的功能,這樣能保證你能夠在新工作中有一定輸出貢獻,而不是完全的學習者。
第四,嘗試面試一些流動性高,離職率高的真正做Linux公司。這樣的公司一個詞形容:“缺人”。火哥之前在珠海某IC原廠工作,由于珠海相關的從業者基數少,應屆畢業生很多也不愿意來小城市發展,再加上公司近年業績不好,離職率高,導致公司缺人,并且很難招到人,所以后來放開招人標準,愿意培養只有單片機經驗,沒有Linux經驗社招者。
當然現在火哥在的深圳知名大廠,由于從業人口基數大,公司品牌和待遇都很有競爭力,競爭較為激烈,雖然號稱缺人(其實是招人太挑剔了),但是一般不會給沒有Linux經驗的求職者機會。
最后,在學習Linux嵌入式的過程中,遇到的問題和寫的代碼,最好有技術博客和GitHub記錄下來,把相關鏈接貼在簡歷上,這也是像面試官證明你真的對嵌入式Linux有一定了解,面試官看完你的博客和GitHub,才能對你的技術水平有進一步了解,決定是否給你機會。
五、 給在校生轉行者的建議
對在校生來說,你多的是時間上的自由,缺的是金錢以及沒有一份保底的工作。
當然時間這東西就像衛生紙,看起來多,但是用著用著就沒有了,所以即使有充裕的時間,也要好好規劃,盡量多學一些東西。
在校生既然缺錢,火哥就不建議花好幾萬培訓費去參加線下的嵌入式培訓,實際上培訓的內容都是嵌入式入門級知識,質量上可能還比不過幾百塊的韋東山嵌入式Linux視頻。而且視頻教程在時間上可能比培訓更加靈活。
在校生的優勢在于大家都沒有行業相關經驗,校招的時候,不會考察你行業相關的知識,而更加注重計算機基礎知識的考察(火哥甚至是憑著操作系統,C語言,數據結構的筆試成績,基本沒有Linux開發經驗的情況下拿到IC原廠Linux的offer, 當然校招之后還有大半年,買了韋東山付費視頻狂補相關知識),所以在校生應該乘著寶貴的時間,把火哥上一節提到的第4點基礎知識打牢固,這樣工作之后就可以專注業務知識學習,更快升職加薪,不用因為基礎知識不牢,回爐重造。
另外,在校生可能有各種單片機嵌入式的競賽,在競賽過程中,可能可以拿到很多獎,得到老師同學的夸贊。但是切記戒驕戒躁,不要因為比普通的同學多掌握2個技術就自以為了不起(你們以后面試的競爭對手根本不是這些完全沒有技術同學),不要因為幾個獎狀就飄了,而不能靜下心來學習數據結構,操作系統原理等基礎知識。
如果不是在知名期刊發表高水平論文,或者國際上認可的ACM, Kaggle, ISLVRC圖像競賽中拿到那種高質量有分數和名次比賽結果的獎,其它國內競賽的獎在面試與實際工作中并沒有太多說服力,面試官反而喜歡基本功扎實,可塑性強的學生,而不是國內各種獎一堆,結果時間復雜度,鏈表堆棧,mmu虛擬地址空間等概念一問三不知的學生。
對在校生來說,你多的是時間上的自由,缺的是金錢以及沒有一份保底的工作。
當然時間這東西就像衛生紙,看起來多,但是用著用著就沒有了,所以即使有充裕的時間,也要好好規劃,盡量多學一些東西。
在校生既然缺錢,火哥就不建議花好幾萬培訓費去參加線下的嵌入式培訓,實際上培訓的內容都是嵌入式入門級知識,質量上可能還比不過幾百塊的韋東山嵌入式Linux視頻。而且視頻教程在時間上可能比培訓更加靈活。
在校生的優勢在于大家都沒有行業相關經驗,校招的時候,不會考察你行業相關的知識,而更加注重計算機基礎知識的考察(火哥甚至是憑著操作系統,C語言,數據結構的筆試成績,基本沒有Linux開發經驗的情況下拿到IC原廠Linux的offer, 當然校招之后還有大半年,買了韋東山付費視頻狂補相關知識),所以在校生應該乘著寶貴的時間,把火哥上一節提到的第4點基礎知識打牢固,這樣工作之后就可以專注業務知識學習,更快升職加薪,不用因為基礎知識不牢,回爐重造。
另外,在校生可能有各種單片機嵌入式的競賽,在競賽過程中,可能可以拿到很多獎,得到老師同學的夸贊。但是切記戒驕戒躁,不要因為比普通的同學多掌握2個技術就自以為了不起(你們以后面試的競爭對手根本不是這些完全沒有技術同學),不要因為幾個獎狀就飄了,而不能靜下心來學習數據結構,操作系統原理等基礎知識。
如果不是在知名期刊發表高水平論文,或者國際上認可的ACM, Kaggle, ISLVRC圖像競賽中拿到那種高質量有分數和名次比賽結果的獎,其它國內競賽的獎在面試與實際工作中并沒有太多說服力,面試官反而喜歡基本功扎實,可塑性強的學生,而不是國內各種獎一堆,結果時間復雜度,鏈表堆棧,mmu虛擬地址空間等概念一問三不知的學生。
編輯:hfy
-
單片機
+關注
關注
6037文章
44569瀏覽量
636207 -
嵌入式
+關注
關注
5086文章
19142瀏覽量
305979 -
工程師
+關注
關注
59文章
1571瀏覽量
68555 -
Linux
+關注
關注
87文章
11314瀏覽量
209791
發布評論請先 登錄
相關推薦
評論