精品日韩在线,日韩精品福利一区二区三区,日韩午夜黄色,国产日韩欧美高清免费

始創于2000年 股票代碼:831685
咨詢熱線:0371-60135900 注冊有禮 登錄
  • 掛牌上市企業
  • 60秒人工響應
  • 99.99%連通率
  • 7*24h人工
  • 故障100倍補償
您的位置: 網站首頁 > 幫助中心>文章內容

再駁Linus:思科工程師對C++不得不說的事

發布時間:  2012/8/25 18:38:22

薩丕爾—沃爾夫假說曾經在語言學研究領域風靡一時。我粗略總結了一下,這個假說的核心思想是:你使用的語言影響和制約了你的想法。例如,如果你的語言只有一個單詞來描述雪,你將很難說出粉狀雪和易碎的冰雹之間的差別。

當我了解后,我徹底不相信薩丕爾—沃爾夫假說。雖然語言相對論帶著一套假說卷土重來,但幾乎可以肯定的是,人類思想絕不受制于詞匯和語法的牢籠。

E.W. Dijkstra是編程語言領域的薩丕爾,他曾說過:

“給以前接觸過BASIC學生教良好的編程幾乎是不可能的。作為潛在的程序員,他們精神上已經殘廢,無再生的希望。使用COBOL更是摧殘了他們的心靈,因此,教他們應該被視為刑事犯罪”。

今天,我們有Linus Torvalds對C++的炮轟,他認為使用C++的程序員會破壞他或她接觸到任何項目。Linus是這樣說的:

“我得出的結論是,任何希望在項目中使用C++而不是C的程序員都是很可能讓我生氣的程序員,因此我不會給他們機會來搞砸我的項目。C++導致真正糟糕的設計選擇。”

Torvalds太過武斷

在我所在的大型企業中,我們的名片背面有一句口號:不迷信科技。做到這一點可能不容易,但是的,我們愿意嘗試。

對我來說,這個訓誡意味著兩件事:

1、嘗試客觀地為工作選擇最佳的工具

2、不要讓你對工具的偏好指揮完成工作的方法

Linus在他的炮轟中已經說得很清楚,任何使用C++編程的人都很心虛,拿這些規則做借口。

但我有不同的想法,我認為C++顯然也有可能成為完成工作最合適的工具。得出這樣的結論是相當客觀的,我認為Linus顯然是被他特殊的技術流派迷惑了。

一個簡單的例子

作為我上學期C/C++編程班的期末作業,我要求學生用C實現一個簡單的令牌計數程序,目標是要重現下面這段C++代碼的行為:

map counts;
string s;
while ( cin >> s )
counts[s]++;
for ( auto ii = counts.begin() ; ii != counts.end() ; ii++ )
cout << ii->second << " : " << ii->first << endl;

這個特殊的程序突出了一些C中沒有的C++功能,如:

●C數組,向量多功能替換

● 字符串類

● 使用iostreams安全輸入

●關聯數組作為標準庫的一部分

這個程序用C++來寫是相當容易的,只需要處理一下輸入流中的錯誤——有時候甚至這一步都沒有必要。

用C實現

用C重寫是一個稍微復雜點的任務,因為C的庫中沒有任何類型的關聯數組。解決這個問題的辦法很多,我選擇了下面的辦法:

● 將所有令牌讀入一個數組

● 完成后,對數組排序

●完成數組排序后,通過遍歷每個令牌獲得計數

雖然這個算法占用的空間比C++程序更多。假設你沒有碰到gsort()之類病態的問題,花的時間可能都差不多。

我堅信用C++比用C寫這個程序更容易,理由如下:

●C I/O缺陷。在C中讀字符串有相當多的困難,由于C I/O庫沒有標準的方法讀取長度無限制的字符串(可以使用編譯器特定的擴展,但那會引起其它問題),你的輸入代碼必須檢查多種錯誤情況,或者構建你自己的字符串輸入函數。

● C數組的內存管理基本上是一項手工任務,我必須為數組分配原始空間,如果超出了它的長度,我還得小心重新分配,做完后,我還得釋放空間。

● C字符串的內存管理有同樣的問題。

● 字符串數組的排序使用gsort()只是有一點不方便,gsort()不能提供C++庫中sort()函數的性能保證。

這個函數的C版本代碼行數要多一些,需要手工完成的任務也要多一些,因此犯錯的幾率也要大一些。

我喜歡C++版本的最后一個原因是,它同樣適合其它類型,如插入和提取運算符類型、比較運算符,都可以使用同樣的代碼,只需要變一個聲明。將實現同樣的事情的代碼轉換成一個函數模板,這樣就可以在以后直接拿來使用了。

我一些最好的朋友是C程序員

那么我偏愛C++版本就能說明我是一個語言偏執的人嗎?

我認為不能如此下結論,首先,我認為這個程序的C版本也有一些不錯的優點:

● 你可以使用POSIX系統調用編寫這個程序,除了內存分配和排序。

●這個程序的C版本因為使用了底層I/O,速度將會更快,C++ iostreams在任何時候都表現良好,但它們的分層方法在談到效率時總是處于不利地位。

因此,對于這樣一個程序,語言的選擇最終歸結為背景,如果你相信80/20規則,并且它不是程序的核心部分,你可能認為這個代碼應該用C++編寫。代碼行數越少,犯錯的幾率就越低,效率可能不是最大的問題。

如果這是一段很關鍵的經常執行的代碼,你可能會認為C是最佳選擇。如果選擇C,請一定要花點額外的時間進行代碼評審,確保沒有內存泄露和指針錯誤,只有那樣,你才上路了。

撫平Linus的情緒

那么Linus看到上面的代碼是如何炮轟的呢?我斗膽猜一下,任何像樣的C++程序員都會寫出類似的代碼。Linus說:

“你一定使用了這種語言“好的”庫功能,如STL和Boost,它們對你的程序可能有幫助,但當它們不工作時,會引起無盡的痛苦”。

在這個程序中,我好好利用了曾是STL一部分的標準庫組件,它們作為標準的一部分已經有十多年的歷史。它們的表現真的很好,在我所知道的任何編譯器中,也沒有可移植性或正確性問題。

“你會發現某些抽象編程模型不是很有效,但現在你所有的代碼都依賴于所有圍繞它的好對象模型。如果不重寫你的應用程序,那么你是無法修復它的。”

的確,盡管C++不能為我做這些事,我只有設法自己編寫程序,不使用任何抽象——沒有新的類,沒有接口,基本上完全是靠C代碼完成許多有用的類的。

但我認為這是規則而不是例外。

“換句話說,只有這樣才能做得好,效率高,系統級和可移植的C++最終會限制自己,但這一切在C中都是可行的。”

除非C有容器類,字符串類,類型安全I/O,以及RAII這樣的技術,這句話才會變成真的。現在來看,它完全是胡說。

在現代C++可用之前,我可能會堅持使用一個簡單的管道來完成這個任務:

tr [:blank:] '\n' | grep -v "^$" | sort | uniq -c

事實上,我可以在編譯語言中做同樣的事。只要它們能給我一些靈活性,我想我不用成為一個偏執狂就能明白這個事實。你對此又是怎樣看的?

作者簡介:Mark Nelson,現任思科公司工程師,《The Data Compression Book》的作者,《Developing Cisco IP Phone Services: A Cisco AVVID Solution》的協作者。


本文出自:億恩科技【www.zuiquanben.com】

