作為一個(gè)C/C++軟件開(kāi)發(fā)的老程序員,我看到過(guò)很多新手程序員滿懷熱情投入到學(xué)習(xí)中來(lái),卻總是處處碰壁。大多數(shù)學(xué)習(xí)者同樣碰到過(guò)相同的障礙,但是,一旦克服了這些壁壘,那么好處立馬就來(lái):
(1)更享受學(xué)習(xí)經(jīng)歷
(2)進(jìn)步更快
(3)碰到難題更執(zhí)著,不輕言放棄
(4)寫(xiě)代碼時(shí)更獨(dú)立
那么,這些障礙究竟是什么呢,我們又該如何攻克它們?我們一起往下看:
1、不知道從什么技術(shù)入手
很多人會(huì)問(wèn):“我應(yīng)該先學(xué)什么編程語(yǔ)言?”之所以會(huì)提出這個(gè)問(wèn)題,是因?yàn)樗麄儾恢雷约簽槭裁匆獙W(xué)習(xí)代碼。
一旦你下定決心去完成一個(gè)特定的項(xiàng)目,那么從什么語(yǔ)言入手這個(gè)問(wèn)題就變成一件很容易的事情:
如果你想構(gòu)建iOS app,那么你需要學(xué)習(xí)Objective C或Swift。
如果你想構(gòu)建Android app,那么你需要學(xué)習(xí)Java。
如果你想構(gòu)建Web app,那么你需要學(xué)習(xí)JavaScript。
其實(shí)現(xiàn)在我們可以使用JavaScript來(lái)創(chuàng)建任何類型的項(xiàng)目——無(wú)論是簡(jiǎn)單的web和移動(dòng)app,還是高級(jí)的硬件項(xiàng)目。大多數(shù)行業(yè)中都有它的身影:音樂(lè)、醫(yī)療、游戲、時(shí)裝。這種語(yǔ)言非常值得學(xué)習(xí)。
如果你還是不能確定要選擇哪種語(yǔ)言,那么不妨咨詢下某個(gè)程序員的意見(jiàn)。只要你確定要構(gòu)建什么項(xiàng)目,那么他就能很快地為你推薦適合你使用的技術(shù)。
另外,知識(shí)都是相通的,所以,不要過(guò)于拘謹(jǐn),選擇語(yǔ)言這一步驟幾乎沒(méi)什么風(fēng)險(xiǎn)。
2、不正確的學(xué)習(xí)動(dòng)機(jī)
在談及壁壘之前,我想先著重說(shuō)明學(xué)習(xí)動(dòng)機(jī)的重要性。不要只是為了編程而學(xué)編程,也不要因?yàn)槁?tīng)說(shuō)它很酷,很劃得來(lái)就來(lái)學(xué)編程。
你得因?yàn)橐鉀Q問(wèn)題而學(xué)習(xí)編程,你得因?yàn)橄胍詣?dòng)化和改善生活而學(xué)習(xí)編程,你得因?yàn)橄胍獦?gòu)建應(yīng)用程序以造福社會(huì)來(lái)學(xué)習(xí)編程。
如果你只是喜歡編程,并希望以此作為職業(yè)的話,那么在之后的學(xué)習(xí)過(guò)程中,你可能會(huì)有一種強(qiáng)烈的沖動(dòng)想要放棄。這通常發(fā)生在事情變得艱難,學(xué)習(xí)體驗(yàn)變得痛苦的情況下。這時(shí)你會(huì)告訴自己,你不喜歡編程了,編程操作不適合你,覺(jué)得自己天生就成不了程序員。
這就是為什么你應(yīng)該考慮圍繞著完成項(xiàng)目設(shè)置目標(biāo)的原因。如果你的心里有計(jì)劃,或者你想要解決更高層次的問(wèn)題,那么你可以對(duì)自己說(shuō):“這可能不是一次愉快的經(jīng)歷,但是我真的想要解決這個(gè)大問(wèn)題,所以我一定要克服這個(gè)障礙。”
3、不能學(xué)以致用,以及責(zé)備自己
選擇好技術(shù)堆棧之后,剛開(kāi)始學(xué)習(xí)理論總是很輕松的,而且網(wǎng)上也有許許多多免費(fèi)和付費(fèi)的在線課程。
很快大多數(shù)學(xué)習(xí)者掌握了理論知識(shí),甚至完全可以自己來(lái)解釋某個(gè)代碼片段的工作原理。理論只是概念的有限集合。任何人都可以在幾天之內(nèi)記住它,如果她/他真的想的話。那么,關(guān)鍵的問(wèn)題是什么?
學(xué)習(xí)者碰到的最大問(wèn)題在于,實(shí)際應(yīng)用理論來(lái)解決問(wèn)題并編寫(xiě)新代碼的時(shí)候。這中間的差距實(shí)際上就是技能空白。
比如說(shuō)游泳。你可以閱讀大量的技術(shù)文章,然后解釋得就像一個(gè)專業(yè)教練。但是,要想實(shí)際應(yīng)用這些理論,就需要大量的實(shí)踐、斗爭(zhēng)和錯(cuò)誤——你肯定會(huì)吞下大量的水!
然而更糟糕的是你開(kāi)始責(zé)備自己。或者認(rèn)為自己不夠聰明,或者覺(jué)得自己沒(méi)有天賦。這其實(shí)跟聰明天賦沒(méi)有關(guān)系,你只是需要練習(xí)技能的過(guò)程:
1.選擇一個(gè)復(fù)雜的項(xiàng)目。理想情況下,這項(xiàng)目得能夠激發(fā)你的興趣。
2.將這個(gè)任務(wù)分割成既小又獨(dú)立的任務(wù)。例如,“實(shí)現(xiàn)登錄頁(yè)面”是一個(gè)很大的任務(wù)。解決一個(gè)任務(wù)不應(yīng)該超過(guò)20行左右的代碼。下面這些提示有助于成功做到這一點(diǎn):
如果你不能解決這個(gè)任務(wù),那么進(jìn)一步將它分割成更小的任務(wù)。
一個(gè)任務(wù)一次不應(yīng)該使用太多的理論概念。
3.一次專注一項(xiàng)任務(wù),而不是并行解決多任務(wù)。不要跳到下一個(gè)任務(wù),除非你已經(jīng)徹底測(cè)試過(guò)當(dāng)前任務(wù),并確信沒(méi)有問(wèn)題。
如果你不這么做,而此時(shí)應(yīng)用程序又出現(xiàn)了問(wèn)題,那么你就不知道你正在并行解決的多任務(wù)中到底是哪個(gè)出了問(wèn)題,尋找起來(lái)就麻煩多了。
4.確保自己在開(kāi)始任務(wù)之前知道所有必要的理論知識(shí)。有時(shí)候,你可能不知道需要學(xué)習(xí)什么理論,這很正常,所以你需要向他人尋求幫助:程序員朋友,導(dǎo)師,或類似StackOverflow的社區(qū)。
5.最后,你解決了任務(wù)。在解決任務(wù)的過(guò)程中,你可能會(huì)碰到很多問(wèn)題,你需要做的就是吸取教訓(xùn),這也是下面要說(shuō)的點(diǎn)。
4、不吸取解決任務(wù)中獲得的經(jīng)驗(yàn)教訓(xùn)
最好的情況是,你解決了任務(wù)并且結(jié)果證明非常有效。此時(shí),很多人往往就直接開(kāi)展下一個(gè)任務(wù)。但是如果你這樣做的話,那么你浪費(fèi)了一個(gè)絕佳的學(xué)習(xí)機(jī)會(huì)。
希望你能夠用以下問(wèn)題來(lái)挑戰(zhàn)自我,幫助自己成長(zhǎng):
哪些邊界情況會(huì)導(dǎo)致我的代碼失敗?即使現(xiàn)在還沒(méi)有失敗,有哪些應(yīng)用程序狀態(tài)可能會(huì)破壞代碼?
我的代碼是否足夠整潔?對(duì)其他開(kāi)發(fā)人員,甚至是自己而言,代碼是否易于理解和改變?因?yàn)橐院罂赡苄枰迯?fù)隱藏在這段代碼中的問(wèn)題,或者根據(jù)其他產(chǎn)品規(guī)格改變代碼。
我的方法是最好的嗎?有沒(méi)有其他選項(xiàng)是我可以選擇使用的?各個(gè)方案的利弊?這任務(wù)是否值得用不同的方式解決?
此模塊與其他模塊是如何交互的?是否會(huì)對(duì)其他模塊造成負(fù)面影響?是否容易被其他模塊影響?
然而,很多時(shí)候,你會(huì)進(jìn)退維谷。
5、你不知道如何處理一個(gè)任務(wù)
你不知道從哪里開(kāi)始?你可能會(huì)隨機(jī)地去嘗試,或者從其他地方復(fù)制一些你自己也不明白的代碼。但是,這是沒(méi)有幫助的。即使你復(fù)制來(lái)的代碼有效也沒(méi)用。因?yàn)楫?dāng)你今后再一次碰到類似的任務(wù),你依然不能解決。
如果你想妥善解決任務(wù),那么首先你得知道你為什么卡殼。下面是一些可能的原因:
1.沒(méi)有很好地掌握這些理論知識(shí):
語(yǔ)言語(yǔ)法
庫(kù)或API的工作原理,某個(gè)具體方法或類的工作原理
編程范式(例如:異步編程)
系統(tǒng)運(yùn)作(例如:HTTP請(qǐng)求是理解Web開(kāi)發(fā)的關(guān)鍵)
如果是上述情況,那么可以去復(fù)習(xí)理論知識(shí),如果依然摸不著頭腦,也可以去找人尋求幫助。
2.任務(wù)太大了,那就分解為一個(gè)個(gè)小任務(wù)。
3.也有可能是因?yàn)槟阕x得太快,忽略了一些你以為熟悉其實(shí)似是而非的概念,所以無(wú)法理解任務(wù)要求。
6、你知道如何解決任務(wù),但解決方案不管用
這是編程中最常見(jiàn)的情況,哪怕是那些經(jīng)驗(yàn)豐富的資深程序員也是如此。你的解決方案之所以不起作用最大的可能是你的代碼中存在著bug。
如何修復(fù)?方法是調(diào)試代碼。這也是作為一個(gè)程序員需要學(xué)習(xí)的最重要的技能之一。這不是可以隨便湊合的事,也不是玩幸運(yùn)猜猜猜游戲。如何尋找bug是有具體步驟的。而且很多書(shū)中都有教這個(gè)技能。
不幸的是,這是很多新手程序員失去動(dòng)力選擇放棄的難關(guān)。很少有課程會(huì)說(shuō)明調(diào)試的重要性。如果你不知道如何正確地調(diào)試,那么它就是不可戰(zhàn)勝無(wú)法攻克的難關(guān)。
很多人擔(dān)心會(huì)花太多時(shí)間用于調(diào)試代碼。這是正常的,在你第一年的編程規(guī)劃中這是不可避免的。
甚至,你還得學(xué)著去喜歡調(diào)試。不妨將此看成是一個(gè)機(jī)會(huì),一個(gè)修復(fù)錯(cuò)誤提高編程能力的機(jī)會(huì)。當(dāng)你解決了一個(gè)bug,可以問(wèn)問(wèn)自己這個(gè)問(wèn)題:“我為什么會(huì)犯這種錯(cuò)誤?以后我該如何預(yù)防再犯?”
還有一個(gè)好主意是將找到的bug寫(xiě)成編程日記,方便你總結(jié)和學(xué)習(xí)。
7、不知道如何接受幫助
當(dāng)我們?cè)趯W(xué)習(xí)代碼,或調(diào)試代碼時(shí),可以咨詢很多材料:書(shū)籍、課程、教程、導(dǎo)師,開(kāi)發(fā)者社區(qū)等等。
在你學(xué)習(xí)這些資源時(shí)最常見(jiàn)的問(wèn)題是,你并沒(méi)有完全了解幕后發(fā)生了什么事情,也不知道概念是如何融入到更大的藍(lán)圖中的。
例如:你在某個(gè)問(wèn)題上花了10小時(shí),最后終于有人提供一個(gè)解決方案,你往往會(huì)采取“拿來(lái)主義”——采納解決方案之后就直接跳到一個(gè)任務(wù)中去。千萬(wàn)別這樣做!相反:
思考自己之前的思維過(guò)程。問(wèn)問(wèn)自己,做錯(cuò)了什么,對(duì)于這個(gè)特定的解決方案有哪些是值得你先前的思路借鑒和改進(jìn)的地方。
詢問(wèn)他人的思維過(guò)程。她/他是如何解決的呢?向?qū)Ψ綄W(xué)習(xí),吸取經(jīng)驗(yàn)。
這也是在StackOverflow和谷歌上搜答案的一大缺點(diǎn):你只知道解決方案,不知道幕后的思考過(guò)程。
8、不去應(yīng)用你學(xué)到的理論
這篇文章也是理論知識(shí),除非你能夠?qū)W以致用,否則它是不會(huì)發(fā)揮一絲一毫作用的——多多應(yīng)用,直到它變成潛意思的例行程序。
編程其實(shí)就是通過(guò)形成良好的習(xí)慣來(lái)幫助你解決各種問(wèn)題的過(guò)程。
所以說(shuō),想要在程序員生涯內(nèi)有更高的成就的話,最最重要的是盡可能的提升自己的編程能力,并且,與其想著怎么去提升,不如從現(xiàn)在開(kāi)始動(dòng)手動(dòng)腦,如果對(duì)于C/C++感興趣的話,可以關(guān)注+私信小編【編程交流】有一些視頻希望可以幫助到你,學(xué)習(xí)不怕從零開(kāi)始,就怕從不開(kāi)始。
-
Web
+關(guān)注
關(guān)注
2文章
1269瀏覽量
69737 -
HTTP
+關(guān)注
關(guān)注
0文章
511瀏覽量
31525 -
C++
+關(guān)注
關(guān)注
22文章
2114瀏覽量
73863
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論