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

隨筆 - 25  文章 - 29  trackbacks - 0
<2006年5月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910

常用鏈接

留言簿(4)

隨筆分類(22)

隨筆檔案(25)

文章分類(2)

文章檔案(2)

相冊

最新隨筆

搜索

  •  

積分與排名

  • 積分 - 57096
  • 排名 - 405

最新評論

閱讀排行榜

評論排行榜

?1 template? < typename?T1,typename?T2 >
?2 class ?mypair?: public ?pair < T1,T2 >
?3 {
?4 public :
?5 ????inline?mypair?():pair() {} ;
?6 ????inline?mypair( const ?T1 & ?a, const ?T2? & ?b):pair < T1,T2 > (a,b) {} ;
?7 ????inline?mypair( const ?mypair < T1,T2 > ? & ?a):pair < T1,T2 > (a) {} ;
?8 ????friend?ostream & ? operator << ? < T1,T2 > (ostream & ?os,mypair < T1,T2 > ? & ?p);
?9 protected :
10 private :
11 }
;
12 template? < typename?T1,typename?T2 >
13 ostream & ? operator << (ostream & ?os,mypair < T1,T2 >& ?p)
14 {
15 ????os << " \n?cout?pair? " ;
16 ????os << endl << " ? " << p.first;
17 ????os << endl << " ? " << p.second;
18 ???? return ?os;
19 }

20 ?
21
22 int ?_tmain( int ?argc,?_TCHAR * ?argv[])
23 {
24 ????f();
25 ????mypair < int , float > ?a( 1 , 2.0333 );
26 ????mypair < int , float > ?b( 2 , 6.04343 );
27 ????mypair < int , float > ?c(b);
28 ????cout << a;
29 ????cout << b;
30 ????cout << c;
31 ????a.swap(b);
32 ????cout << a;
33 ????cout << b;
34
35 ????cout << (a == b);
36
37 ???? return ? 0 ;
38 }

39
#include <utility>
template <typename T1,typename T2>
class pair
{
??? 1.空構造
??? 2.雙參數構造
???? 3.拷貝構造
????? 4.swap交換
5.內含2個T1,T2型 變量(first ,second);
}
pair 是struct ,所有成員公有
template <typename T1,typename T2>

??? pair<T1,T2> make_pair(const T1&,const T2&)

?? 操作符重載模版
make_pair(a,b);//按值返回個pair< >對象;
make_pair<int,float >(a,b);

auto_ptr<T> ptr(new int);//智能指針類???

輔助函數模板
max ,min, swap
template<class Type>   void swap(      Type& _Left,       Type& _Right   );   #include <algorithm>


4個比較算子
#include <utility>
using namespace rel_ops;
就重載了這幾個算子

template<Class Type>   bool operator!=(      const Type& _Left,      const Type& _Right);template<class Type1, class Type2>   bool operator!=(      const pair<Type1, Type2>& _Left,      const pair<Type1, Type2>& _Right   );
非pair<> 的在 std::rel_ops中



?1以下是迭代器基類
?2template<class?_Category,
?3????class?_Ty,
?4????class?_Diff?=?ptrdiff_t,
?5????class?_Pointer?=?_Ty?*,
?6????class?_Reference?=?_Ty&>
?7????????struct?iterator
?8????{????//?base?type?for?all?iterator?classes
?9????typedef?_Category?iterator_category;
10????typedef?_Ty?value_type;
11????typedef?_Diff?difference_type;
12????typedef?_Diff?distance_type;????//?retained
13????typedef?_Pointer?pointer;
14????typedef?_Reference?reference;
15????}
;
16

