青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

In my way

On my way

常用鏈接

統(tǒng)計

最新評論

VS 2010 C++ 王者歸來

作為Visual C++程序員,大家心里都很憋屈!大家都在問,Visual C++的前途在哪里?堅持C++還有沒有意義?

  在Visual Studio 2010中我們找到了答案,找到了C++的未來:C++王者歸來!
  雖然在C++的發(fā)展歷程中經(jīng)歷了上述小小的波折,但是我們應當看到,世界上還有無數(shù)的C++代碼在穩(wěn)定地運行著,這些代碼還需要維護,需要升級。另外,C++在某些領域還是具有不可替代的優(yōu)勢,無數(shù)基于C++的新項目正在進行著。微軟也逐漸意識到了這一點,開始不斷增強Visual Studio對C++的支持力度。在這次的Visual Studio 2010 CTP中,無論是從C++語言本身還是從IDE方面,都給我們帶來了很多期盼已久的新特性。花開兩朵,各表一枝。我們這里按下Visual Studio 2010在IDE方面的增強不表,單說它對即將到來的C++新標準C++0x的支持。

  C++的新標準C++0x雖然還沒有正式發(fā)布,但是已經(jīng)進入了feature freeze的階段,很多人都在猜測C++0x中的x到底是9還是10,從目前的情況來看,9是最大的可能了。Visual Studio 2010作為下一代開發(fā)工具,當然不會錯過對新的C++標準C++0x的支持。除了隨著之前發(fā)布的Visual C++ Feature Pack而引入的TR1包含的部分特性外,在新的Visual Studio 2010中,還引入了4個重要的C++新特性。號稱C++0x的“四大天王”。這些新特性的引入,必將給C++注入新的活力。

  Lambda表達式

  很多編程編程語言都支持匿名函數(shù)(anonymous function)。所謂匿名函數(shù),就是這個函數(shù)只有函數(shù)體,而沒有函數(shù)名。Lambda表達式就是實現(xiàn)匿名函數(shù)的一種編程技巧,它為編寫匿名函數(shù)提供了簡明的函數(shù)式的句法。同樣是Visual Studio中的開發(fā)語言,Visual Basic和Visual C#早就實現(xiàn)了對Lambda表達式的支持,終于Visual C++這次也不甘落后,在Visual Studio 2010中添加了對Lambda表達式的支持。

  Lambda表達式使得函數(shù)可以在使用的地方定義,并且可以在Lambda函數(shù)中使用Lambda函數(shù)之外的數(shù)據(jù)。這就為針對集合操作帶來了很大的便利。在作用上,Lambda表達式類似于函數(shù)指針和函數(shù)對象,Lambda表達式很好地兼顧了函數(shù)指針和函數(shù)對象的優(yōu)點,卻沒有它們的缺點。相對于函數(shù)指針或是函數(shù)對象復雜的語法形式,Lambda表達式使用非常簡單的語法就可以實現(xiàn)同樣的功能,降低了Lambda表達式的學習難度,避免了使用復雜的函數(shù)對象或是函數(shù)指針所帶來的錯誤。我們可以看一個實際的例子:

// LambdaDemo.cpp : Defines the entry point for the console application.
//

#include
"stdafx.h"
#include
<algorithm>
#include
<iostream>
#include
<ostream>
#include
<vector>

using namespace std;

int _tmain(int argc, _TCHAR* argv[])
{
    vector
<int> v;
    
for (int i = 0; i < 10; ++i) {
        v.push_back(i);
    }
         for_each(v.begin(), v.end(), [] (
int n) {
        cout
<< n;
        
if (n % 2 == 0) {
            cout
<< " even ";
        }
else {
            cout
<< " odd ";
        }
    });
    cout
<< endl;

    
return 0;
}

  這段代碼循環(huán)遍歷輸出vector中的每一個數(shù),并判斷這個數(shù)是奇數(shù)還是偶數(shù)。我們可以隨時修改Lambda表達式而改變這個匿名函數(shù)的實現(xiàn),修改對集合的操作。在這段代碼中,C++使用一對中括號“[]”來表示Lambda表達式的開始,其后的”(int n)”表示Lambda表達式的參數(shù)。這些參數(shù)將在Lambda表達式中使用到。為了體會Lambda表達式的簡潔,我們來看看同樣的功能,如何使用函數(shù)對象實現(xiàn):
 
