C_and_CPP 板


LINE

※ 引述《tomex (tomex_ou)》之銘言: : 為何C++要把宣告放在HEADER FILE 內? : 我一開始學習此語言也覺得可疑(從高階往低階學習), : 問老手他們的回答都是:「目的應該是要隱藏實作, : 你寫在 .h 檔裡面, 內容不就給人看光了?」 你問的真的是老手嗎? : 這理由對於用慣c/c++的人,是很正常的解釋, : 但對於一開始就接觸更高階語言(java/c#)的人就無法怪怪的, : 若是不給他人看源碼,乾脆包成dll或lib檔就行了?! : 正確答案就是,c++語言本身在#include特性的限制。 : 原來c/c++都是靠#include來了解其他的class資訊, : 但include很容易重複載入造成error : 更加上為了相容c語言中必須先宣告變數才能使用的舊包袱, : 因此若要引用別的class之函數型別, : 為了加快載入速度,自然切分.h與.cpp比較佳。 原因可能很多 加快速度應該是最不重要的 打從人類還在寫組合語言的時代 界面和實作就是分離的 界面和實作分離有許多好處 同樣的 function prototype 可以有不同的 implementation client code 不須要改變任何一行程式碼 只要連結不同的 library 就可以使用不同的 implementation 甚至如果你是用 dynamic linking 的方式 就算 library 有改版 只要界面還是相同的 那 client code 連重編都不用 : c#這種新語言就沒這種限制,它通通寫在一個class裏, : 編譯器會先把它們compile成中間語言(IL), : 再從IL裏自動就抽出class的相關型別資訊(metadata) : 形成一個dll檔,因此源碼也不外露,型別辨識也沒問題。 : 相較java或c#的namespace管理,c++使用#include是比較陽春的 是啊 你會問說 為什麼 C++ 的 #include 沒有這麼聰明? 因為 #include 是 preprocessor 在做的 preprocessor 不是 compiler 它只認得註解和井號開頭的關鍵字 所以它不知道你寫 class XXX 是在宣告類別 自然也無法從實作中抽取界面 這的確是 (我認為) 目前 C++ 的不足之處 : 其實只要c++ compiler能多聰明一點,編譯時能自動辨別該*.h是否已經載入 : 就不用讓程式員必須在每個.h裏開頭明義就要寫這樣的贅詞: : #ifndefine xxxH : #definde xxxH 這就和前面的界面實作分離一點關係也沒有了 這只是在避免重覆宣告 : 當你把一個複雜的class成更多的子class, 這是什麼意思? : 使用#include來形容這些就更顯不足與繁雜 : c++雖然也提出namespace概念,但在巢狀namespace實作不是很好 : 反而讓寫法更加複雜。 : 我發現c++為了更快,又要相容c語言,很不習慣去改良容易讓人誤解的地方 很簡單啊 如果 C++ 改了它 那 C++ 根本就無法流行 C++ 設計之初的要求就是盡可能和 C 相容 因此程式設計師幾乎不用死任何腦細胞就可以繼續使用現有的 C library : 例如新人都知道void是不傳回retun的關鍵字, : 但對於指向任何型別的指標用void*就會讓人困擾 : 為何不再創造一個any關鍵字,any*不是比較直接嗎? 你用的是 C++ 嗎? 為什麼你會用到 void* ? 如果程式寫得好 這東西根本就不需要 : 然而,c++之所以變化萬千,是因為它在不變更目前架構下, : 利用很多組合來表達更多意思 : 雖然很有創意,但對新手而言,容易犯錯或不解, : 在開發速度上並沒有多大助益。 : 結論,每個語言有它適用的時機及簡化的理由, : c++少了高階語言的智慧功能來增加效能,也減少compiler的冗大複雜 : 雖然有點不方便的地方,大家就忍耐一點吧! : (寫組語的專家可為你的不知福而氣悶呢!) : 但我心中還是覺得,有些該改該變的,還是要積極變更。 : 程式碼老了就應該要刪除碼代,不要惜舊,如此才能一直進步才是。 : 大家為了方便maintaining的理由一直排斥微軟的進步,吾不以為然, ^^^^^^^^^^ 首先 這世界並不是只有微軟在發明新語言 其次 你可能不太了解微軟為了相容性而在 windows 內作了多少調整 : 既然選了程式員之路,還怕改變嗎? 不是怕改變 而是重寫一套大型軟體的難度不下於蓋一棟101 當然 很有錢的情況另當別論 --



※ 發信站: 批踢踢實業坊(ptt.cc)
◆ From: 61.62.3.35 ※ 編輯: littleshan 來自: 61.62.3.35 (04/30 14:32)
1F:推 tomex:你的意見也很不錯的,給我很好的指正,謝謝。 04/30 14:49
2F:推 GoldenField:為什麼void* 不需要 @@a? 04/30 15:59
3F:推 littleshan:倒不如問 為什麼需要void* 04/30 19:22
4F:推 zeus1208:那請問...有人可以說明"mpi.h"怎麼匯入嗎~ (跪) 04/30 19:50
5F:推 GoldenField:如果不知道檔案型態的時候 用void*不是很正常嗎? 04/30 19:52
6F:→ GoldenField:應該是 變數型態 04/30 19:52
7F:推 orc1424:微軟為了相容性真的太痛苦了... 05/01 21:14







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:Tech_Job站內搜尋

TOP