服務器租用/服務器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質保障!--億恩科技[ENKJ.COM]

  • 您可能在找
  • 億恩北京公司:
  • 經營性ICP/ISP證:京B2-20150015
  • 億恩鄭州公司:
  • 經營性ICP/ISP/IDC證:豫B1-20183354
  • 億恩南昌公司:
  • 經營性ICP/ISP證:贛B2-20080012
  • 服務器/云主機 24小時售后服務電話:0371-60135900
  • 虛擬主機/智能建站 24小時售后服務電話:0371-60135900
  • 網絡版權侵權舉報電話:0371-60135995
  • 警情提示:注意防范電信網絡詐騙
  • 專注服務器托管17年
    掃掃關注-微信公眾號
    0371-60135900
    Copyright© 1999-2026 ENKJ All Rights Reserved 地址:鄭州市高新區翠竹街1號總部企業基地億恩大廈  法律顧問:河南亞太人律師事務所郝建鋒、杜慧月律師  B1-20183354   京公網安備41019702002023號 
      0
     
     
     
     

    0371-60135900
    7*24小時客服服務熱線

     
     
    精品日韩在线,日韩精品福利一区二区三区,日韩午夜黄色,国产日韩欧美高清免费
    精品国产亚洲一区二区在线观看| 国产精品日韩久久久| 成人国产精品| 亚洲一区二区三区无吗| 麻豆91在线播放| 尤物精品在线| 国产一区二区三区免费在线| 久久狠狠婷婷| 日本精品久久| 欧美手机在线| 国产精品2区| 久久亚洲视频| 成人看片网站| 精品国产a一区二区三区v免费| 免费久久99精品国产自在现线| 久久免费精品| 日韩av中文字幕一区二区| 久久久国产亚洲精品| 国产精品.xx视频.xxtv| 蜜桃传媒麻豆第一区在线观看| 在线手机中文字幕| 欧美日韩一区二区三区在线电影| 日韩成人三级| 国产一区二区精品福利地址| 亚洲精品美女91| 免播放器亚洲| 蘑菇福利视频一区播放| 欧美日韩中文一区二区| 亚洲www免费| 久久男人av资源站| 成人在线丰满少妇av| 国产精品大片| 国产精品qvod| 国产精品1区在线| 国产精品久久久久久av公交车| 最新国产精品久久久| 激情91久久| 亚洲高清二区| 九色精品91| 99re国产精品| 四虎精品一区二区免费| 日韩国产在线一| 国产视频一区二| 久久久久亚洲精品中文字幕| 国产suv精品一区二区四区视频| 久久久精品区| 蜜臀av亚洲一区中文字幕| 色婷婷久久久| 国产精品成久久久久| 日本三级亚洲精品| 免费中文字幕日韩欧美| 日韩av福利| 国产精品a级| 日本午夜精品久久久久| 91久久午夜| 欧美日韩在线二区| 国产成人在线中文字幕| 国产激情一区| 国产欧美综合一区二区三区| 日韩中文字幕一区二区高清99| 午夜国产欧美理论在线播放| 亚洲综合电影| 亚洲综合在线电影| 久久精品一区二区不卡| 91精品精品| av一区二区高清| 99成人在线| 影院欧美亚洲| 亚久久调教视频| 日本欧美大码aⅴ在线播放| 97久久精品| 精品五月天堂| 韩国久久久久久| 在线视频观看日韩| 日韩一级网站| 欧美天堂一区| 日韩av专区| 免费毛片在线不卡| 六月丁香综合| 欧美精品影院| 日本不卡免费高清视频在线| 欧美色图国产精品| av一区二区高清| 综合日韩在线| 欧美黄色一区二区| 亚洲四虎影院| 亚洲在线成人| 免费一级欧美片在线观看网站| 久久99国产精品视频| 久久久久国产精品一区二区| 精品中文一区| 麻豆极品一区二区三区| 丝袜美腿一区| 日韩欧美中文字幕在线视频| 久久精品一区二区国产| 亚洲免费黄色| 久久99高清| 图片区亚洲欧美小说区| 国产欧美日韩在线一区二区 | 亚洲欧美日韩在线观看a三区| 日韩和欧美一区二区三区| 日韩精品诱惑一区?区三区| 日产欧产美韩系列久久99| 黄毛片在线观看| 欧美亚洲免费| 自拍日韩欧美| 国产精品精品| 国产乱码精品| 国产99精品| 久久影院资源站| 日本在线不卡视频| 99久久婷婷| sm捆绑调教国产免费网站在线观看| 日韩午夜电影| 亚洲五月婷婷| 日本美女一区| 色乱码一区二区三区网站| 日本va欧美va精品| 亚洲一区二区网站| 亚洲女同中文字幕| 国产综合精品一区| 99久久久久国产精品| 欧美羞羞视频| 精品国产亚洲一区二区三区在线 | 久久精品国产精品亚洲毛片| 日本在线观看不卡视频| 综合国产精品| 视频一区二区国产| 美女精品在线| 视频精品一区二区| 男人操女人的视频在线观看欧美| 欧美日韩日本国产亚洲在线 | 久久在线视频免费观看| 久久精品影视| 国产真实久久| 一区二区视频欧美| 玖玖精品视频| 亚洲3区在线| 国产精品日本一区二区三区在线| 日韩av中文在线观看| 久久免费精品| 久久高清免费| 爽好多水快深点欧美视频| 综合激情网...| 国产探花在线精品一区二区| 国产高清日韩| 久久精品不卡| 欧美日韩国产一区二区三区不卡 | 日韩美女一区二区三区在线观看| 日韩在线第七页| 黄色日韩在线| 国产伦理久久久久久妇女| 精品不卡一区| 午夜国产欧美理论在线播放| 日韩高清在线不卡| 97精品国产福利一区二区三区| 五月天综合网站| 国产精品一区2区3区| 99成人在线视频| 国产日韩欧美一区在线| 欧美日韩视频网站| 99视频精品| 国产精品99视频| 国产日韩免费| 日韩精品成人| 亚洲一区二区三区中文字幕在线观看| 精精国产xxxx视频在线播放| 久久av免费| 麻豆一区二区三| 国产精品多人| 麻豆国产精品一区二区三区| 日本中文字幕不卡| 日韩国产在线观看一区| 日本成人在线视频网站| 亚洲美女久久| 欧美精品影院| 日韩福利视频一区| 日韩国产在线不卡视频| 日本午夜精品一区二区三区电影| 亚洲精品九九| 欧美三区不卡| 久久亚洲精精品中文字幕| 麻豆一区二区99久久久久| 精品一区二区三区视频在线播放 | 精品久久免费| 国产精品13p| 欧美日韩国产v| 伊人精品在线| 日本一区中文字幕| 日韩av中文在线观看| 国产精品丝袜在线播放| 美女视频黄久久| 婷婷成人综合| 亚洲精品字幕| 精品一区二区三区四区五区| 久久久久亚洲| 日本成人手机在线| 精品视频在线观看网站| 久久中文视频| 欧美精品影院|