#include "stdafx.h"
#include
<algorithm>
#include
<iostream>
#include
<ostream>
#include
<vector>
using namespace std;

struct LambdaFunctor {
    void operator()(
int n) const {
        cout
<< n << " ";
        
if (n % 2 == 0) {
            cout
<< " even ";
        }
else {
            cout
<< " odd ";
        }

    }
};

int _tmain(int argc, _TCHAR* argv[])
{
    vector
<int> v;

    
for (int i = 0; i < 10; ++i) {
        v.push_back(i);
    }

    for_each(v.begin(), v.end(), LambdaFunctor());
    cout
<< endl;

    
return 0;
}

  通過比較我們就可以發(fā)現(xiàn),Lambda表達式的語法更加簡潔,使用起來更加簡單高效。

靜態(tài)斷言static_assert

  在之前的C++標準C++03中,我們可以使用兩種斷言:
  • 使用預處理中的條件編譯和#error指令,可以在預處理階段檢查一些編譯條件
  • 可以使用宏assert來進行運行時檢查,以確保程序邏輯的正確性

  但使用#error方法是非常煩瑣的,并且不能夠對模板參數(shù)進行檢查,因為模板實例化是在編譯時進行,而#error方法是在預處理階段進行的。而assert宏是在運行時進行檢查。不難發(fā)現(xiàn),我們缺少了一樣東西,那就是可用于在編譯時檢查的工具。于是,靜態(tài)斷言應運而生。

  在新的C++標準C++0x中,加入了對靜態(tài)斷言的支持,引入了新的關鍵字static_assert來表示靜態(tài)斷言。使用靜態(tài)斷言,我們可以在程序的編譯時期檢測一些條件是否成立,這個特性在調試模板函數(shù)的模板參數(shù)時特別有用。在編譯的時候,模板函數(shù)實例化,這時我們就可以使用靜態(tài)斷言去測試模板函數(shù)的參數(shù)是否按照我們的設計擁有合適的值。例如下面這段代碼:

template <int N> struct Kitten {
    static_assert(N
< 2, "Kitten<N> requires N < 2.");
};

int main() {
    Kitten
<1> peppermint;
    Kitten
<3> jazz;

  
return 0;
}

  當我們在主函數(shù)中使用“1”去實例化Kitten這個結構體時,在編譯的時候,靜態(tài)斷言static_assert會測試參數(shù)N的值,當N的值小于2時就會產生一個斷言錯誤,并將相應的調試幫助信息輸出到“Error List”窗口中,這樣程序員就可以對問題快速定位,解決問題就更加方便了。
 


圖2 static_assert斷言及其輸出


  另外,靜態(tài)斷言還帶來很多其他的優(yōu)勢。例如靜態(tài)斷言在編譯時進行處理,不會產生任何運行時刻空間和時間上的開銷,這就使得它比assert宏具有更好的效率。另外比較重要的一個特性是如果斷言失敗,它會產生有意義且充分的診斷信息,幫助程序員快速解決問題。

  auto關鍵字

  在C++0x中,auto關鍵字的意義發(fā)生了改變。從Visual C++ 2010開始,auto關鍵字將用于指引編譯器根據(jù)變量的初始值來決定變量的數(shù)據(jù)類型。換句話說,我們可以把auto當成一種新的數(shù)據(jù)類型,它可以“從初始化器(initialize)中推導出所代表的變量的真正類型”。這種對auto關鍵字的使用方式可以大大消除當前替代方式所導致的冗長和易出錯的代碼。我們看一個實際的例子:

