25個會讓你戀戀不忘的水平動彈網站設計 |
發布時間:2015-10-14 文章來源: 瀏覽次數:2628 |
假如你的代碼工作正常并且表現良好,你可能會想知道為什么還要使用C++ 11。當然了,使用用最新的技術感覺很好,但是事實上它是否值得呢?在我看來,謎底毫無疑問是肯定的。我在下面給出了9個理由,它們分為兩類:機能上風和開發效率。 獲得機能上風 理由1:move語義(move semantics)。簡樸的說,它是優化復制的一種方式。有時候復制很顯然是鋪張的。假如你從一個臨時的string對象復制內容,簡樸的復制指針到字符緩沖區將比創建一個新的緩沖區再復制要高效得多。他之所以能工作是由于源對象超出了范圍。 然而,在這以前C++并沒有判定源對象是不是臨時對象的機制。move語義通過除了復制操縱外還答應你有一個move構造函數(move constructor)和一個move賦值運算(move assignment)符來提供這個機制。 你知道嗎?當你在Visual Studio 2010中使用尺度庫中的類如string或vector時,它們已經支持move語義了。這可以防止不必要的的復制從而改善機能。 通過在你的類中實現move語義你可以獲得額外的機能晉升,好比當你把它們存儲到STL容器中時。還有,move語義不僅可以應用到構造函數,還可以應用到方法(如vector的push_back方法)。 理由2:通過使用種別屬性(type traits,如is_floating_point)和模板元編程(template metaprogramming,如enable_if template),你可認為某些特定的類型定制模版,這可以實現優化。 理由3:哈希表現在已經是尺度實現的了,它提供更快速的插入、刪除和查找,這在處理大量數據時很有用。你現在可以隨便使用unordered_map, unordered_multimap, unordered_set 和unordered_multiset這幾種數據結構了。 進步效率 進步效率不僅都是在代碼機能方面,開發時間也是寶貴的。C++ 11可以讓你的代碼更短、更清楚、和更易于閱讀,這可以讓你的效率更高。 理由4:auto樞紐字可以自動推斷類型,所以下面的代碼: vector<vector<MyType>>::const_iterator it = v.begin() 現在可以很簡樸的寫成: auto it = v.cbegin() 盡管有些人會說,它躲藏了類型信息,在我看來它利大于弊,由于它減少了視覺混換并展示了代碼的行為,還有它可以讓你我少打良多字! 理由5:Lambda表達式提供了一種方法來定義匿名方法對象(實際上是閉包),這是代碼更加線性和有規律可循。這在和STL算法結合使用時很利便: bool is_fuel_level_safe() { return all_of(_tanks.begin(), _tanks.end(), [this](Tank& t) { return t.fuel_level() > _min_fuel_level; }); } 理由6:新的智能指針(smart pointer)替代了有題目的auto_ptr,你可以不用擔心內存的開釋并移除相關開釋內存的代碼了。這讓代碼更清楚,并杜絕了內存泄露和查找內存泄露的時間。 理由7:把方法作為first class object是一個非常強盛的特性,這讓你的代碼變得更靈活和通用了。C++的std::function提供了這方面的功能。方法提供一種包裝和傳遞任何可調用的東西-函數指針, 仿函數(functor), lambda表達式等。 理由8:還有很多其它小的功能,如override、final樞紐字和nullptr讓你的代碼意圖更明確。對我來說,減少視覺混亂和代碼中能夠更清晰地表達我的意圖意味著更興奮、更高效。 另一個開發效率的方面是錯誤檢測。假如你的錯誤在運行時發生,這意味著你至少需要運行軟件,并可能得通過一系列步驟來重現錯誤,這需要時間。 C++ 11提供了一種方法來檢查先決前提并盡早的在可能的時機捕捉錯誤-編譯過程中,在你運行代碼前。這就是理由9。 這是通過靜態斷言(static_assert)和種別屬性模版實現的。這種方法的另一個好處是,它不需要占用任何的運行時開銷,沒有什么機能損失! 現在開始把握C++ 11 在C++ 11尺度中除了上描述的還有更多的改動和新功能,它需要一整本數來描述。不外,我相信它們是值得你花時間去學習的。你將省去以往花在進步效率上的時間。良多主流的編譯器已經開始支持C++ 11的一些尺度了。還等什么?開始吧! 注:良多名詞覺得翻譯成了中文還不如看英文來的愜意,翻譯成了中文的后面括號里備注了原英文單詞。 |