欧美性猛交xxxx免费看_牛牛在线视频国产免费_天堂草原电视剧在线观看免费_国产粉嫩高清在线观看_国产欧美日本亚洲精品一5区

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

計(jì)算機(jī)編程領(lǐng)域的知識

算法與數(shù)據(jù)結(jié)構(gòu) ? 來源:編程指北 ? 作者:編程指北 ? 2020-10-30 09:51 ? 次閱讀

前言

為什么突然想寫這個(gè)話題呢? 最近有不少新關(guān)注的讀者,在后臺(tái)問:大學(xué)學(xué) JavaC++ 哪個(gè)好找工作,學(xué)前端好還是后端好,該學(xué) Vue 還是 React。。。 仿佛看到了自己當(dāng)年的模樣,所以覺得有必要單獨(dú)寫一篇文章,單純以一個(gè)計(jì)算機(jī)應(yīng)屆畢業(yè)生的身份聊聊,我認(rèn)為大學(xué)四年,計(jì)算機(jī)科班學(xué)生應(yīng)該學(xué)些什么,哪些才是重點(diǎn)。 同樣大學(xué)四年,為什么有些同學(xué)畢業(yè)就能成為大廠 Offer 收割機(jī),各種 SP、SSP 拿到手軟,有的同學(xué)明明在學(xué)校寫了好多網(wǎng)站,項(xiàng)目經(jīng)歷滿滿,經(jīng)歷春秋招,卻找到一份工作都很難。不能說后者沒認(rèn)真學(xué)習(xí),或許是用力的方向不對。話不多說,直接進(jìn)正題吧。

正文

人類的知識邊界一直在不斷的擴(kuò)張,俗話說學(xué)無止境,這放在計(jì)算機(jī)領(lǐng)域也同樣適用,計(jì)算機(jī)本身是一個(gè)人造科學(xué),不屬于自然科學(xué)。 每年,甚至每個(gè)月都不斷有新的編程框架推出,學(xué)到頭禿你也學(xué)不完,也沒有必要去挨個(gè)學(xué)。 并且你會(huì)發(fā)現(xiàn),很多一二線大廠內(nèi)部用的東西基本都是自己搞一套的,比如服務(wù)發(fā)現(xiàn)、RPC、KV、DB、消息隊(duì)列、日志、監(jiān)控等等。 所以一般這些大廠招聘的時(shí)候基本不會(huì)因沒學(xué)過某種框架而掛你,反正很多東西都是要進(jìn)來重新學(xué)的。 他們會(huì)更加關(guān)注你的基礎(chǔ)知識、解決問題的經(jīng)驗(yàn)以及聰明度這種更加通用的能力上。 反而是一些小公司,可能會(huì)要求你必須會(huì) Spring、Vue、Redis... 這些框架或者組件。

騰訊JD

阿里JD

某家外包JD 上面分別是騰訊、阿里、某外包公司的招聘 JD(job description),顯然,騰訊阿里看中的是扎實(shí)的編程基本功和快速學(xué)習(xí)能力,這意味著有培養(yǎng)潛力。 而外包公司就要求你會(huì) xx 數(shù)據(jù)庫、Spring 之類。不去評價(jià)哪個(gè)好,但是如果你想去 BAT,那是不是至少對照著它們的 JD 來提高自己的能力,不失為一種捷徑。 在這里,我粗淺的把計(jì)算機(jī)編程領(lǐng)域的知識分為三個(gè)部分:

基礎(chǔ)知識

特定領(lǐng)域知識

框架和開發(fā)技能