#include <iostream>
#include
<map>
#include
<ostream>
#include
<regex>
#include
<string>
using namespace std;
using namespace std::tr1;

int main() {
    map
<string, string> m;

    
const regex r("(\\w+) (\\w+)");

    
for (string s; getline(cin, s); ) {
        smatch results;
        
if (regex_match(s, results, r)) {
            m[results[
1]] = results[2];
        }
    }
    
for (auto i = m.begin(); i != m.end(); ++i) {
        cout
<< i->second << " are " << i->first << endl;
    }

    
return 0;
}

  在這段代碼中,我們使用auto關鍵字來代替了真正的數(shù)據(jù)類型map<string, string>::iterator,這使得整個代碼自然而簡潔。

  另外,跟其他數(shù)據(jù)類型一樣,我們也可以對auto關鍵字進行修飾,例如添加const,指針(*),左值引用(&),右值引用(&&)等等,編譯器會根據(jù)auto類型所代表的真正的數(shù)據(jù)來決定這些修飾的具體含義。

  為了兼容一些舊有的C++代碼,我們可以使用/Zc:auto這個編譯器選項,來告訴編譯器是采用auto關鍵字的原有定義還是在新標準C++0x中的定義。

右值引用

  作為最重要的一項語言特性,右值引用(rvalue references)被引入到 C++0x中。我們可以通過操作符“&&”來聲明一個右值引用,原先在C++中使用“&”操作符聲明的引用現(xiàn)在被稱為左值引用。 
int a;
int& a_lvref = a;  // 左值引用

int b;
int&& b_rvref = b;  // 右值應用

  左值引用和右值引用的表現(xiàn)行為基本一致,它們唯一的差別就是右值引用可以綁定到一個臨時對象(右值)上,而左值引用不可以。例如: 

int& a_lvref = int();      // error C2440: 'initializing' : cannot convert from 'int' to 'int &'    
int&& b_rvref = int();  // OK!

  在第一行代碼中,我們將一個臨時對象int()綁定到一個左值引用,將產生一個編譯錯誤。而在第二行中,我們將臨時對象綁定到右值引用,就可以順利通過編譯。

  右值是無名的數(shù)據(jù),例如函數(shù)的返回值一般說來就是右值。當對右值進行操作的時候,右值本身往往沒有必要保留,因此在某些情況下可以直接“移動”之。通過右值引用,程序可以明確的區(qū)分出傳入的參數(shù)是否為右值,從而避免了不必要的拷貝,程序的效率也就得到了提高。我們考慮一個簡單的數(shù)據(jù)交換的小程序,從中來體會右值引用所帶來的效率提升。我們可以寫一個函數(shù)swap來實現(xiàn)兩個變量值的交換:

template <class T> swap(T& a, T& b)
{
    T tmp(a);  
// tmp對象創(chuàng)建后,我們就擁有了a的兩份拷貝
    a
= b;      // 現(xiàn)在我們擁有b的兩份拷貝
    b
= tmp;    // 現(xiàn)在我們擁有a的兩份拷貝
}

  在這段代碼中,雖然我們只是為了進行簡單的數(shù)據(jù)交換,但是卻執(zhí)行了多次對象拷貝。這些對象的拷貝操作,特別是當這些對象比較大的時候,無疑會影響程序的效率。

  那么,如果使用右值引用如何實現(xiàn)呢?

// RValueRef.cpp : Defines the entry point for the console application.
//

#include
"stdafx.h"

template
<class T>
T
&& move(T&& a)
{
    
return a;
}

template
<class T> void swap(T& a, T& b)
{
    T tmp(move(a));
// 對象a被移動到對象tmp,a被清空
    a
= move(b);    // 對象b被移動到對象a,b被清空
    b
= move(tmp);  // 對象tmp被移動到對象b
}