?1template<class?_Ty>
?2????class?allocator
?3//基類,是個空結構
?4????????:?public?_Allocator_base<_Ty>
?5????{????//?generic?allocator?for?objects?of?class?_Ty
?6public:
?7????typedef?_Allocator_base<_Ty>?_Mybase;
?8????typedef?typename?_Mybase::value_type?value_type;
?9
10
11????typedef?value_type?_FARQ?*pointer;
12????typedef?value_type?_FARQ&?reference;
13????typedef?const?value_type?_FARQ?*const_pointer;
14????typedef?const?value_type?_FARQ&?const_reference;
15
16????typedef?_SIZT?size_type;
17????typedef?_PDFT?difference_type;
18
19????template<class?_Other>
20????????struct?rebind
21????????{????//?convert?an?allocator<_Ty>?to?an?allocator?<_Other>
22????????typedef?allocator<_Other>?other;
23????????}
;
24
25????pointer?address(reference?_Val)?const
26????????{????//?return?address?of?mutable?_Val
27????????return?(&_Val);
28????????}

29
30????const_pointer?address(const_reference?_Val)?const
31????????{????//?return?address?of?nonmutable?_Val
32????????return?(&_Val);
33????????}

34
35????allocator()
36????????{????//?construct?default?allocator?(do?nothing)
37????????}

38
39????allocator(const?allocator<_Ty>&)
40????????{????//?construct?by?copying?(do?nothing)
41????????}

42
43????template<class?_Other>
44????????allocator(const?allocator<_Other>&)
45????????{????//?construct?from?a?related?allocator?(do?nothing)
46????????}

47
48????template<class?_Other>
49????????allocator<_Ty>&?operator=(const?allocator<_Other>&)
50????????{????//?assign?from?a?related?allocator?(do?nothing)
51????????return?(*this);
52????????}

53
54????void?deallocate(pointer?_Ptr,?size_type)
55????????{????//?deallocate?object?at?_Ptr,?ignore?size
56????????operator?delete(_Ptr);
57????????}

58
59????pointer?allocate(size_type?_Count)
60????????{????//?allocate?array?of?_Count?elements
61????????return?(_Allocate(_Count,?(pointer)0));
62????????}

63
64????pointer?allocate(size_type?_Count,?const?void?_FARQ?*)
65????????{????//?allocate?array?of?_Count?elements,?ignore?hint
66????????return?(allocate(_Count));
67????????}

68
69????void?construct(pointer?_Ptr,?const?_Ty&?_Val)
70????????{????//?construct?object?at?_Ptr?with?value?_Val
71????????_Construct(_Ptr,?_Val);
72????????}

73
74????void?destroy(pointer?_Ptr)
75????????{????//?destroy?object?at?_Ptr
76????????_Destroy(_Ptr);
77????????}

78
79????_SIZT?max_size()?const
80????????{????//?estimate?maximum?array?size
81????????_SIZT?_Count?=?(_SIZT)(-1)?/?sizeof?(_Ty);
82????????return?(0?<?_Count???_Count?:?1);
83????????}

84????}
;
以上是.net 2003 中 iterator 和 allocator 的代碼
可以看出 stl是借助allocate 模板來分配元素 空間的?


一個自定義迭代器,和自定義容器

??1template<typename?item>
??2class?maniter;
??3
??4template?<typename?T>
??5class?man
??6{
??7public:
??8????typedef?maniter<T>?iterator?;
??9?????man()
?10????{
?11????????array=NULL;
?12????????size=0;
?13????}

?14????iterator?begin()
?15????{
?16????????iterator?*pt?=new?iterator;
?17????????pt->p=array;
?18????????return?*pt;
?19????}

?20????iterator?end()
?21????{
?22?????????iterator?*pt=new?iterator;
?23?????????pt->p=array+sizeof(T)*size;
?24?????????return?*pt;
?25????}

?26???????man(int?count)
?27????{
?28????????
?29????????array=new?T?[count];
?30
?31????????size=count;
?32????????for?(int?i=0;i<size;i++)
?33????????{
?34
?35????????????*(array+i)=i;
?36????????}

?37????
?38????}

?39????man(const?man&?a)
?40????{
?41
?42????????
?43????????if(this!=&a)
?44????????{
?45??????????????????????size=a.size;
?46????????
?47????????????try{
?48????????array=new?T[a.size];?
?49????????????}

?50????????????catch?(bad_alloc?e)?{
?51????????????????
?52????????????}

?53????????}

?54????????for?(int?i=0;i<a.size;i++)
?55????????{
?56????????????
?57????????????*(array+i)=a.array[i];
?58????????}

?59????????
?60????????
?61????}

?62????void?operator?=(const?man&?a)
?63????{
?64????????
?65????????
?66????????delete?[]?array;
?67????????array=new?T?[a.size];?
?68????????size=a.size;
?69????????for?(int?i=0;i<a.size;i++)
?70????????{
?71????????????*(array+i)=a.array[i];
?72????????}

?73????????
?74????????????//return?*this;
?75????}

?76????~man()
?77????{
?78????????delete?[]?array;
?79????????size=0;
?80????}

?81????man<T>&?operator++()
?82????{
?83???????????this->array++;
?84???????????return?*this;
?85????}

?86????const?man<T>?operator++(int?)
?87????{
?88????????man<T>?temp=*this;
?89????????????(this->array)++;
?90????????????????return?temp;
?91????}

?92???
?93protected:
?94????friend?ostream&?operator<<?<T>(ostream&?os,const?man<T>?&?a);
?95private:
?96????T?*?array;
?97????int?size;
?98}
;
?99template?<typename?T>
100ostream&?operator<<(ostream&?os,?const?man<T>&?a)
101{
102????cout<<"\n?in?printing?man"<<endl;
103????if?(!a.size)
104????{
105????????cout<<"\n"<<"?array?is?null";
106????}

107???????for?(int?i=0;i<a.size;i++)
108???????{
109???????????
110??????????os<<"?"<<a.array[i];
111???????}

112???????cout<<endl;
113???????return?os;
114?}

