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

沐楓小筑(C++)

愛老婆,要比編程多一點...

  C++博客 :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
  18 Posts :: 0 Stories :: 84 Comments :: 0 Trackbacks

公告

沐楓的個人主頁

eoool.com生成

eoool.com生成

常用鏈接

留言簿(8)

我參與的團(tuán)隊

搜索

  •  

積分與排名

  • 積分 - 57590
  • 排名 - 404

最新評論

閱讀排行榜

評論排行榜

    一直在使用C/C++,對于循環(huán)語句while、do while、for,對于for情有獨鐘,因為其簡潔、清晰、靈活。訪問數(shù)組類型的變量,只有for寫出來的語句是最易于閱讀的,如:
int arr[N] = {/**/};
for(int i = 0; i < N; ++i)
  printf(
"arr[%d] = %d\n", i, arr[i]);

    然而,這種情況,到了STL時,就有些變味了:
for(vector<MyClass>::const_iterator iter = m_vecData.begin(); iter != m_vecData.end(); ++iter)
{
    
if(!iter->IsBusy())
        iter
->DoSomeThing(param);
}
    這么長的一個for,不再給人一種清晰的感覺了?;蛟S因為這個程序比較短,還沒有太大的感覺,當(dāng)回頭去看自已的程序中,有不少這樣的寫法時,我就覺得一陣心煩。改改?
for(size_t i = 0; i < m_vecData.size(); ++i)
{
    
if(!m_vecData[i].IsBusy())
        m_vecData[i].DoSomeThing(param);
}
    不錯,還是簡單點好啊。但是因為這里舉的是vector的例子。如果是list或是別的什么容器,就行不通了。
    其它的高級語言,都提供了foreach或是for in語句,寫出來就很清晰:
foreach(item in m_vecData)
{
    
if(!item.IsBusy())
        item.DoSomeThing(param);
}
    C++是不是也可以這么簡單?好象STL中也有一個for_each,試著改寫一下:
struct IfNotBusyThenDoSomeThing
{
   
IfNotBusyThenDoSomeThing(const Param& param)
        : param_(param)
    {}
    
void operator() (const MyClass& item)
    {
        
if(!item.IsBusy())
            item.DoSomeThing(param_);
    }
private:
    
const Param& param_;
};

for_each(m_vecData.begin(), m_vecData.end(),
IfNotBusyThenDoSomeThing(param));
    不錯,for語句簡單了,但是卻多了IfNotBusyThenDoSomeThing的定義,這代碼可是多了好幾倍。要是每個循環(huán)都要來這么一下,我還不如直接寫for,要來得爽快一些?;蛟S還有別的辦法:
vector<MyClass> notBusyClass;
remove_copy_if(m_vecData.begin(), m_vecData.end(), inserter(notBusyClass, notBusyClass.begin()), mem_fun_ref(
&MyClass::IsBusy));
for_each(notBusyClass.begin(), notBusyClass.end(), bind2nd(mem_fun_ref(
&MyClass::DoSomeThing), param));
    天哪,這種寫法好象更恐怖。而且,還不是每種情況都能用的:
    1. notBusyClass不能是vector<const MyClass&>,因為不能建立指向引用的指針。這就要求MyClass是可拷貝的。但就算是可拷貝的,有時候拷貝成本也是很高的。
    2. MyClass::DoSomeThing的參數(shù)不能是引用(我們常定義參數(shù)為:const Param&),因為不能定義引用的引用這種類型。
    3. 一旦出現(xiàn)錯誤,這錯誤信息會讓人極其昏倒。

    看來單靠標(biāo)準(zhǔn)C++是不成的。Boost的lambda的庫似乎很不錯,用用:
    for_each(m_vecData.begin(), m_vecData.end(),
        if_then( !bind(
&MyClass::IsBusy, _1),
            bind(
&MyClass::DoSomeThing, _1, param)));
    不錯,好了一些,但是還是很不好看。有沒有更好的?有,boost1.34新加入的BOOST_FOREACH:
BOOST_FOREACH(cosnt MyClass& item, m_vecData)
{
    
if(!item.IsBusy())
        item.DoSomeThing(param);
}
    Oh Yeah!

    好了,問題來了,為什么C++不直接在語言中提供foreach這個功能呢?
    個人認(rèn)為,原因有幾點:
    1. C/C++除了數(shù)組外,沒有內(nèi)置的容器,因此for語句足矣。
    2. 當(dāng)C++進(jìn)化到STL的時候,C++標(biāo)準(zhǔn)委員會根本沒空去考慮其它的。
    而其它高級語言之所以內(nèi)置了foreach,就是因為它們一開始就提供了標(biāo)準(zhǔn)的容器庫和迭代/枚舉接口,因此提供foreach就順理成章了。

    現(xiàn)在,總算C++開始考慮,由模板引入而造成的代碼復(fù)雜性的問題,這的確是Cpper的福音。因此,一系列相關(guān)的提案被提交。牽涉到上面代碼中的提案就有: DecltypeLambda expressions and closures for C++proposal for new for-loop?! ?br>    其中,最符合foreach要求的就是新的for循環(huán)。采用這個語句,上面的程序就可以這么寫:
for(const MyClass& item : m_vecData)
{
    
if(!item.IsBusy())
        item.DoSomeThing(param);
}

    不過,考慮到Decltype&auto提案已經(jīng)被采納,新的for-loop就不知道能不能再被采納。因為使用Decltype&auto后,程序可以這么寫:
for(auto iter = m_vecData.begin(), end = m_vecData.end(); iter != end; ++iter)
{
    if(!iter->IsBusy())
        iter->DoSomeThing(param);
}
    似乎還是復(fù)雜點是吧?但是有了decltype&auto后,foreach功能可以用程序庫或宏的形式被模擬,BOOST_FOREACH就是這么做的。具體模擬的方式<<proposal for new for-loop>>提案寫的很清楚了。
    同時,假如lambda提案要是能再被通過的話,那就真的要開心了:
for_each(
  m_vecData, 
  
<>(item) extern(param)
  {
    
if(!item.IsBusy())
        item.DoSomeThing(param);
  }
);
    Cool!

    不過,VC++2008倒是增加了foreach功能,不過關(guān)鍵字不是foreach,而是for each,這個讓人有點郁悶.要用的時候最好用宏定義替換一下,免得可移植性上出現(xiàn)問題.

posted on 2007-09-26 19:51 沐楓 閱讀(17022) 評論(11)  編輯 收藏 引用 所屬分類: C++

Feedback

# re: 從for到foreach 2007-09-26 22:05 danielwyo
for(vector<MyClass>::const_iterator iter = m_vecData.begin(); iter != m_vecData.end(); ++iter)
{
if(!iter->IsBusy())
iter->DoSomeThing(param);
}
----------------------------------
這個用的最多的了, 也很直觀吧, 干嘛一定要強調(diào)使用foreach呢? 至于對C++新版本的期待, 我已經(jīng)不抱希望了, 所謂的C++0x也不知道N年才出來, 而正式可以廣泛使用的編譯器, 那更是不知道要到什么時間了.   回復(fù)  更多評論
  

# re: 從for到foreach 2007-09-27 06:29 danielwyo
突然注意到了, 你的名字是ly, 跟我老婆的簡寫一樣. 后面一個liny, 一看更象.   回復(fù)  更多評論
  

# re: 從for到foreach 2007-09-27 08:33 螞蟻終結(jié)者
用for來處理container確實比較麻煩,有時候for語句還得折行。
估計新的特性可能還要等不少時間...  回復(fù)  更多評論
  

# re: 從for到foreach 2007-09-27 15:13 沐楓
并非完全要期待C++0x,那玩意兒至少要2年呢。

主要是為了希望能提高c++代碼的可讀性。
10多年前,剛學(xué)習(xí)C++的時候,為其傾倒,首要的,也是它在語言級上支持類,使得數(shù)據(jù)與算法的封裝變得直觀。
后來又加上函數(shù)重載和操作符重載,使得表達(dá)式變得簡單清晰。
再后來,模板的出現(xiàn),使得消除重復(fù)代碼的同時還可以得到類型安全的保證。
這一切都是喜歡C++的理由。

然后,最終發(fā)現(xiàn),這一切也變成容易寫出壞味道甚至難以維護(hù)的代碼的禍?zhǔn)住++語法太過于低級,沒有更高一級的抽象,造成了對很多人最終難學(xué)難用難看的印象和后果。

既然無法從語法級別上進(jìn)行改進(jìn),那就只好從程序庫中補充。因此,象BOOST等一系列的庫,都在這上面花了不少力氣。有許多人說這些庫用的“技巧"旁門左道,因此而抵制。事實上,它們只是為了能夠讓別的人不需要用很深刻的技巧,而打造了一批讓我們可以很順手使用的程序庫。

foreach 如此,format和assign如此,lambda,functional,bind,xpressive 等等,無不如此。

正是這些庫能簡化并提高程序設(shè)計的效率和可讀性,才有了C++0x的提案和實踐,也才有了C++語言的進(jìn)化。  回復(fù)  更多評論
  