基礎(chǔ)知識是指不管從事任何方向的軟件工程師都應(yīng)該掌握的,比如數(shù)據(jù)結(jié)構(gòu)、算法操作系統(tǒng)。 特定領(lǐng)域知識就是你從事某個(gè)細(xì)分方向時(shí)需要掌握的知識,比如做游戲引擎的需要掌握圖形學(xué);做前端的需要掌握瀏覽器渲染原理、前端三大件;算法工程師需要更多的數(shù)學(xué)知識。 畢竟計(jì)算機(jī)各種門類挺多的,需要選個(gè)細(xì)分方向?qū)Q邢氯?,什么都學(xué)只會(huì)什么都不精(大佬除外啦。

一、基礎(chǔ)知識

現(xiàn)在大環(huán)境比較浮躁,很少有人愿意花心思在基礎(chǔ)上,喜歡直接學(xué) Python機(jī)器學(xué)習(xí)、寫秒殺、做商城。 找工作的時(shí)候都是想看面經(jīng)、總結(jié)速成。 但是作為優(yōu)秀的計(jì)算機(jī)系學(xué)生的你怎么能流于各種編程框架(造框架除外),糾結(jié)學(xué) SpringBoot 還是 SSH 呢? 把時(shí)間花在算法、基礎(chǔ)學(xué)科上他不香嗎?功利一點(diǎn)講,回報(bào)反而會(huì)更大。 況且在計(jì)算機(jī)領(lǐng)域,很多基礎(chǔ)的理論并不十分高深,我們努努力就可以掌握其中的核心知識。

1.1 數(shù)學(xué)

首先說明,這里把數(shù)學(xué)列出來不是為了顯得高端,而是自己吃過數(shù)學(xué)的虧。 如果你是自學(xué)轉(zhuǎn)行當(dāng)程序員,我當(dāng)然不會(huì)推薦數(shù)學(xué),因?yàn)檗D(zhuǎn)行的大概率是去學(xué) Java、前端這類,對數(shù)學(xué)基本沒啥要求。 但是這篇文章主要面向的是還在大學(xué)的科班學(xué)生,這部分同學(xué)以后也許會(huì)去做算法(CV、NLP之類)、游戲引擎、信息安全編碼等 這些方向?qū)?shù)學(xué)要求就會(huì)偏高,在計(jì)算機(jī)領(lǐng)域,線代、概率論、統(tǒng)計(jì)學(xué)這些數(shù)學(xué)分支相對比較重要,計(jì)算機(jī)本質(zhì)上還是離散的。 比如在機(jī)器學(xué)習(xí)或數(shù)據(jù)挖掘中常常用線性代數(shù)來降低數(shù)據(jù)維度,很多問題最終都能化為求解線性方程組。 所以為了避免以后想走這些方向卻被數(shù)學(xué)卡住,在大一、大二上數(shù)學(xué)課的時(shí)候就好好的學(xué)一下。 書到用時(shí)方恨少,不要現(xiàn)在以為沒用處就不好好學(xué),等你需要的時(shí)候,就知道后悔了。(默默流下了不學(xué)無術(shù)的眼淚┭┮﹏┭┮ 什么?你說以后肯定做開發(fā)方向? 那的確可以把數(shù)學(xué)優(yōu)先級放后面一點(diǎn),用得確實(shí)不多,不過上數(shù)學(xué)課的時(shí)候總該認(rèn)真聽下吧,拿個(gè)高績點(diǎn)也是百利無一害嘛。說不準(zhǔn)哪天你又想加入算法內(nèi)卷大軍呢?

1.2 C語言

你也許會(huì)很疑惑,這里明明說基礎(chǔ)知識,為什么要把一門編程語言單獨(dú)列出來呢? 因?yàn)樵谖铱磥恚瑳]有比 C 語言更適合用來理解計(jì)算機(jī)系統(tǒng)了。 我們后面將會(huì)提到的操作系統(tǒng)、體系結(jié)構(gòu) 這些東西非常適合用 C 語言去理解或者去實(shí)踐。 并且 C 語言本身的語言特性非常少,但是想學(xué)好又是不容易,很多人都覺得 C 語言難,難在哪里呢?回想了一下我大一時(shí)的感受:

簡陋的標(biāo)準(zhǔn)庫,幾乎沒有可用的數(shù)據(jù)結(jié)構(gòu)和算法,什么都得自己來

指針很難理解和使用

需要了解匯編、鏈接、裝載、內(nèi)存等才能把 C 語言用好

不巧的是,這些東西正是計(jì)算機(jī)系統(tǒng)知識的一部分,所以用 C 語言作為學(xué)習(xí)計(jì)算機(jī)系統(tǒng)知識是最有效率的方式。 真的很難想象用 Java 或是 Python 去給別人講解內(nèi)存,因?yàn)檫@些語言抽象程度都比 C 語言高,意味著離計(jì)算機(jī)系統(tǒng)也就越遠(yuǎn)。 在 TIOBE 編程語言排行榜上,C語言幾乎永遠(yuǎn)占據(jù)前三位,其地位自然毋庸置疑。

TIOBE-2020排行榜 而且?guī)缀跄汩_發(fā)中用到的很多東西都是用C語言編寫的,Linux、Nginx、Redis、MySQL、Git......或許你會(huì)想要探究下原理,閱讀點(diǎn)這些開源軟件的源碼,那么 C 語言也是你必備的瑞士軍刀。 深入學(xué)習(xí) C 語言,能夠了解計(jì)算機(jī)底層的執(zhí)行原理,是理解程序運(yùn)行機(jī)制的絕佳語言,無出其右。 在這里,不得不引用對C語言最經(jīng)典的總結(jié):

任何比C語言更低級的語言,都不足以完整地抽象一個(gè)計(jì)算機(jī)系統(tǒng);任何比C高級的語言,都可以用C來實(shí)現(xiàn)。

這真是極高而中肯的評價(jià)! 所以對于計(jì)算機(jī)科班來說,不管你是做前端還是后端,算法還是開發(fā),C 語言都建議你好好學(xué)習(xí)。這是無關(guān)方向的一門語言,就是基礎(chǔ)!

1.3 操作系統(tǒng)

