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

C++ Programmer's Cookbook

{C++ 基礎(chǔ)} {C++ 高級} {C#界面,C++核心算法} {設(shè)計模式} {C#基礎(chǔ)}

Performance of Iteration Methods (very good)

I've been implementing numerical libraries in .NET and have come to some conclusions about iteration performance. My classes have to hold a large amount of data and be able to iterate through that data as quickly as possible. In order to compare various methods, I created a simple class called Data that encapsulates an array of doubles.

Download source - 6 Kb

Method #1: Enumeration

Data implements IEnumerable. It contains GetEnumerator which returns its own DataEnumerator, an inner class.
public IEnumerator GetEnumerator()
????{
???? returnnew DataEnumerator(this);
????}
????
????internalclass DataEnumerator : IEnumerator
????{
???? private Data internal_=null;
???? privateintindex=-1;

???? public DataEnumerator( Data data)
???? {
????????internal_=data;
???? }

???? publicobject Current
???? {
????????get
????????{
???????? returninternal_.Array[index];
????????}
???? }

???? publicbool MoveNext()
???? {
????????index++;
????????if(index >=internal_.Array.Length )
????????{
???????? returnfalse;
????????}
????????returntrue;
???? }

???? publicvoid Reset()
???? {
????????index=-1;
???? }
????}

Method #2: Indexing

I implemented an index operator on the class which simply calls the index operator on the array.

????publicdoublethis[intposition]
????{
???? get
???? {
????????returnarray_[position];
???? }
????}

Method #3: Indirect Array

I created a property to access the array.

????publicdouble[] Array
????{
???? get
???? {
????????returnarray_;
???? }
????}
When iterating, I called the Array property and then its index operator.
d = data.Array[j];

Method #3: Direct Array

I created a reference to the array.

double[] array = data.Array;
Then, I iterate through that reference.
d = array[j];

Method #4: Pointer Math

Finally, I tried improving performance by iterating through the array in Managed C++ using pointer manipulation.

????????staticvoiditerate( Data&data)
????????{
???????? double d;
???????? double__pin*ptr=&(data.Array[0]);
???????? for(int i =0; i < data.Array.Length; i++)
???????? {
????????????d =*ptr;
????????????++ptr;
???????? }
????????}
I called it this way:
Pointer.iterate( data );

Conclusions

To test the different methods, I allocated 1,000,000 doubles into an array and indexed over all of them. I repeated this 1,000 times to minimize randomness. Here are the results...

Results

Enumeration is always slow. That's not surprising as I'm using a general data structure to hold the doubles. Each access performs a cast. The three operator/property methods differed very slightly. These are probably all optimized similarly. Using pointer math to traverse over the raw data was significantly faster. This is probably due to the fact that there's no bounds checking. In summary, if you have large amounts of data and performance is critical, consider using managed C++.

超級collection類:

using?System;
using?System.Collections;

namespace?Iterations
{
??
public?class?Data?:?IEnumerable
??
{
????
private?double[]?array_;

????
public?Data(int?size)?
????
{
??????array_?
=?new?double[size];
??????Random?random?
=?new?Random();
??????
for?(?int?i?=?0;?i?<?size;?i++?)
??????
{
????????array_[i]?
=?random.Next();
??????}

????}


????
public?double?this[int?position]
????
{
??????
get
??????
{
????????
return?array_[position];
??????}

????}


????
public?double[]?Array
????
{
??????
get?
??????
{
????????
return?array_;
??????}

????}


????
public?IEnumerator?GetEnumerator()?
????
{
??????
return?new?DataEnumerator(?this?);
????}

????
????
internal?class?DataEnumerator?:?IEnumerator
????
{
??????
private?Data?internal_?=?null;
??????
private?int?index?=?-1;

??????
public?DataEnumerator(?Data?data?)?
??????
{
????????internal_?
=?data;
??????}


??????
public?object?Current
??????
{
????????
get
????????
{
??????????
return?internal_.Array[index];
????????}

??????}


??????
public?bool?MoveNext()
??????
{
????????index
++;
????????
if?(?index?>=?internal_.Array.Length?)?
????????
{
??????????
return?false;
????????}

????????
return?true;
??????}


??????
public?void?Reset()
??????
{
????????index?
=?-1;
??????}

????}

??}

}
test code:
using?System;
using?System.Collections;

using?Iterations;

namespace?Test
{
??
class?Test
??
{
????
private?double?d;
????
private?int?reps;
????
private?int?size;
????
private?double?seconds;
????
private?Data?data?=?null;
????
private?DateTime?before;
????
private?TimeSpan?total;

????[STAThread]
????
static?void?Main(string[]?args)
????
{
??????Test?test;
??????
if?(?args.Length?>?1?)?
??????
{
????????test?
=?new?Test(?int.Parse(?args[0]?),?int.Parse(?args[1]?));
??????}
?
??????
else?
??????
{
????????test?
=?new?Test();
??????}

??????test.TestAll();
????}


????
public?Test()?:?this(?1000,?1000000?)
????
{
????}


????
public?Test(?int?reps,?int?size?)
????
{
??????
this.reps?=?reps;
??????
this.size?=?size;
??????data?
=?new?Data(?size?);
????}


????
private?void?TestAll()
????
{
??????System.Console.WriteLine();
??????System.Console.WriteLine(?
"repetitions:?"?+?reps?);
??????System.Console.WriteLine(?
"iterations:?"?+?size.ToString(?"e"?));
??????System.Console.WriteLine();
??????TestEnumeration();
??????TestIndexing();
??????TestIndirectArrays();
??????TestDirectArrays();
??????TestPointerMath();
??????System.Console.WriteLine();
????}


????
private?void?TestEnumeration()?
????
{
??????total?
=?new?TimeSpan(?0?);
??????
for?(?int?i?=?0;?i?<?reps;?i++?)?
??????
{
????????before?
=?DateTime.Now;
????????IEnumerator?enumerator?
=?data.GetEnumerator();
????????
while?(?enumerator.MoveNext()?)?
????????
{
??????????d?
=?(double)?enumerator.Current;
????????}

????????total?
+=?DateTime.Now?-?before;
??????}

??????seconds?
=?total.Seconds?+?(?total.Milliseconds?/?1000.0?);
??????System.Console.WriteLine(?
"Enumeration:?\t\t"?+?seconds?+?"?seconds"?);
????}


????
private?void?TestIndexing()
????
{
??????total?
=?new?TimeSpan(?0?);
??????
for?(?int?i?=?0;?i?<?reps;?i++?)?
??????
{
????????before?
=?DateTime.Now;
????????
for?(?int?j?=?0;?j?<?size;?j++?)
????????
{
??????????d?
=?data[j];
????????}

????????total?
+=?DateTime.Now?-?before;
??????}

??????seconds?
=?total.Seconds?+?(?total.Milliseconds?/?1000.0?);
??????System.Console.WriteLine(?
"Indexing:?\t\t"?+?seconds?+?"?seconds"?);??????
????}


????
private?void?TestIndirectArrays()
????
{
??????total?
=?new?TimeSpan(?0?);
??????
for?(?int?i?=?0;?i?<?reps;?i++?)?
??????
{
????????before?
=?DateTime.Now;
????????
for?(?int?j?=?0;?j?<?size;?j++?)
????????
{
??????????d?
=?data.Array[j];
????????}

????????total?
+=?DateTime.Now?-?before;
??????}

??????seconds?
=?total.Seconds?+?(?total.Milliseconds?/?1000.0?);
??????System.Console.WriteLine(?
"Indirect?Arrays:?\t"?+?seconds?+?"?seconds"?);?
????}


????
private?void?TestDirectArrays()
????
{
??????total?
=?new?TimeSpan(?0?);
??????
for?(?int?i?=?0;?i?<?reps;?i++?)?
??????
{
????????before?
=?DateTime.Now;
????????
double[]?array?=?data.Array;
????????
for?(?int?j?=?0;?j?<?size;?j++?)
????????
{
??????????d?
=?array[j];
????????}

????????total?
+=?DateTime.Now?-?before;
??????}

??????seconds?
=?total.Seconds?+?(?total.Milliseconds?/?1000.0?);
??????System.Console.WriteLine(?
"Direct?Arrays:?\t\t"?+?seconds?+?"?seconds"?);
????}


????
private?void?TestPointerMath()
????
{
??????total?
=?new?TimeSpan(?0?);
??????
for?(?int?i?=?0;?i?<?reps;?i++?)?
??????
{
????????before?
=?DateTime.Now;
????????Pointer.iterate(?data?);
????????total?
+=?DateTime.Now?-?before;
??????}

??????seconds?
=?total.Seconds?+?(?total.Milliseconds?/?1000.0?);
??????System.Console.WriteLine(?
"Pointer?Math:?\t\t"?+?seconds?+?"?seconds"?);
????}

????}

}

posted on 2006-04-14 12:50 夢在天涯 閱讀(368) 評論(0)  編輯 收藏 引用 所屬分類: C#/.NET

公告

EMail:itech001#126.com

導(dǎo)航

統(tǒng)計

  • 隨筆 - 461
  • 文章 - 4
  • 評論 - 746
  • 引用 - 0

常用鏈接

隨筆分類

隨筆檔案

收藏夾

Blogs

c#(csharp)

C++(cpp)

Enlish

Forums(bbs)

My self

Often go

Useful Webs

Xml/Uml/html

搜索

  •  

積分與排名

  • 積分 - 1817676
  • 排名 - 5

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              国产精品高潮久久| 国产精品白丝av嫩草影院| 久久阴道视频| 欧美在线综合| 久久av一区二区三区亚洲| 欧美制服丝袜第一页| 久久爱91午夜羞羞| 久久久噜噜噜久噜久久| 久色婷婷小香蕉久久| 男人的天堂亚洲| 欧美高清一区| 国产精品videosex极品| 国产精品美女一区二区在线观看 | 欧美国内亚洲| 亚洲国产毛片完整版 | 亚洲国产导航| 亚洲精品中文字幕有码专区| 亚洲欧洲偷拍精品| 99国产精品自拍| 亚洲一区视频在线| 久久精品国产精品亚洲综合| 久久综合狠狠综合久久综青草| 巨胸喷奶水www久久久免费动漫| 欧美成人精品不卡视频在线观看| 欧美电影免费网站| 亚洲精品在线三区| 午夜综合激情| 美女国内精品自产拍在线播放| 欧美精品在线视频观看| 国产精品久久久久久久9999| 国产一区二区三区免费不卡| 亚洲成色777777在线观看影院 | 美女诱惑黄网站一区| 亚洲高清三级视频| 亚洲一区二区免费视频| 久久久福利视频| 欧美人交a欧美精品| 欧美日韩精品一区二区三区四区| 国产精品久久一级| 在线色欧美三级视频| 在线性视频日韩欧美| 久久精品视频免费播放| 亚洲国产精品一区二区第一页| 一区二区日韩欧美| 卡一卡二国产精品| 国产精品私人影院| 日韩视频一区二区三区在线播放免费观看 | 亚洲第一搞黄网站| 亚洲——在线| 免费精品视频| 亚洲一区二区久久| 欧美精品激情在线观看| 国产日韩精品一区| 国产精品99久久久久久久vr | 欧美日韩不卡| 亚洲第一二三四五区| 欧美一区二区| 亚洲伦伦在线| 美日韩免费视频| 国产偷国产偷精品高清尤物| 99精品视频一区| 免费人成网站在线观看欧美高清| 亚洲一区二区三区影院| 欧美激情亚洲综合一区| 一区二区在线观看av| 午夜亚洲影视| 9l视频自拍蝌蚪9l视频成人 | 亚洲第一二三四五区| 久久精品99国产精品酒店日本| 亚洲人体影院| 美日韩免费视频| 极品尤物一区二区三区| 欧美一区三区三区高中清蜜桃| 亚洲精品一品区二品区三品区| 久久久综合香蕉尹人综合网| 国产欧美视频在线观看| 亚洲午夜精品| 亚洲精品国产系列| 久热精品在线| 亚洲国产精品福利| 久久综合九色欧美综合狠狠| 亚洲欧美在线高清| 国产精品久久久久av免费| 一本色道久久| 亚洲精品国偷自产在线99热| 欧美1区视频| 亚洲国产另类精品专区| 免费日韩成人| 久久理论片午夜琪琪电影网| 国产亚洲综合在线| 久久久精品久久久久| 亚洲欧美日韩综合aⅴ视频| 国产精品久久久一区麻豆最新章节 | 日韩视频免费观看高清完整版| 麻豆精品一区二区综合av | 欧美中文字幕在线观看| 国产欧美91| 久久精品人人做人人综合| 亚洲制服av| 国产精品影视天天线| 欧美在线视频a| 性欧美8khd高清极品| 国产一区二区精品丝袜| 久久精品视频播放| 久久人人97超碰国产公开结果| 韩日视频一区| 欧美成人精品福利| 欧美成人免费播放| 一区二区欧美日韩视频| 一区二区久久久久| 国产精品一区二区三区四区 | 国产精品乱码妇女bbbb| 亚洲欧美日韩在线观看a三区| 亚洲一区二区黄色| 国产一区清纯| 欧美第一黄色网| 欧美大片在线观看一区| 一本色道**综合亚洲精品蜜桃冫 | 久久久蜜臀国产一区二区| 久久精品免费看| 亚洲欧洲精品一区二区精品久久久| 亚洲高清网站| 国产精品久久久久久影院8一贰佰 国产精品久久久久久影视 | 亚洲欧洲一区二区在线观看| 欧美日韩专区在线| 久久国产一区二区| 麻豆精品精华液| 一区二区三区精品视频| 亚洲女性裸体视频| 激情视频一区| 亚洲精品一区在线观看| 国产精品欧美风情| 久热国产精品视频| 欧美日产在线观看| 欧美综合国产精品久久丁香| 久久综合九色99| 中文一区字幕| 久久久久久久综合色一本| 亚洲精品小视频| 亚洲欧美日韩网| 亚洲青涩在线| 亚洲欧美精品suv| 亚洲激情欧美激情| 亚洲一区国产视频| 亚洲国产精品成人综合色在线婷婷| 亚洲免费观看| 伊人蜜桃色噜噜激情综合| 99成人免费视频| 在线观看中文字幕亚洲| 中文精品视频| 亚洲激情综合| 香蕉久久一区二区不卡无毒影院 | 亚洲精品一区二区网址| 午夜精品短视频| av成人免费在线观看| 欧美一级淫片aaaaaaa视频| 亚洲日本欧美| 欧美中文字幕精品| 亚洲欧美日韩一区二区三区在线| 久久久久www| 亚洲欧美一区二区三区极速播放 | 欧美精选在线| 国产精品入口66mio| 欧美国产日韩一二三区| 国产欧美综合一区二区三区| 亚洲三级免费| 在线观看91精品国产入口| 亚洲永久在线| 一本一本久久a久久精品综合妖精| 久久国产精品免费一区| 亚洲欧美在线高清| 欧美日韩成人精品| 亚洲国产视频一区| 伊人久久大香线蕉综合热线| 亚洲视频专区在线| 99ri日韩精品视频| 美女精品在线观看| 蜜桃久久精品乱码一区二区| 国产精品一二三四| 夜夜嗨av色综合久久久综合网| 亚洲精品一区二区三区福利| 久久精品国产欧美亚洲人人爽| 亚洲欧美日韩中文视频| 欧美视频一区二| 日韩午夜在线| 99这里只有久久精品视频| 免费观看国产成人| 免费国产自线拍一欧美视频| 韩日精品视频一区| 久久国产欧美精品| 久久久久久9| 国内成人精品一区| 欧美在线播放| 久久精品国产久精国产思思| 国产精品美女黄网| 亚洲一卡二卡三卡四卡五卡| 亚洲一级二级在线| 欧美午夜不卡| 亚洲综合第一| 欧美一区二区三区电影在线观看|