# re: 從for到foreach 2007-09-27 16:12 沐楓
@danielwyo
姓林的重名的實在是沒有辦法避免,我周圍常能找到重名的。更何況拼音。
---
上面的例子實在是簡單,因此,還不覺得那個iterator循環(huán)難看到哪去。一旦復(fù)雜度提高了,再那么寫就很不順眼了。
既使用foreach,也頂多改善一些罷了。

倒是對于.net引入的LINQ語法,很是向往。SQL當(dāng)初面世的時候,曾被推寵,但直到今天也僅用于數(shù)據(jù)庫。真正開始在一般的程序設(shè)計上普及,看來看去也只有LINQ了。

象上面的例子,用C#3.0寫就是:
m_vecData
  .
Where(item => !item.IsBusy())
  .
All(item => item.DoSomeThing(param));
LINQ則:
var s = from item in m_vecData
        
where !item.IsBusy()
        
select item;
s.
All(item => item.DoSomeThing(param));

如果是用Ruby:
m_vecData.each {|item| !item.IsBusy() and item.DoSomeThing(param)}
  回復(fù)  更多評論
  

# re: 從for到foreach 2007-09-27 18:35 danielwyo
具體的情況確實不好說, 而針對復(fù)雜的for循環(huán), foreach也會變得復(fù)雜. 我覺得其實這個并沒有占有多少優(yōu)勢.

而sql語法本身有一定的缺陷, 被推崇為最新代語法, 其實在軟件開發(fā)上并不占有優(yōu)勢, 個人認(rèn)為, 它僅僅是更加接近英語語法而已, 并不是什么重要的改進(jìn). 很多人接觸sql語法也并沒有覺得比其它語法好學(xué).

其實我就是你上面提到的抵制那些庫的人, 不過boost還好, 至少其中的regex等比較實用的東西我還是用的比較多. 我還是更加喜歡ace這種更加實用的產(chǎn)品.   回復(fù)  更多評論
  

# re: 從for到foreach 2007-09-27 22:15 missdeer
感覺BOOST_FOREACH好像可能會有性能問題、、
不過std::for_each+boost::bind/boost::lambda簡直就是無敵~  回復(fù)  更多評論
  

# re: 從for到foreach 2007-09-27 22:53 沐楓
@missdeer
好象、可能,這個說的很不地道。
性能的確會稍差,但差的是常數(shù)級別。循環(huán)體內(nèi)是不差的。也就是說,大多數(shù)情況下可以忽略。  回復(fù)  更多評論
  

# re: 從for到foreach 2007-10-23 16:03 阿鐵
沐楓,你好!
不提供foreach,就沒有限制了,那么你想diy個forloop也行了.  回復(fù)  更多評論
  

# re: 從for到foreach[未登錄] 2010-05-17 10:14 123
for_each 性能比 純for加上迭代要高一些  回復(fù)  更多評論
  