int _tmain(int argc, _TCHAR* argv[])
{
    
int a = 1;
    
int b = 2;
    swap(a, b);

  
return 0;
}

  在這段重新實現(xiàn)的代碼中,我們使用了一個move()函數(shù)來代替對象的賦值操作符“=”,move()只是簡單地接受一個右值引用或者左值引用作為參數(shù),然后直接返回相應對象的右值引用。這一過程不會產生拷貝(Copy)操作,而只會將源對象移動(Move)到目標對象。

  正是拷貝(Copy)和移動(Move)的差別,使得右值引用成為C++0x中最激動人心的新特性之一。從實踐角度講,它能夠完美是解決C++中長久以來為人所詬病的臨時對象的效率問題。從語言本身講,它健全了C++中的引用類型在左值右值方面的缺陷。從庫設計者的角度講,它給庫設計者又帶來了一把利器。而對于廣大的庫使用者而言,不動一兵一卒便能夠獲得“免費的”效率提升。

  在Visual Studio 2010中,因為有了對這些C++0x新特性的支持,重新點燃了程序員們對C++的熱情。C++重振雄風,指日可待!

posted on 2009-04-27 16:02 谷主 閱讀(11856) 評論(13)  編輯 收藏 引用

評論

# re: VS 2010 C++ 王者歸來 2009-04-28 13:46 Kevin Lynx

個人從來沒有認為C/C++就是窮途末路。技術環(huán)境在浮躁,也不至于認為某個語言不行了。
C++0x的新特性看起來還比較有趣。  回復  更多評論   

# re: VS 2010 C++ 王者歸來 2009-06-28 21:52 kinsung

費勁啊,還是用C#吧,程序員也要生產力。  回復  更多評論   

# re: VS 2010 C++ 王者歸來 2009-06-29 19:06 kyline

@kinsung
開發(fā)的目標產品,導致我們用什么語言!語言并無絕對的優(yōu)劣!  回復  更多評論   

# re: VS 2010 C++ 王者歸來[未登錄] 2009-07-04 12:37 google

C++在vs里面就像是后媽生的!!!太委屈了?微軟有了C#就不要vc了嗎??  回復  更多評論   

# re: VS 2010 C++ 王者歸來 2009-08-12 19:06 Alchemist

C++ 比 C# 效率高 幾倍  回復  更多評論   

# re: VS 2010 C++ 王者歸來[未登錄] 2010-01-23 20:17 Jeffrey

你這個講解的我完全沒看出有什么優(yōu)點
比如那個Lambda表達式的例子,跟把那個遍歷的操作單獨寫個函數(shù)沒簡潔到哪去,還多了個struct出來
還有最后一個,T tmp(move(a)),這個時候a被清空是啥意思?如果a是int型,清空成0?,如果是class,那這swap操作傳指針好了  回復  更多評論   

# re: VS 2010 C++ 王者歸來 2010-01-26 00:03 hanxb

這3個性能實在沒啥意思。

能不能在界面開發(fā)多下點功夫,最起碼實現(xiàn)delphi的panel這樣的窗口框架
  回復  更多評論   

# re: VS 2010 C++ 王者歸來 2010-02-08 22:59 Sweet

@Alchemist
你是實際測試過還是看的參考文章?
效率這個問題要看在什么環(huán)境下。  回復  更多評論   

# re: VS 2010 C++ 王者歸來 2010-02-26 13:55 alexwu

@Jeffrey
struct LambdaFunctor {
void operator()(int n) const {
cout << n << " ";
if (n % 2 == 0) {
cout << " even ";
} else {
cout << " odd ";
}

}
};
這個是仿函數(shù)的寫法,C++本來就支持這個的,到時那個匿名函數(shù),個人反而覺得反感,原因是怎么斷點調試  回復  更多評論   

# re: VS 2010 C++ 王者歸來 2010-03-09 02:46 ABC

真看不出匿名函數(shù)到底有什么好處,代碼看起來更費勁了!  回復  更多評論   

# re: VS 2010 C++ 王者歸來[未登錄] 2011-01-05 11:22 Lin

template <class T> void swap(T& a, T& b)
{
T tmp(move(a)); // 對象a被移動到對象tmp,a被清空
a = move(b); // 對象b被移動到對象a,b被清空
b = move(tmp); // 對象tmp被移動到對象b
}