我們編程的 IDE、寫出來的程序全部都需要運(yùn)行在操作系統(tǒng)上,說操作系統(tǒng)是計(jì)算機(jī)軟件的基石也不為過。 程序運(yùn)行起來就需要?jiǎng)?chuàng)建進(jìn)程,這涉及到操作系統(tǒng)的進(jìn)程管理;寫程序需要定義變量、存儲(chǔ)數(shù)據(jù)吧,這又涉及到內(nèi)存,對應(yīng)內(nèi)存管理;有時(shí)候我們還需要讀寫文件,這又離不開和文件系統(tǒng)打交道;你需要學(xué)習(xí)使用鎖、條件變量、臨界區(qū)來保證程序并發(fā)執(zhí)行時(shí)不會(huì)錯(cuò)亂。 而讀寫文件、分配內(nèi)存這些又離不開系統(tǒng)調(diào)用(System call)。 并且當(dāng)你真正做起工程就會(huì)發(fā)現(xiàn),很多問題是和操作系統(tǒng)緊密相關(guān)的,不理解操作系統(tǒng),你連問題的原因都分析不出來。 比如前段時(shí)間我們出現(xiàn)的在基于協(xié)程(libco)的框架下,使用多線程的鎖去做同步互斥偶發(fā)死鎖,后來分析才發(fā)現(xiàn)原因: 由于協(xié)程是應(yīng)用層實(shí)現(xiàn)的,一個(gè)線程內(nèi)多個(gè)協(xié)程對于操作系統(tǒng)是感知不到的:

協(xié)程模型 那么當(dāng)一個(gè)協(xié)稱 A 上鎖后發(fā)起網(wǎng)絡(luò) IO 請求,這個(gè)時(shí)候會(huì)被切換到另外一個(gè)協(xié)程B,而協(xié)程 B 又去請求這個(gè)鎖。 那么這個(gè)時(shí)候操作系統(tǒng)會(huì)認(rèn)為這個(gè)鎖已經(jīng)被上了,因此會(huì)將協(xié)程 B 對應(yīng)的線程掛起到等待隊(duì)列,這樣的話就導(dǎo)致協(xié)程 A 永遠(yuǎn)無法運(yùn)行,也就無法釋放鎖,導(dǎo)致死鎖。 解決的方法也很簡單,就是將鎖設(shè)置為可重入鎖,可重入意味著同一個(gè)線程多次去請求同一個(gè)鎖不會(huì)導(dǎo)致掛起。這樣當(dāng)協(xié)程 B 再去請求鎖的時(shí)候,操作系統(tǒng)就會(huì)認(rèn)為協(xié)程 B 所在的線程已經(jīng)持有這個(gè)鎖了,直接返回,繼續(xù)執(zhí)行。 總之,我們寫程序每時(shí)每刻都在和操作系統(tǒng)交互,沒有理由不學(xué)好。

1.4 編譯原理

編譯原理可能是我們平時(shí)接觸得最少的了,大家也許會(huì)覺得自己又不用去造新的編程語言,學(xué)編譯原理干啥。 學(xué)好編譯原理有啥用? 你會(huì)站在更高的角度去審視這些編程語言,看到的不再是表面的語法,更會(huì)想到語法背后的實(shí)現(xiàn)。 這種感覺很透徹,就像搞懂了操作系統(tǒng)、體系結(jié)構(gòu)你會(huì)明白一個(gè)程序從雙擊鼠標(biāo)開始,到底是如何被運(yùn)行起來的,這種掌握一切細(xì)節(jié),透徹的感覺,真的很奇妙,不信你去試試。 說人話! 那學(xué)了編譯原理你能干啥? 當(dāng)你學(xué)完有限狀態(tài)機(jī)以后,你會(huì)發(fā)現(xiàn)以前覺得很牛逼正則表達(dá)式似乎自己也能用 DFA、NFA 實(shí)現(xiàn)一下了。狀態(tài)機(jī)的思想在編程中很多地方都用得上。 比如解析 HTTP 協(xié)議,如果沒學(xué)過狀態(tài)機(jī)思想,你可能會(huì)一行行的 if/else 去做解析,這里最麻煩的地方在于,if/else 需要提前將 HTTP 頭部字段都接收到再來判斷,而我們知道 HTTP 基于 TCP,而 TCP 是流式傳輸,所以你很有可能是幾個(gè)字符一組組接收到的,這個(gè)時(shí)候用 if/else 寫出來就很難看了。 而用狀態(tài)機(jī)編寫起來代碼就會(huì)非常優(yōu)雅。狀態(tài)的轉(zhuǎn)移是由規(guī)則驅(qū)動(dòng)的,接收到一個(gè)字符就判斷一個(gè),非常的方便。 繼續(xù)學(xué)完語法分析,你會(huì)掌握遞歸下降分析這樣非常重要的思想,你可以使用遞歸下降快速的實(shí)現(xiàn)四則運(yùn)算計(jì)算器。 如果不用遞歸下降你可能需要先中綴表達(dá)式轉(zhuǎn)后綴,然后求值,這是我們大一數(shù)據(jù)結(jié)構(gòu)課寫的,當(dāng)時(shí)用棧寫的,有點(diǎn)麻煩。后來學(xué)完編譯原理,又用遞歸下降重寫了一遍,區(qū)區(qū)幾十行代碼遍搞定。 還有一類場景在實(shí)際開發(fā)中的用的很多,比如淘寶、京東這樣的電商,它們的營銷規(guī)則有很多,比如滿減、直減、跨店等等,這樣的規(guī)則是不可能寫死在代碼里的。 那是怎么做的呢? 一般會(huì)實(shí)現(xiàn)一個(gè)配置系統(tǒng),并設(shè)計(jì)一個(gè)DSL(領(lǐng)域特定語言)來表達(dá)這些規(guī)則,將規(guī)則直接配置到系統(tǒng)中,這樣可以非常方便的修改,那么如何在代碼里去解析 DSL 定義的規(guī)則呢?這就需要為 DSL 寫一個(gè)語法解析器,這里就會(huì)用到語法分析的方法。 DSL(Domain Specific Language),是一種用于某個(gè)特定領(lǐng)域的程序設(shè)計(jì)語言。這種特定于某個(gè)領(lǐng)域是相對于 C、C++、Python 這種通用語言而言的,通用語言可以在各個(gè)領(lǐng)域使用,我們熟悉的大多數(shù)程序設(shè)計(jì)語言都是通用語言,它們都是圖靈完備的。 像我們平常經(jīng)常使用的 JSON、SQL、HTML 這些都算是一種 DSL,你甚至可以嘗試用遞歸下降去寫一個(gè) JSON、XML 解析器,這比寫電商網(wǎng)站更有價(jià)值的。 繼續(xù)往下學(xué)你會(huì)了解到抽象語法樹 AST 如何生成、如何轉(zhuǎn)化為中間代碼、如何對中間代碼優(yōu)化、最終又是怎么生成機(jī)器指令的。 你會(huì)看到貪心算法在寄存器分配中的應(yīng)用,也會(huì)看到圖論中的可達(dá)性分析又是如何實(shí)現(xiàn)死代碼消除。 IDE上面那個(gè)綠色的編譯按鈕對你不再是黑魔法。 為啥點(diǎn)一下就能生成可執(zhí)行的程序? 你寫的英文字母又是如何變成一個(gè)個(gè)二進(jìn)制指令的? 學(xué)完編譯原理,這些通通不是問題,媽媽再也不用擔(dān)心你的學(xué)習(xí)~ 當(dāng)然完成一個(gè)像 GCC、Clang 這樣的編譯器難度太高太高,我們學(xué)習(xí)編譯原理的目的也不是去造這樣的輪子,而是為了更好的理解和運(yùn)用編程語言。

