Re: [問題] 關於C++學習過程請教

作者: tinlans ( )   2022-04-14 06:04:41
※ 引述《Suxing133 (怪盜巴哥)》之銘言:
: 各位前輩們早上好,
: 小弟目前大二,再一年就準備做專題考研。
: 目前正在自學C++,
: 原本是跟學校的課程學習JAVA,
: 雖然是資管但對C/C++的指標有莫名的憧憬,
: 所以才在這個時間點改學習另一個語言,
: 缺點是班上沒有同學一起學習C++,
: 因此想上來板上請教各位前輩們一些問題。
對指標的憧憬導致在資管大二階段跳過來學 C++ 這個動機有點怪,
如果這板不是 C_AND_CPP,有很大機率我會建議你別學下去。
我倒是比較好奇這個憧憬對你後來學習 C++ 和使用 C++ 造成什麼樣的影響。
寫程式很忌諱的一點是炫技,C 要炫技大部分是靠指標,C++ 還有很多語言機制可炫技。
你的生涯規劃我也同樣好奇,未來會想從事用 C++ 開發程式的工作嗎?
資管需要學習的東西很廣,但 C++ 這東西某方面來說需要學精,
你如果未來不想從事會用到 C++ 的相關工作,你還有好多好多東西得去學。
浪費時間在 C++ 這語言的學習上,你可能會喪失職場競爭力,這很嚴重。
不過既然你還打算讀研究所,也許碩班論文和教授給你做的計畫還能給你指引方向,
所以這邊先不強迫你去思考未來想去什麼公司、做什麼樣的工作內容。
只是我眼光比較短淺,好像想不太到哪個資管所教授接的計畫會需要學生使用 C++。
因此 C++ 可能只會變成你花了最精華的大學時期的一個短暫興趣,
而與你同世代的資管人可能利用這四年時間累積了更龐大的有用知識在職場上發光發熱。
你在研究所開始之後的人生不會再有時間讓你這麼悠閒的讀 C++ Primer,
也許將來的某一天你會後悔為何不花一樣的時間去學 10 幾種近代資訊技術。
另外就是畢業專題我記得都是要團隊合作。
班上都沒人跟你一起學 C++ 了,到時專題你打算一個人一組用 C++ 寫嗎?
不過話又說回來,很多其它語言的 plugin 或 extension 其實都是用 C/C++ 在寫。
或許未來有一天你現在的經驗能成為你的助力,讓你能做到別人不能做到的效能改善。
如果幾年後你最終選擇了其它用不到 C++ 的語言當謀生工具,要記得你還有這個優勢。
: 學習過程:
: 目前是讀C++ Primer 5/e 讀到一半左右,
: 預計再半個月能接近讀完,
: 之後打算繼續讀Effective 系列&STL函式庫,
: 中間還有刷一些Leetcode Easy的題目,
: 未來打算寫一些小專題累積開發能力。
: 問題:
: 不知道這樣學習方式有沒有需要改進的地方?
: 不知道有沒有榮幸獲得各位前輩的經驗,
: 目前刷Leetcode算是心態滿崩的,
: 因為網路上大多都在使用STL,
: 還有code都是寫class,
: 這樣好像沒有練習到main呼叫的過程,
: 甚至在考慮要不要改刷CPE的題庫。
: 感謝抽空看我廢話,打擾到不好意思!
: (第一次在ptt發文,排版不好還請見諒!
: (有違反版規的話非常抱歉!
刷題這件事對你來說太早,板友已經都講過了我就不講了。
比起 The C++ Programming Language,
C++ Primer 的內容編排更接近 C++ 語言辭典這類工具書。
如果你打算把寫 C++ 當作你未來正職使用的語言,
讀過它一遍你將不會被編譯錯誤或一些非預期的編譯結果感到意外,
至少遇到的當下你腦中會閃過書上的某些片段然後回來查。
如果現在是 2011 年,而且你的目的是想更透徹瞭解這個語言,
我會建議你在讀完 C++ Primer 之後去讀 The C++ Programming Language。
之後再建議你去讀 Effective 和 Exception 系列的書做補強。
但是從 2012 年開始,Effective 和 Exception 系列已經過時,
雖然裡面的精神可以花點時間去瞭解,但裡面許多過時的內容我也擔心新手誤會。
Effective C++ 3/e 算是 2012 後這系列裡唯一值得去讀的書,但也沒更多了。
類似的進階學習資源都變成在網路上,紙本或電子書已經不太有人出版。
另外關於並行程式設計的主題,是被獨立在一本叫 C++ Concurrency in Action 的書上。
這本書需要特別另外去讀,因為裡面涵蓋的主題既有的書籍裡不太會介紹。
歐萊禮還有一本「優化 C++」在你遇到效能瓶頸時可以去讀,但現在不用急著去看。
你讀的 C++ Primer 5/e 在 2022 年的現在也是一本過時的書,
但我無法給你更好的建議,因為我不是從這個年代才開始學 C++ 的。
如果你想找一本跟得上時代的 C++ 書籍,無論簡體還是繁體中文我還真不知道有沒有。
因為我已經是體力衰退的中年人,沒力氣幫你找,只能說關鍵字是 C++17 和 C++20。
我自己這幾年是在 manning.com、leanpub.com、packtpub.com 上面買電子書來讀,
再來就是去一些板友也常提到的網站逛逛,不斷追著最新標準走。
如果你的英文能力不足以讀這些原文電子書,我會建議你設法把英文補好。
走軟體開發除非你是走少數特殊行業,不然靠吃台灣內需肯定得不到什麼好的發展。
特別是你的英聽跟口說如果不行的話,強烈建議先去補習加強或利用學校資源。
這些基礎語言技能沒有的話,我還是建議你先別學什麼 C++,
不然以國內匱乏的中文資源,再過個 10 年,你跟完全不會 C++ 的人很高機率是一樣的。
除了唸書,Boost C++ Libraries 也該練習去使用,
我學生時代給自己設定一週要學會裡面一個函式庫的目標,
學會使用它可以幫上你不少忙,但終究它也是輪子和積木等級的函式庫。
Qt 之類的 GUI framework 你至少要學會一套,這樣你的軟體開發工具才會完整。
至於你說的「未來打算寫一些小專題累積開發能力」,這又是完全不同的議題。
你在我上述的電子書商網站搜尋 C++ 可以找到一狗票 C++17 和 C++20 的書,
所以我也不去羅列我看過買過什麼只講 C++ 的書,畢竟意義有限。
所謂的開發能力,是跨越程式語言的一項知識,也是你需要花大量時間鑽研的東西。
以歐萊禮的「深入淺出物件導向分析與設計」和「深入淺出設計模式」為出發點,
你會開始見識到超脫語言之外的軟體分析與設計知識,這比起使用什麼語言還要重要。
在這領域也有個名作家 Martin Fowler 出的書也值得一讀,特別是重構相關的書籍。
這裡我可以列一下我讀過的書,因為關鍵字比較難下,
你可以去書商網站從他們的目錄裡瞭解這些書在講什麼東西:
1. Hands-On Design Patterns with C++
2. Software Architecture with C++
3. Clean C++20 - Sustainable Software Development Patterns and Best Practices
4. Architectural Patterns (書名太短給你 ISBN 978-1-78728-749-5 防止你找錯)
5. Software Architect's Handbook
6. Good Code, Bad Code
7. Five Lines of Code
8. Software Mistakes and Tradeoffs
9. Street Coder
有些書還沒出完,上面那些電子書的網站都可以在作者出完書之前買到書,
買了之後先讀到可以把作者目前已經寫好的章節,甚至可以給作者意見或和作者討論。
要注意這些書裡用的範例程式碼未必是 C++,但你要吸收的主要是它的精神。
這對你未來轉換跑道去用其它語言一樣有用,也是你到達學生時代終點前所該學習的。
manning.com 出的書品質比較高,我在這還是會建議你去翻翻這網站上的書籍標題。
我會希望你至少先從標題確認,看看你有沒有能力知道這些書分別是在講什麼的。
雖不求 100% 知道那些是什麼東西,但起碼要知道個七、八成。
我指的是就算只是懂得標題上的名詞是啥也好,就這程度上你至少得略懂七、八成標題。
坦白說以資管人而言,你大概知道它們是什麼,然後都摸過一點,會比你學 C++ 有用。
我也不喜歡在 C_AND_CPP 板上一直勸人學 C++ 以外的東西,
但既然你表明了你是資管人,我這個看過很多資管人人生的資工人還是得勸說一下。
另外 manning.com 這網站近年開始搞起了 live project,
你如果找到感興趣的主題也可以去試試。
不過如果你沒有足夠的英文能力,這些機會也就與你無緣。
作者: tylpk (tylpk)   2022-04-14 10:56:00
推mannimg,沒有DRM,方便放不同的閱讀器。b天瓏買的紙本也可下載電子書,但不確定是不是每本都可以。
作者: Suxing133 (怪盜巴哥)   2022-04-14 12:35:00
tinlans大大您好!這篇文章我看了一個早上,真的打破我的價值觀以及我對學習方式的見解,有些地方想要請教您~就不另外發文回覆了!我怕內容會離題違反版規,請問有空嗎?我應該直接在下推文問還是站內信呢?沒有空也沒關係!真的已經幫我很大的忙了!!再次感謝您抽空回答小弟。
作者: steak5566 (牛排56)   2022-04-14 21:42:00
Primer要讀完就很硬了 我覺得當工具書看
作者: Etern (Eternalding)   2022-04-15 08:48:00
用心推
作者: NTAP (低調糗哥)   2022-04-15 09:28:00
好用心,推
作者: F04E (Fujitsu)   2022-04-15 12:03:00
作者: sa074463 (壘包)   2022-04-15 13:03:00
推 感謝大神
作者: ShenJing (ShenJing)   2022-04-16 10:12:00
推用心回覆
作者: final01 (牛頓運動定律)   2022-04-17 14:38:00
Effective Modern C++沒列?我覺得這本的確沒effective的威力~可是我覺得還是新手必讀之一?XD
作者: Lalef (Lalef)   2022-04-19 12:03:00
借問,如果要刷leetcode刷題還是得靠C++對吧?
作者: KanzakiHAria (神崎・H・アリア)   2022-04-19 15:03:00
刷演算法當然是python阿不限語言的程式比賽前100名九成是py
作者: unmolk (UJ)   2022-04-20 06:24:00
用心推
作者: oToToT (屁孩)   2022-04-20 14:15:00
上面要不要看看codejam之類的比賽前幾名都用什麼語言
作者: b0920075 (Void)   2022-04-21 15:46:00
第一次聽到程式競賽九成用 python ...,這個數據哪來的
作者: KanzakiHAria (神崎・H・アリア)   2022-04-21 17:31:00
https://adventofcode.com/ 去看leaderboardC++還沒有刻完data structure人家py答案都出來了你講codajam是有統計從題目出現到pass的時間?不過就只有執行時間而已 編譯語言本來就跑比較快我是不意外啦 C++版的人都寫C++比py快 (跟自己比然後以為外面世界也是寫C++比py快www一堆題目C++要寫上百行 py只要幾十行的不要以為我是用py才反對c++ 我平常工作是寫c++17寫poc的時候還是用py最快 要榨效能再上c++不懂的人可以先去看甚麼是手稿語言就會知道差別
作者: EricTCartman (阿ㄆㄧㄚˇ)   2022-04-22 18:30:00
一堆題目要寫上百行?哪些還是你自己百行內能寫完的程式寫到上百行 幻想全世界寫C++的都跟你一樣ww
作者: b0920075 (Void)   2022-04-22 19:05:00
競賽選手愛用訓練網站的 cf div1 前五十名都用 c++ ,目前是沒聽過哪個選手會拿 advent of code 當作備賽訓練,這看起來像社群辦的小圈圈活動,如果是拿 atcoder/cf/codechef還是各大知名 oj 或是 ioi/acm icpc/topcoder/google code jam 之類的大賽各有說服力,這些選手應該都比你我更了解用什麼語言對自己的競賽成績更有利
作者: EricTCartman (阿ㄆㄧㄚˇ)   2022-04-22 19:24:00
快貼一段你用py寫幾十行 結果C++寫到上百行的來看看讓我開一下眼界
作者: KanzakiHAria (神崎・H・アリア)   2022-04-22 20:03:00
所以時間拿出來阿 從題目出現到答案輸出的時間編譯語言本來就比手稿語言快誰不知道加上寫code時間誰比較快時間是另一回事@EricTCartman 所以閣下意思是手稿語言行數比較多每個人要有自己判斷力 如果手稿語言行數比C++多那整個手稿語言世界可扔去垃圾桶了 速度慢還行數多
作者: b0920075 (Void)   2022-04-22 20:17:00
時間在 codeforces 比賽結果那邊就有了啊,執行時間也是比賽的一環,你執行時間慢連通過的資格都沒有XD再說前五十名哪個不是寫的快執行時間又短的
作者: EricTCartman (阿ㄆㄧㄚˇ)   2022-04-22 20:18:00
哇 你這稻草人立得真是讓我拍案叫絕我從頭到尾哪句寫手稿語言行數比C++多 麻煩您框一下
作者: b0920075 (Void)   2022-04-22 20:19:00
作者: EricTCartman (阿ㄆㄧㄚˇ)   2022-04-22 20:20:00
我只是好奇Python寫幾十行 C++可以到上百行的題目長怎樣
作者: b0920075 (Void)   2022-04-22 20:23:00
比賽應該是直接上模板,該弄得都弄好,一鍵輸出,剩下時間用來思考和實作演算法吧
作者: EricTCartman (阿ㄆㄧㄚˇ)   2022-04-22 20:24:00
啊對了 我平常工作也會寫Py跟C++ 我從來沒打算證明C++比Py更好用更簡潔 我只是納悶 你用"上百行"跟"一
作者: KanzakiHAria (神崎・H・アリア)   2022-04-22 20:24:00
00:02 你要說這個時間是從看到題目打好code到上傳?
作者: EricTCartman (阿ㄆㄧㄚˇ)   2022-04-22 20:25:00
堆題目" 遠遠超越我的認知
作者: KanzakiHAria (神崎・H・アリア)   2022-04-22 20:25:00
所你的意思是這題從看到+打code+compile+run 兩秒?
作者: b0920075 (Void)   2022-04-22 20:25:00
...你可以點進去看各個選手每一題的比賽開始到提交的時間
作者: KanzakiHAria (神崎・H・アリア)   2022-04-22 20:28:00
你說要點進去 所以我剛剛就是說 有沒有rank是總時間而非這種是以執行時間做為排序的這個外面的rank是用執行時間當然編譯語言時間短阿而且這個比賽本身就是執行時間作為標準 當然積分上C++有利如果說原PO就是要參加這種以執行時間為積分的當然C++沒話說 沒有語言可以做到比C++更細緻的調校但我不認為原PO目的極致執行時間競賽 而且前面都已
作者: b0920075 (Void)   2022-04-22 20:34:00
你去看 codeforces 比賽規則,他是以題目出來之後到提交的時間和錯誤次數和題目本身的分數算成績,執行時間通過是最低要求,但是你跑得快跟你最後分數無關==
作者: KanzakiHAria (神崎・H・アリア)   2022-04-22 20:34:00
經說了刷leetcode很崩潰 誰不知道C++初學上手難度?我承認我錯了 打比賽最適合的語言是C++ 原PO請學C++打比賽 加油
作者: EricTCartman (阿ㄆㄧㄚˇ)   2022-04-22 20:56:00
阿Py幾十行上百行的C++題目咧 貼來看看阿
作者: oToToT (屁孩)   2022-04-22 21:43:00
自己沒打過大家普遍認同的比賽就不要出來誤人子弟好嗎順便幫你補充一下00:02是兩分鐘的意思,代表看到題目寫出答案再到上傳花兩分鐘再補充一下像是前面提到AoC的部分,排行榜靠前的選手在像是codeforces的比賽中也幾乎都是用C++寫的,所以還是要看你所說的比賽到底是哪種類型的,如果是完完全全只拚手速的話的確python有機會寫起來比較快,但如果是competitiveprogramming的話大多還是以C++為主
作者: Ommm5566 (56天團)   2022-04-23 00:32:00
AOC++還有用raku的全都學就沒問題
作者: Hurricaneger (褲襪脫落大尉)   2022-04-23 14:00:00
看本爸爸的,再一本函式庫,再一本更新快的外國paper
作者: yoco (眠月)   2022-04-24 01:30:00
真的,沒事不要學 C++
作者: firejox (Tangent)   2022-04-24 02:36:00
python 的 sort 跟 priority queue 比 c++ 難用不適合比賽吧
作者: wulouise (在線上!=在電腦前)   2022-04-29 23:31:00
說真的你要學 先從python開始,如果有緣C++會找到你順便推一下yoco
作者: cphe (魔鬼藏在垃圾筒裡)   2022-04-30 13:07:00
在推文吵架真的是侮辱了這篇優文
作者: DerLuna (陽月)   2022-05-06 20:58:00
如果是寫金融即時交易的 C++還是主流那種收入也是最頂的....簡單的說C++如果學通 是真的很神 也真的可以很賺而且基本上C你也會懂 韌體等等也沒問題但如果要泛用的話 C#算是最折衷吧
作者: VF84 (Jolly Roger)   2022-05-06 23:05:00
連這個都能吵,真閒欸講點不相干的,在念書時期不太需要讓自己被語言侷限住,學你你喜歡的就好。我高中是用 C++ 寫 C,備考研究所的時候是用 Rust,在沒有太多 C++ 的經驗下,找到一份 C++ 的工作現在正在惡補 Modern C++ 中...Orz我面試的時候連 move semantics 的本質到底是什麼都不太清楚現在應該也只是一知半解啦...Orz
作者: smes95303 (羅吉奇希斯)   2022-05-07 11:50:00
這篇看下來.....學好英文再去想自己要幹嘛比較實際
作者: ppc ( )   2022-05-10 16:03:00
你人也太好@@
作者: TheOneisNEO (Thomas Anderson)   2022-05-15 16:20:00
leetcode weekly排名一百內的應該用c++遠多於py雖然說這應該不算很厲害的比賽 但前面的人應該不差
作者: bboman (BBO)   2022-06-10 12:11:00
leetcode週賽100名內大部分都是競賽出身的,一定是C++多競賽用Python的問題是執行太慢了,有可能演算法寫對但TLEPython只有在簡單題拼手速的時候可能有優勢而已最後推一下,在這篇吵競賽用什麼真的是汙辱這篇優文...

Links booklink

Contact Us: admin [ a t ] ucptt.com