代碼右邊的注釋,請解釋!
你以為寫程序是變魔術啊?
讓move正常工作的一個重要機制你都沒有寫出來,還發(fā)什么貼誤人子弟?  回復  更多評論   

# re: VS 2010 C++ 王者歸來[未登錄] 2011-01-05 11:42 Lin

寫程序不是憑空想象,也不是變魔術,每一個語言元素都是有依據(jù)的。
能夠讓rvalue reference的move semantics正常工作的重要要求:

T必須根據(jù)自身數(shù)據(jù)特性重載下面兩個函數(shù):

T(T&& rhs);
T& operator=(T&& rhs);

并且在這兩個函數(shù)里實現(xiàn)數(shù)據(jù)移動而不是拷貝的操作,例如T內部包含一個動態(tài)對象指針p,那么重載的這兩個rvalue函數(shù)需要做的僅僅是淺拷貝,而不需要拷貝整個對象,因為傳入?yún)?shù)是rvalue,明確的告訴函數(shù)這個值是一個臨時值,可以偷竊他的內容,然后重置這個值

T(T&& rhs)
{
p = rhs.p; // 不需要對象拷貝,僅僅”偷竊“指針
rhs.p = nullptr; // 手動清空傳入右值引用,因為它將在函數(shù)返回后被立即析構
}
  回復  更多評論   

# re: VS 2010 C++ 王者歸來 2012-02-03 15:50 溪流