115
116template?<typename?it,typename?T>
117it?myfind(it?begin,?it?end?,?const?T&?a)
118{
119????for?(;begin!=end&&*begin!=a;++begin)
120????{}
121????return?begin;
122}

123?
124template<typename?item>
125class?maniter
126{
127public:
128????item*?p;
129????maniter():p(0)
130????{
131
132????}

133????item&?operator*(){return?*p;};
134????item*?operator->(){return?p;};
135????item&?operator++(){p++;return?*p;};
136????item?operator++(int){item?temp=*this;this++;return?temp;}
137????bool?operator==(const?maniter?&?ele)
138????{
139????????return?*p==*(ele.p);
140????}

141????bool?operator!=(const?maniter?&?ele)
142????{
143????????return?*p!=*(ele.p);
144????}

145
146protected:
147private:
148????
149}
;
150int?_tmain(int?argc,?_TCHAR*?argv[])
151{
152/*
153????vector<man<int>?>?a;
154for?(int?i=1;i<10;++i)
155????{
156????????cout<<"\n?"<<i;
157?????????man<int>*?manb=new?man<int>?(i);
158????????a.push_back(*manb);
159?????????delete?manb;
160????????
161????}
162??*/

163????man<int?>?b(5);
164????cout<<(*myfind(b.begin(),b.end(),3));//very?perfect,自定義迭代器成功實現
165?????//迭代器就是包含容器節點指針的類模板對象,提供?*,->,++,--,==,!=?(essential)操作的,這些操作需要迭代器
166????//對容器結構了解,如本列中maniter?就清楚知道man?類中的節點結構是個1維數組
167return?0;
168}

169
170
類型萃取技術(迭代器中廣泛使用的技術)

? template <typename T>
?? struct iterator
{
??? typedef T? value_type;
};
template <typename T>
?struct iterator_trait
{
?????typedef? T ?typename? T::iterator::value_type?? value_type;
};

template <typename T>
typename iterator_trait<T>::value_type
?f(T)
{};

???萃取機 iterator_trait<迭代器〉??快速的從迭代器中 取出 迭代器實際類型
(very important)
???????