1.5 體系結(jié)構(gòu)&組成原理

上面說的都是軟件層面,體系結(jié)構(gòu)則是關(guān)于計(jì)算機(jī)是如何工作的,你會(huì)了解到典型的存儲(chǔ)程序計(jì)算機(jī)是怎樣運(yùn)轉(zhuǎn)的。 記得南大有個(gè)老師說過 “我們不是學(xué)習(xí)使用計(jì)算機(jī)的,而是學(xué)習(xí)如何造計(jì)算機(jī)”,雖然造計(jì)算機(jī)有點(diǎn)夸張,但是至少我們得了解下計(jì)算機(jī)的實(shí)現(xiàn)原理,了解下代碼是怎么被 CPU 執(zhí)行的吧?不然其實(shí)你會(huì)很困惑,明明一堆英文字母,怎么在 CPU 這種電路上跑起來的,我大一學(xué) C 語言就百思不得其解,直到后來學(xué)了組成原理和數(shù)字邏輯。 我們說計(jì)算機(jī)中一切都是 0、1,0、1 又是通過高低電平來表達(dá)的,通過與、或、非等邏輯門電路來表達(dá)二進(jìn)制的數(shù)值運(yùn)算,再將這些簡單的電路集成在一起,就形成了 ALU 等具有運(yùn)算能力的處理器。 你會(huì)看到一條指令是如何被CPU執(zhí)行的,CPU 從內(nèi)存或 Cache 中取出指令,放入指令寄存器,并對指令譯碼。譯碼就是按照指令的編碼規(guī)則,將指令拆分成一系列的微操作和操作數(shù)。然后發(fā)出各種設(shè)備控制指令,執(zhí)行微操作。這樣就完成一條指令的執(zhí)行。 我們說學(xué)完編譯原理,能夠明白寫的英文代碼是如何被變成二進(jìn)制指令的,學(xué)完操作系統(tǒng)能搞懂二進(jìn)制程序是如何被鏈接在一起,又是如何被操作系統(tǒng)加載、執(zhí)行的。而組成原理則會(huì)告訴你二進(jìn)制指令是如何控制 CPU 跑起來的,我們的操作系統(tǒng)本質(zhì)上也是一個(gè)二進(jìn)制的程序。 當(dāng)你理解了計(jì)算機(jī)存儲(chǔ)層次結(jié)構(gòu),理解了多級 Cache,你就會(huì)通過優(yōu)化數(shù)據(jù)訪問方式來編寫出速度更快的程序。 你會(huì)學(xué)到底層體系結(jié)構(gòu)對 C 這些語言的棧幀和參數(shù)傳遞的支持,參數(shù)是如何被傳遞給另外一個(gè)函數(shù)的?函數(shù)的返回值又是如何拿到。 這是學(xué)習(xí)組成原理對于寫代碼的意義。 學(xué)這些到底有什么意義? 你會(huì)完整的看到寫的代碼如何變成二進(jìn)制指令,又是如何去控制各種門電路,最后變成屏幕上花花綠綠的程序的(當(dāng)然這里可能還需要學(xué)習(xí)顯示器的原理),這就是我們常說的“基礎(chǔ)”和“原理”。 并且計(jì)算機(jī)體系結(jié)構(gòu)中的很多思想,是能夠廣泛運(yùn)用于現(xiàn)代軟件開發(fā)的,比如 CPU 的多級 Cache 思想,就是我們現(xiàn)在服務(wù)器開發(fā)中提高并發(fā)度常用的緩存技術(shù),包括緩存的替換策略等等。 當(dāng)計(jì)算機(jī)對你不再是黑盒,你了解寫下的代碼到執(zhí)行的每一步,而這也將成為你以后的核心競爭力,作為科班畢業(yè)生不應(yīng)該只會(huì)使用 Java、Redis、Mysql、Spring 來寫各種網(wǎng)站。 如果讀者里有半路轉(zhuǎn)行或者從培訓(xùn)班出來的,也希望你們能夠抽出空余時(shí)間去補(bǔ)補(bǔ)這些基礎(chǔ)課,這會(huì)讓你在編程這條路上走的更遠(yuǎn)和更穩(wěn)。