# re: 從for到foreach 2011-01-26 16:43 mickey
C++從VS2005之后就有for each的啊。
vector<MyClass> myVector;
for each(auto element in myVector)
{
//xxx
}  回復(fù)  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美人与性禽动交情品 | 国产伦精品一区二区三区视频孕妇| 久久九九热re6这里有精品| 亚洲欧美视频| 亚洲图片欧洲图片日韩av| 欧美黄色片免费观看| 欧美激情视频给我| 一本一本a久久| 午夜精品久久久久久99热软件| 亚洲天堂男人| 欧美一区二区精品久久911| 久久激情视频久久| 久久一区二区精品| 欧美精品免费在线| 国产日韩欧美中文| 亚洲国产婷婷| 亚洲一区二区精品在线| 欧美主播一区二区三区| 欧美~级网站不卡| 正在播放亚洲| 另类激情亚洲| 国产精品久久久久婷婷| 在线观看日韩av| 中国女人久久久| 久久久精品一区| 亚洲九九精品| 久久精品人人做人人综合| 欧美精品免费视频| 国外成人在线| 亚洲影视在线播放| 亚洲二区三区四区| 亚洲一区二区三区精品视频| 免费在线国产精品| 国产欧美日韩免费| 在线视频欧美日韩| 免费人成精品欧美精品| 午夜精品福利在线观看| 欧美日韩午夜视频在线观看| 精品动漫3d一区二区三区免费| 亚洲香蕉在线观看| 亚洲欧洲综合另类| 欧美在线91| 国产精品亚洲综合天堂夜夜| 日韩视频精品| 欧美激情第4页| 久久久.com| 国模精品一区二区三区色天香| 亚洲国产精品第一区二区| 日韩一级精品视频在线观看| 久久国产主播精品| 一区二区毛片| 欧美日韩国产综合一区二区| 亚洲高清自拍| 免费成人你懂的| 久久在线视频在线| 在线精品国产欧美| 免播放器亚洲| 久久精品日产第一区二区| 国产欧美一区二区三区国产幕精品| 亚洲伦理在线| 亚洲国产成人在线| 欧美寡妇偷汉性猛交| 91久久视频| 亚洲激情自拍| 欧美日韩视频第一区| 一区二区三区不卡视频在线观看| 亚洲激情在线视频| 欧美视频中文一区二区三区在线观看| 99国产麻豆精品| aⅴ色国产欧美| 国产精品每日更新| 久久久精彩视频| 玖玖国产精品视频| 亚洲精品乱码久久久久久黑人| 欧美肥婆在线| 欧美精品一区二区三区四区| 亚洲视频 欧洲视频| 亚洲深夜av| 国产日韩欧美亚洲一区| 久久天堂精品| 久久综合狠狠综合久久综青草| 亚洲激情欧美激情| av成人免费观看| 国产一区二区高清视频| 亚洲国产精品美女| 欧美性猛交一区二区三区精品| 午夜精品一区二区在线观看| 亚洲欧美文学| 亚洲黄色尤物视频| 在线亚洲欧美视频| 国内精品模特av私拍在线观看| 男人插女人欧美| 欧美午夜在线一二页| 久久一区二区三区四区| 欧美日韩高清在线| 久久婷婷久久| 欧美性久久久| 亚洲高清视频在线| 国产偷自视频区视频一区二区| 欧美成人国产一区二区| 欧美亚洲成人精品| 免费成人av在线看| 国产精品99一区二区| 久热精品在线| 国产精品看片资源| 亚洲经典视频在线观看| 国产亚洲欧美日韩美女| 99热这里只有成人精品国产| 激情久久五月| 亚洲欧美日韩精品久久久| 宅男噜噜噜66国产日韩在线观看| 欧美不卡高清| 国产精品日韩电影| 最新69国产成人精品视频免费| 国产精品视频观看| 亚洲三级色网| 亚洲高清在线观看| 亚洲一区二区精品视频| 亚洲伦理精品| 久久综合狠狠综合久久综青草| 欧美一二三区精品| 欧美午夜精品久久久久久久| 亚洲国产日韩综合一区| 在线观看一区| 久久精品人人爽| 久久久久久伊人| 国产伦精品一区二区三区四区免费 | 欧美私人网站| 欧美国产日韩一区二区在线观看| 国产亚洲欧美激情| 欧美一级在线亚洲天堂| 亚洲欧美日韩国产中文在线| 欧美久久久久久久| 亚洲日产国产精品| 日韩一级欧洲| 欧美日本韩国一区| 亚洲美女一区| 中文欧美字幕免费| 欧美体内she精视频| 亚洲网址在线| 欧美一区二区成人| 国产欧美日韩伦理| 久久精品国产一区二区电影| 久久激情网站| 韩国视频理论视频久久| 久久久xxx| 女人色偷偷aa久久天堂| 亚洲国产精品久久久久秋霞影院 | 一区二区三区日韩精品视频| 在线中文字幕一区| 国产精品成人一区二区| 一本到高清视频免费精品| 亚洲午夜精品视频| 国产午夜精品全部视频在线播放| 欧美在线免费视频| 欧美大片免费观看| 日韩亚洲欧美成人| 国产精品视频导航| 久久综合婷婷| 9l国产精品久久久久麻豆| 久久丁香综合五月国产三级网站| 黄色成人在线网址| 欧美激情久久久| 亚洲欧美中文日韩v在线观看| 久久久久久网址| 日韩视频在线免费观看| 国产麻豆精品theporn| 久色成人在线| 亚洲男女自偷自拍图片另类| 午夜亚洲性色视频| 久久久精品久久久久| 国产精品久久午夜夜伦鲁鲁| 亚洲欧美伊人| 欧美成人精品三级在线观看| 99精品欧美一区二区蜜桃免费| 欧美日韩一区在线观看| 欧美亚洲网站| 亚洲精品乱码久久久久久| 亚洲欧美一级二级三级| 亚洲国产日韩一区二区| 国产乱码精品一区二区三区忘忧草 | 欧美激情一区二区三区蜜桃视频 | 亚洲一区二区三区高清不卡| 好看的日韩av电影| 欧美视频在线观看 亚洲欧| 免费成人高清| 校园春色国产精品| 亚洲精品自在久久| 免费在线亚洲欧美| 久久国产精品99久久久久久老狼 | 欧美精品国产精品| 久久久亚洲综合| 亚洲一区二区在线| 日韩一级成人av| 亚洲国产欧美一区二区三区丁香婷| 香蕉尹人综合在线观看| 亚洲开发第一视频在线播放| 韩国欧美国产1区| 国产偷国产偷精品高清尤物| 欧美日韩综合在线|