posted on 2006-05-31 16:53 黃大仙 閱讀(1244) 評論(0)  編輯 收藏 引用 所屬分類: c++
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产亚洲欧洲997久久综合| 欧美日本一区二区三区| 亚洲国产日韩欧美在线动漫| 美女爽到呻吟久久久久| 亚洲国产你懂的| 久久国产一区| 亚洲国产高清自拍| 国产情侣一区| 欧美96在线丨欧| 在线视频日韩| 99v久久综合狠狠综合久久| 国产精品欧美日韩| 久久这里只精品最新地址| 国产日韩精品在线观看| 国产精品久久久久久久7电影| 日韩亚洲国产欧美| 久久久午夜电影| 国产婷婷成人久久av免费高清| 国产精品一区免费在线观看| 欧美日韩大片| 欧美日韩成人在线| 久久成人免费电影| 亚洲欧美另类在线观看| 午夜国产精品视频免费体验区| 亚洲国产99精品国自产| 国产日韩一区二区三区在线播放| 欧美精品成人91久久久久久久| 久久九九久精品国产免费直播| 欧美不卡三区| 欧美福利电影网| 欧美成人亚洲成人日韩成人| 西西人体一区二区| 老妇喷水一区二区三区| 亚洲精品一区二区三区蜜桃久 | 国产一区二区精品久久| 亚洲欧美精品一区| 毛片一区二区| 免费在线日韩av| 欧美成人小视频| 国产精品高潮粉嫩av| 国产精品日韩精品| 国产日韩欧美高清| 欧美激情bt| 国产精品成人观看视频国产奇米| 国产精品magnet| 久久精品在线播放| 国产精品一区视频网站| 久久婷婷国产综合精品青草 | 亚洲人成在线播放网站岛国| 亚洲高清在线播放| 99精品国产在热久久| 欧美不卡一卡二卡免费版| 欧美成人在线免费视频| 亚洲福利电影| 午夜视频一区在线观看| 亚洲日本va午夜在线影院| 野花国产精品入口| 久久精品亚洲国产奇米99| 国产精品嫩草久久久久| 国产一区二区日韩| 亚洲国产一区二区a毛片| 国产区亚洲区欧美区| 国产喷白浆一区二区三区 | 一区二区av| 午夜久久久久| 欧美大胆a视频| 美女国内精品自产拍在线播放| 免费久久久一本精品久久区| 欧美香蕉视频| 国产精品自在欧美一区| 久久精品视频网| 久久xxxx| 亚洲精品少妇网址| 欧美日韩综合在线| 在线观看国产一区二区| 亚洲一区制服诱惑| 亚洲综合成人在线| 欧美久久电影| 国产精品乱子久久久久| 日韩视频永久免费| 国产深夜精品福利| 一区二区欧美激情| 91久久久久久| 久久三级视频| 国产亚洲精品久久久久久| 欧美在线观看视频一区二区| 欧美性猛交xxxx免费看久久久 | 亚洲欧美在线免费| 亚洲电影免费在线 | 亚洲国产精品久久久久婷婷884| 另类激情亚洲| 亚洲欧美国产不卡| 欧美日韩国产区| 亚洲综合电影| 亚洲欧美日韩国产综合| 国产精品国产福利国产秒拍| 久久久久久色| 欧美在线视频网站| 国产精品色婷婷久久58| 欧美成人精品1314www| 玖玖视频精品| 在线免费观看日本一区| 99精品国产在热久久婷婷| 午夜精品久久久久久久99热浪潮| 欧美日韩一区成人| 亚洲香蕉网站| 在线视频精品一| 国产精品亚洲综合色区韩国| 亚洲欧美在线一区| 亚洲免费一在线| 国产日韩在线一区| 久久久久久999| 亚洲欧美一区在线| 99精品视频一区| 9人人澡人人爽人人精品| 亚洲欧美中文日韩v在线观看| 欧美成人精品1314www| 国产精品sss| 亚洲第一精品电影| 欧美日韩国产综合网| 夜夜嗨av一区二区三区网站四季av| 欧美中文字幕在线观看| 激情偷拍久久| 欧美国产免费| 91久久香蕉国产日韩欧美9色| 欧美日韩一区二区免费视频| 亚洲免费在线视频一区 二区| 欧美成人一区二区| 精品成人免费| 亚洲伦理在线免费看| 亚洲欧美国产高清va在线播| 亚洲欧美国产日韩中文字幕| 欧美一区视频| 国产一区二区高清不卡| 亚洲图片在线| 国产综合色产在线精品| 久久精品欧美日韩| 国产性色一区二区| 欧美不卡一区| 国产精品日韩精品欧美精品| 亚洲欧美另类久久久精品2019| 激情自拍一区| 99国产精品久久久久久久久久| 亚洲视频在线一区观看| 午夜精品国产更新| 亚洲精品自在久久| 欧美日韩亚洲一区二区三区在线| 欧美一区二区视频在线观看| 亚洲精品视频在线观看免费| 99pao成人国产永久免费视频| 欧美亚洲一区二区在线| 亚洲激情一区| 欧美日韩性生活视频| 嫩草国产精品入口| 国产精品久久久久av| 亚洲另类春色国产| 欧美体内she精视频在线观看| 久久亚洲欧美国产精品乐播| 国产精品二区三区四区| 亚洲伊人伊色伊影伊综合网| 亚洲欧洲免费视频| 欧美在线观看你懂的| 亚洲第一精品影视| 国产亚洲成精品久久| 一区二区成人精品| 欧美在线观看视频一区二区| 欧美激情91| 欧美国产精品一区| 久久国产精品久久久久久久久久 | 久久免费高清视频| 国内精品国产成人| 欧美自拍丝袜亚洲| 在线亚洲欧美| 欧美在线欧美在线| 国产视频久久| 欧美影片第一页| 国内精品视频666| 国产精品免费电影| 日韩视频免费大全中文字幕| 国产欧美精品国产国产专区| 久久亚洲私人国产精品va| 欧美一区二区三区的| 国内精品久久久久影院薰衣草| 欧美性理论片在线观看片免费| 久久综合激情| 在线国产亚洲欧美| 欧美一区二区在线免费观看| 亚洲另类黄色| 一区二区三区回区在观看免费视频| 中文精品视频一区二区在线观看| 玖玖玖免费嫩草在线影院一区| 国产欧美一区二区精品仙草咪| 亚洲欧美在线观看| 欧美一进一出视频| 国产亚洲精品7777| 久久精品一二三区| 欧美亚洲日本国产| 亚洲一卡二卡三卡四卡五卡| 国产精品爱久久久久久久| 欧美影院视频|