1.6 數(shù)據(jù)結(jié)構(gòu)與算法

為什么把算法放到最后來講,是不重要嗎?相反,它太重要了,所以才讓它來壓軸。 如果要問我大學(xué)什么最后悔?那肯定是沒有從大一就開始好好學(xué)算法,去打 ACM。 現(xiàn)在還在大一、大二的同學(xué)還不抓緊機(jī)會(huì),別等到以后來后悔。當(dāng)然,不打 ACM,我們也是能夠?qū)W好數(shù)據(jù)結(jié)構(gòu)和算法的。 數(shù)據(jù)結(jié)構(gòu)和算法你能在任何計(jì)算機(jī)領(lǐng)域里看到,比如在編譯原理中寄存器的分配會(huì)用到貪心,死代碼檢測與消除會(huì)用到圖論里不可達(dá)的知識;操作系統(tǒng)進(jìn)程、線程調(diào)度會(huì)用到多級隊(duì)列和調(diào)度算法;組成原理中 Cache 的替換會(huì)用到 LRU、FIFO 等算法;開發(fā)必備的數(shù)據(jù)庫也離不開 B+ 樹、LSM 等數(shù)據(jù)結(jié)構(gòu)和查找算法。 很多時(shí)候我們需要的算法都被封裝到編程語言的基礎(chǔ)庫里了,以至于很多同學(xué)會(huì)覺得算法離我們太遠(yuǎn),其實(shí)不是的。 如果不學(xué)習(xí)算法,連什么時(shí)候用 Map(紅黑樹實(shí)現(xiàn))、什么時(shí)候用 HashMap 都分不清。 所以學(xué)習(xí)算法有助于我們根據(jù)應(yīng)用場景選擇最合適的數(shù)據(jù)結(jié)構(gòu)。 日常開發(fā)中也一定離不開算法,比如小北最近工作中涉及的某種嵌套 TLV(Tag-Length-Value)結(jié)構(gòu)編碼的解析,就需要用到遞歸、多叉樹等知識。如果不學(xué)習(xí)算法,那么程序中只能見到大量的 if/else、while/for。。??梢哉f不會(huì)算法的工程師一定不是一個(gè)優(yōu)秀的工程師。

1.7 為什么我不說計(jì)網(wǎng)、數(shù)據(jù)庫等

很多人喜歡把計(jì)算機(jī)網(wǎng)絡(luò)、數(shù)據(jù)庫原理這些也歸為計(jì)算機(jī)基礎(chǔ)來,我當(dāng)然也認(rèn)同,因?yàn)橐粋€(gè)知識結(jié)構(gòu)完整的計(jì)算機(jī)科班學(xué)生,應(yīng)該了解這些知識。 但是我個(gè)人是覺得計(jì)算機(jī)網(wǎng)絡(luò)、數(shù)據(jù)庫無非就是建立在操作系統(tǒng)、編譯原理、組成原理之上的應(yīng)用層軟件。 什么是數(shù)據(jù)庫?沒有數(shù)據(jù)庫之前你會(huì)用文件去存儲(chǔ)數(shù)據(jù),但是不方便查找、修改等,數(shù)據(jù)庫只是提高了這個(gè)過程的效率。 網(wǎng)絡(luò)干什么的?網(wǎng)絡(luò)就是讓不在同一臺(tái)電腦上的程序互相通信,本質(zhì)上就是進(jìn)程間通信的手段。 如果你只是開發(fā)單機(jī)工業(yè)軟件,甚至真的可以不學(xué)網(wǎng)絡(luò),只是由于現(xiàn)在大多數(shù)程序員都是在互聯(lián)網(wǎng)公司工作,所以不管前后端,都離不開和HTTP等網(wǎng)絡(luò)協(xié)議打交道。再次重申:不是計(jì)網(wǎng)、數(shù)據(jù)庫不重要,只是我認(rèn)為它們屬于構(gòu)建在操作系統(tǒng)之上的軟件,不劃在基礎(chǔ)之列。

二、領(lǐng)域知識