@Lin
學習了
  回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            日韩一二三区视频| 亚洲午夜一级| 在线观看亚洲精品视频| 欧美精品一区二区三区视频| 久久九九国产| 欧美成人午夜免费视在线看片| 久久久久国产精品一区| 免费久久精品视频| 欧美激情一区二区| 欧美日韩亚洲一区二区| 国产精品一区三区| 亚洲国产精品成人久久综合一区 | 欧美a一区二区| 亚洲黄色免费网站| 亚洲激情视频在线播放| 亚洲欧美日韩在线播放| 欧美**字幕| 好吊一区二区三区| 亚洲视频在线播放| 欧美日韩国产另类不卡| 黄色综合网站| 欧美在线观看视频一区二区三区| 亚洲黄色小视频| 久久夜色精品国产| 伊人久久大香线蕉av超碰演员| 亚洲天堂av在线免费观看| 亚洲国产成人av在线| 久久午夜视频| 国外成人网址| 麻豆精品一区二区综合av| 欧美在线视频一区二区三区| 欧美午夜精品久久久久久久 | 欧美视频第二页| 久久久水蜜桃| 影音先锋另类| 欧美激情国产日韩| 欧美人与性禽动交情品 | 亚洲自拍另类| 一区二区欧美日韩| 国产日产欧美精品| 久久久久国产精品一区| 午夜性色一区二区三区免费视频| 国产日韩欧美一区二区| 鲁鲁狠狠狠7777一区二区| 久久久综合免费视频| 日韩一区二区久久| 午夜一区二区三区不卡视频| 伊人蜜桃色噜噜激情综合| 亚洲国产精品一区二区三区| 欧美日本国产视频| 久久亚洲精品一区| 欧美视频精品在线观看| 久久午夜电影| 国产精品v日韩精品| 米奇777在线欧美播放| 国产精品亚洲精品| 亚洲精品视频在线| 伊人久久综合| 欧美主播一区二区三区| 亚洲综合国产| 亚洲伊人第一页| 欧美日本三区| 亚洲人成高清| 在线视频欧美一区| 欧美国产综合视频| 亚洲高清视频的网址| 在线日本高清免费不卡| 久久人人爽爽爽人久久久| 国产精品福利久久久| 亚洲午夜视频在线| 欧美一级在线视频| 欧美日韩大片一区二区三区| 免费观看日韩| 亚洲激情六月丁香| 美女国内精品自产拍在线播放| 久久久一区二区| 亚洲国产一区视频| 欧美激情精品久久久久久黑人 | 99在线|亚洲一区二区| 欧美激情精品久久久久久大尺度| 亚洲激情成人| 久久精品国产第一区二区三区| 欧美第一黄色网| 亚洲在线免费观看| 在线精品国产欧美| 欧美国产日产韩国视频| 一区二区三欧美| 麻豆成人在线播放| 国产欧美婷婷中文| 亚洲国产精品女人久久久| 精品不卡在线| 国产精品成人免费精品自在线观看| 亚洲日本中文字幕区| 香蕉久久a毛片| 亚洲狼人精品一区二区三区| 国产精品草草| 久久精品2019中文字幕| 在线观看成人一级片| 国产一区二区中文| 久久综合九色九九| 国产精品欧美一区二区三区奶水| 欧美伊人久久久久久午夜久久久久 | 国产亚洲人成a一在线v站 | 美女视频网站黄色亚洲| 一区二区激情| 亚洲国产综合91精品麻豆| 欧美在线观看一区| 亚洲男人的天堂在线| 亚洲国产精品小视频| 欧美激情精品久久久久久变态| 亚洲欧美视频在线观看视频| 91久久极品少妇xxxxⅹ软件| 亚洲欧美国产日韩天堂区| 亚洲美女区一区| 91久久久久久| 亚洲精品影视| 9l视频自拍蝌蚪9l视频成人 | 国产欧美高清| 国产精品久久久一区麻豆最新章节| 国产精品综合av一区二区国产馆| 欧美日韩另类丝袜其他| 欧美日韩亚洲一区二区三区在线观看 | av成人免费在线观看| 亚洲免费观看高清完整版在线观看熊 | 欧美一级久久| 久久久久久久久久码影片| 欧美国产日韩一区二区| 日韩午夜在线观看视频| 亚洲综合导航| 另类av一区二区| 欧美乱大交xxxxx| 国产精品天美传媒入口| 在线成人免费观看| 中文在线不卡视频| 女仆av观看一区| 亚洲午夜一区| 国产精品毛片一区二区三区| 亚洲二区在线视频| 久久成人资源| 亚洲午夜三级在线| 欧美aa在线视频| 欧美一区二区三区免费视频| 欧美色大人视频| 亚洲视频1区| 噜噜噜在线观看免费视频日韩| 欧美私人网站| 亚洲一区二区三区国产| 亚洲理伦电影| 欧美日韩国产一区二区三区地区| **性色生活片久久毛片| 欧美ed2k| 玖玖玖国产精品| 亚洲欧洲日韩在线| 欧美激情影音先锋| 欧美日本一区| 亚洲永久免费视频| 亚洲性av在线| 国产午夜精品理论片a级大结局 | 久久午夜国产精品| 亚洲国产精品久久久久秋霞蜜臀 | 一本色道久久综合亚洲精品小说 | 欧美在线一区二区| 久久久久久日产精品| 免费在线看成人av| 欧美四级在线观看| 亚洲免费av网站| 国产九色精品成人porny| 午夜精品久久久久久久99樱桃| 一区二区国产日产| 黄色av日韩| 欧美午夜剧场| 欧美在线观看www| 久久久九九九九| 亚洲永久视频| 麻豆成人在线| 久久久久久网站| 欧美大胆成人| 久久国产精品高清| 亚洲激情黄色| 午夜激情亚洲| 宅男噜噜噜66国产日韩在线观看| 一区二区黄色| 亚洲成色www8888| 永久免费精品影视网站| 亚洲一区二区三区视频播放| 91久久中文| 免费观看成人| 亚洲第一在线| 亚洲国产一区二区在线| 久久夜色撩人精品| 男人的天堂亚洲| 在线观看欧美日本| 蜜桃av一区二区| 模特精品裸拍一区| 91久久亚洲| 欧美日韩成人在线观看| 中文国产成人精品| 欧美一区二区三区的| 黄色一区二区三区| 欧美精品国产|