這個(gè)我不敢說太多,因?yàn)楦鱾€(gè)領(lǐng)域我也不太懂。只簡單提一點(diǎn),拋磚引玉罷了。 如果你想去騰訊、網(wǎng)易做游戲引擎開發(fā),那么圖形學(xué)一定是你繞不開的知識,此外你還得學(xué)習(xí)渲染管線、著色器、物理、光照等等。 如果你想去 PingCap 這樣的公司做分布式存儲(chǔ),那么分布式理論知識一定是你繞不開的關(guān)口,包括 CAP 定理、Paxos 算法、Raft 算法、ZAB 協(xié)議等等。 如果你想寫一個(gè)數(shù)據(jù)庫,那么你需要去了解磁盤、索引實(shí)現(xiàn)、SQL 解析(編譯原理)、事務(wù)、如何用 MVCC 解決讀寫沖突等等一大堆的東西,還得了解一大堆編程語言層面的東西,比如鎖、信號量、并發(fā)編程技巧,不得不說造數(shù)據(jù)庫是一個(gè)臟活也是一個(gè)累活。 更進(jìn)一步你想去做分布式數(shù)據(jù)庫,那可能還得去學(xué)習(xí)數(shù)據(jù)分片的知識,查詢?nèi)蝿?wù)如何做,是集中做,還是將邏輯下推給各個(gè)節(jié)點(diǎn),如何實(shí)現(xiàn)分布式事務(wù)等等。 你說你只想去大廠 CRUD?沒毛病,老鐵! 那你得熟悉一門編譯型語言(C/C++、Java、Go),理解語言部分底層原理,比如 C++ 你得看看 STL、看看對象模型吧,你不懂什么虛函數(shù)表、智能指針還想去騰訊寫 C++? Java 的你得背背 JVM,什么垃圾回收算法吧,你不看看ConcurrentHashMap 好意思說你是做Java的? 咱CRUD的對象是數(shù)據(jù)庫吧?那不得學(xué)學(xué)怎么才能把數(shù)據(jù)庫用好。用戶通過 HTTP 訪問我們得服務(wù),總得了解 HTTP吧?順帶著不看下 TCP 三次握手、四次揮手你好意思說是學(xué)計(jì)算機(jī)的? 用戶把錢、信息放咱們這,總得保證用戶數(shù)據(jù)安全吧?那 XSS、SQL 注入、CSRF 這些常見的 Web 攻擊手段你總得了解吧?HTTPS、RSA、簽名、數(shù)字證書這些安全手段總得知道吧。 雙十一流量太大,老板還讓你必須頂住,那你總得了解下緩存、異步、消息隊(duì)列、NoSQL 這些千萬 QPS 必備的大殺器吧? 看看!要想做好CRUD也不是那么容易滴。(上面這段只是換一種方式把做后端的同學(xué)要學(xué)的知識寫出來,不是吐槽更不是調(diào)侃,純屬娛樂。

技能

這就很多了,包括 VSCode、Jetbrains 全家桶這些 IDE,文檔編寫 Markdown、Git 等版本管理工具。SSH 遠(yuǎn)程登錄、端口轉(zhuǎn)發(fā),Ngrok 內(nèi)網(wǎng)穿透等等這些提高你開發(fā)效率的工具,都算是技能,這個(gè)沒啥好說的,平時(shí)用到多學(xué)習(xí)多積累就好了。 我只提一點(diǎn),盡早使用 Linux、類 Unix(Mac)作為主力開發(fā)電腦。我大二的時(shí)候,就是看了王 ying 的那篇《完全用 Linux 工作》,直接買了個(gè) SSD 套上 U 盤外殼,做了一個(gè)啟動(dòng)盤,后來用了將近一年的 Ubuntu,只有在選課、提交作業(yè)等需要用的 IE 瀏覽器的時(shí)候才會(huì)打開 Windows(這里不得不吐槽學(xué)校老古董網(wǎng)站?。?當(dāng)然了,我也不是狂熱的 Linux 愛好者,只是單純覺得做開發(fā)的話,離不開各種環(huán)境安裝、命令行的使用,這點(diǎn)上面類 Unix 系統(tǒng)帶有天然的優(yōu)勢,誰用誰知道!

總結(jié)

寫完才發(fā)現(xiàn),這篇文章連篇幅都是「基礎(chǔ) : 領(lǐng)域知識 : 技能」 接近 7 : 2 : 1。 這也是我推薦你在大學(xué)期間分配學(xué)習(xí)時(shí)間的比例,至少學(xué)習(xí)基礎(chǔ)知識的時(shí)間不少于 50%,當(dāng)然,這些東西你都學(xué)完了那可以去找找感興趣的方向?qū)Q幸幌隆?千萬不要大一、大二一上來就扎進(jìn) Java Web、Python 爬蟲這種東西,這些可以學(xué),但不是重點(diǎn)。 這篇文章由于篇幅限制,沒有寫到具體該如何去學(xué),有哪些好的資料,我準(zhǔn)備把這個(gè)單獨(dú)再寫一個(gè) 《How 篇》,持續(xù)關(guān)注我喲~ 那么如何檢驗(yàn)學(xué)得如何呢? 想必你一定聽說這個(gè)計(jì)網(wǎng)面試題:“從 URL 輸入到頁面展現(xiàn)到底發(fā)生什么?“ 這個(gè)問題換個(gè)表達(dá)就是「一個(gè)數(shù)據(jù)包是如何發(fā)送到另外一臺(tái)電腦的」。 如果你能完整的說出整個(gè)過程,那么計(jì)網(wǎng)你一定是學(xué)懂了!這就是為啥面試這么喜歡問這個(gè)問題的原因。 那么我們依葫蘆畫瓢提一個(gè)問題 “從代碼被寫下到程序運(yùn)行起來到底發(fā)生了什么?” 這個(gè)問題回答得越詳細(xì)越好,基本上能說清楚了,你就理解了編譯原理、操作系統(tǒng)、組成原理這三座大三。 這個(gè)問題也放在這,后續(xù)發(fā)文總結(jié),請持續(xù)關(guān)注編程指北哦。 唉,當(dāng)年要是有這么個(gè)貼心學(xué)長告訴我這些,也不至于在 Andorid 開發(fā)、Java Web、Python 爬蟲這些玩大半年啊。。。 不過還好后來自己意識到了基礎(chǔ)的重要性,開始學(xué)匯編、重學(xué) C、搞 mini os、看 Linux 內(nèi)核實(shí)現(xiàn)原理,最后成功的把頭發(fā)掉了一把。。。 責(zé)任編輯:lq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 操作系統(tǒng)
    +關(guān)注

    關(guān)注

    37

    文章

    6898

    瀏覽量

    123784
  • C語言
    +關(guān)注

    關(guān)注

    180

    文章

    7614

    瀏覽量

    137782
  • 數(shù)據(jù)結(jié)構(gòu)

    關(guān)注

    3

    文章

    573

    瀏覽量

    40235

原文標(biāo)題:怎樣才算一個(gè)計(jì)算機(jī)知識體系完整的畢業(yè)生-- What篇

文章出處:【微信號:TheAlgorithm,微信公眾號:算法與數(shù)據(jù)結(jié)構(gòu)】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    量子計(jì)算機(jī)與普通計(jì)算機(jī)工作原理的區(qū)別

    ? 本文介紹了量子計(jì)算機(jī)與普通計(jì)算機(jī)工作原理的區(qū)別。 量子計(jì)算是一個(gè)新興的研究領(lǐng)域,科學(xué)家們利用量子力學(xué),制造出具有革命性能力的計(jì)算機(jī)。雖然
    的頭像 發(fā)表于 11-24 11:00 ?532次閱讀
    量子<b class='flag-5'>計(jì)算機(jī)</b>與普通<b class='flag-5'>計(jì)算機(jī)</b>工作原理的區(qū)別

    工業(yè)計(jì)算機(jī)類型介紹

    工業(yè)領(lǐng)域沒有計(jì)算機(jī)的世界就像沒有管弦樂隊(duì)的交響樂,缺乏實(shí)現(xiàn)最佳性能所需的和諧和精確度。計(jì)算機(jī)徹底改變了工業(yè)的運(yùn)作方式,將效率、準(zhǔn)確性和創(chuàng)新推向了新的高度。事實(shí)上,根據(jù)最近在印度進(jìn)行的一項(xiàng)研究
    的頭像 發(fā)表于 11-04 15:56 ?291次閱讀
    工業(yè)<b class='flag-5'>計(jì)算機(jī)</b>類型介紹

    ROM對計(jì)算機(jī)性能的影響

    是一種非易失性存儲(chǔ)器,即使在斷電的情況下也能保持?jǐn)?shù)據(jù)不丟失。它通常用于存儲(chǔ)固件,這些固件是計(jì)算機(jī)啟動(dòng)和運(yùn)行操作系統(tǒng)所必需的。ROM的內(nèi)容在制造過程中被寫入,并且通常不能被用戶更改。 ROM的類型 PROM(可編程ROM) :用戶可以通過特殊的
    的頭像 發(fā)表于 11-04 10:31 ?518次閱讀

    計(jì)算機(jī)視覺與人工智能的關(guān)系是什么

    引言 計(jì)算機(jī)視覺是一門研究如何使計(jì)算機(jī)能夠理解和解釋視覺信息的學(xué)科。它涉及到圖像處理、模式識別、機(jī)器學(xué)習(xí)等多個(gè)領(lǐng)域知識。人工智能則是研究如何使計(jì)算
    的頭像 發(fā)表于 07-09 09:25 ?773次閱讀

    計(jì)算機(jī)視覺在人工智能領(lǐng)域有哪些主要應(yīng)用?

    計(jì)算機(jī)視覺是人工智能領(lǐng)域的一個(gè)重要分支,它主要研究如何讓計(jì)算機(jī)能夠像人類一樣理解和處理圖像和視頻數(shù)據(jù)。計(jì)算機(jī)視覺技術(shù)在許多領(lǐng)域都有廣泛的應(yīng)用
    的頭像 發(fā)表于 07-09 09:14 ?1660次閱讀

    深度學(xué)習(xí)在計(jì)算機(jī)視覺領(lǐng)域的應(yīng)用

    隨著人工智能技術(shù)的飛速發(fā)展,深度學(xué)習(xí)作為其中的核心技術(shù)之一,已經(jīng)在計(jì)算機(jī)視覺領(lǐng)域取得了顯著的成果。計(jì)算機(jī)視覺,作為計(jì)算機(jī)科學(xué)的一個(gè)重要分支,旨在讓計(jì)
    的頭像 發(fā)表于 07-01 11:38 ?996次閱讀

    工業(yè)控制計(jì)算機(jī)的特點(diǎn) 工業(yè)控制計(jì)算機(jī)的應(yīng)用領(lǐng)域

    工業(yè)控制計(jì)算機(jī)是一種專門為工業(yè)自動(dòng)化和控制系統(tǒng)設(shè)計(jì)的計(jì)算機(jī)。它具有高度的可靠性、穩(wěn)定性和實(shí)時(shí)性,能夠滿足工業(yè)生產(chǎn)過程中對控制精度和響應(yīng)速度的嚴(yán)格要求。 工業(yè)控制計(jì)算機(jī)的特點(diǎn) 高可靠性 :工業(yè)控制
    的頭像 發(fā)表于 06-16 11:30 ?1587次閱讀

    工業(yè)控制計(jì)算機(jī)與普通個(gè)人計(jì)算機(jī)相比有何區(qū)別?

    引言 隨著科技的不斷發(fā)展,計(jì)算機(jī)在各個(gè)領(lǐng)域的應(yīng)用越來越廣泛。在眾多計(jì)算機(jī)類型中,工業(yè)控制計(jì)算機(jī)和普通個(gè)人計(jì)算機(jī)是兩種常見的
    的頭像 發(fā)表于 06-11 10:45 ?1088次閱讀

    計(jì)算機(jī)視覺的主要研究方向

    計(jì)算機(jī)視覺(Computer Vision, CV)作為人工智能領(lǐng)域的一個(gè)重要分支,致力于使計(jì)算機(jī)能夠像人眼一樣理解和解釋圖像和視頻中的信息。隨著深度學(xué)習(xí)、大數(shù)據(jù)等技術(shù)的快速發(fā)展,計(jì)算機(jī)
    的頭像 發(fā)表于 06-06 17:17 ?1139次閱讀

    工業(yè)計(jì)算機(jī)與普通計(jì)算機(jī)的區(qū)別

    在信息化和自動(dòng)化日益發(fā)展的今天,計(jì)算機(jī)已經(jīng)成為了我們?nèi)粘I詈凸ぷ髦胁豢苫蛉钡墓ぞ摺H欢?,?b class='flag-5'>計(jì)算機(jī)領(lǐng)域中,工業(yè)計(jì)算機(jī)和普通計(jì)算機(jī)雖然都具備基
    的頭像 發(fā)表于 06-06 16:45 ?1629次閱讀

    【量子計(jì)算機(jī)重構(gòu)未來 | 閱讀體驗(yàn)】 跟我一起漫步量子計(jì)算

    首先感謝發(fā)燒友提供的試讀機(jī)會(huì)。 略讀一周,感觸頗深。首先量子計(jì)算機(jī)作為一種前沿技術(shù),正逐步展現(xiàn)出其巨大的潛力,預(yù)示著未來社會(huì)和技術(shù)領(lǐng)域的深刻變革。下面,我將從幾個(gè)方面探討量子計(jì)算機(jī)如何重構(gòu)我們
    發(fā)表于 03-13 19:28

    【量子計(jì)算機(jī)重構(gòu)未來 | 閱讀體驗(yàn)】+ 了解量子疊加原理

    作為零基礎(chǔ)初學(xué)級的量子小白,對神秘詭異的量子世界充滿了好奇。說起量子計(jì)算機(jī),我有許多問號,量子計(jì)算機(jī)的工作原理是什么?它和電子計(jì)算機(jī)有什么區(qū)別?量子計(jì)算機(jī)如何
    發(fā)表于 03-13 17:19

    【量子計(jì)算機(jī)重構(gòu)未來 | 閱讀體驗(yàn)】第二章關(guān)鍵知識點(diǎn)

    計(jì)算機(jī)能夠減少計(jì)算和操作的繁瑣程度 作者從如何提高計(jì)算機(jī)的運(yùn)算速度上,提出了提高計(jì)算速度的兩個(gè)方向: 加快計(jì)算機(jī)的運(yùn)行速度,通俗易懂的說法
    發(fā)表于 03-06 23:17

    【量子計(jì)算機(jī)重構(gòu)未來 | 閱讀體驗(yàn)】+ 初識量子計(jì)算機(jī)

    分介紹了量子計(jì)算機(jī)的工作原理、計(jì)算能力、研發(fā)現(xiàn)狀等專業(yè)知識點(diǎn);第二部分介紹了量子計(jì)算機(jī)的應(yīng)用場景,比如工廠、物流、智慧交通、自動(dòng)駕駛等等;正好適合我這樣的量子小白閱讀。 開始第一部分
    發(fā)表于 03-05 17:37

    計(jì)算機(jī)視覺的十大算法

    隨著科技的不斷發(fā)展,計(jì)算機(jī)視覺領(lǐng)域也取得了長足的進(jìn)步。本文將介紹計(jì)算機(jī)視覺領(lǐng)域的十大算法,包括它們的基本原理、應(yīng)用場景和優(yōu)缺點(diǎn)。這些算法在圖像處理、目標(biāo)檢測、人臉識別等
    的頭像 發(fā)表于 02-19 13:26 ?1377次閱讀
    <b class='flag-5'>計(jì)算機(jī)</b>視覺的十大算法