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

Lyt
posts - 16,comments - 61,trackbacks - 0

繼前天湊動態(tài)多維數(shù)組失敗后,經(jīng)指導(dǎo),終于將其實(shí)現(xiàn)。

把數(shù)組的維度一并放在模板里,而不用構(gòu)造函數(shù)來實(shí)現(xiàn),于是定義Array看起來像下邊這樣,其中NewArray是一個(gè)全局變量:

Array<int3> a=NewArrary[3][2][1];   //相當(dāng)于int[3][2][1]

operator[] 是利用特化類模板來實(shí)現(xiàn)的:

template<typename _Type, int _DimensionCount>
class Array
{
private:
  _Type
* Elements;
  
int Size;
public:
  Array
<_Type, DimensionCount-1> operator[](const int Index);
}
;

template
<typename _Type>
class Array<_Type, 1>
{
private:
  _Type
* Elements;
  
int Size;
public:
  _Type
& operator[](const int Index);
  _Type 
operator[](const int Index)const;
}
;

在實(shí)現(xiàn) Array<_Type, DimensionCount-1> operator[](const int Index) 時(shí)遇到一個(gè)問題,我需要返回一個(gè)Array<_Type, DimensionCount-1>,這個(gè)結(jié)果是根據(jù)當(dāng)前的Array的信息來生成的,肯定需要用到private成員Elements,于是考慮用friend class Array<_Type, DimensionCount-1>,沒想到編譯器又噴我了,還是不能通過,原因不明T_T,無奈只能把Elements這些信息放到public下。

Array的測試用例如下:

#include "Library/UnitTest/UnitTest.h"
#include 
"Library/Basic/Array.h"

using namespace Lyt;

void InitArray(int* a, const int Size)
{
    
if (a)
    
{
        
for (int i=0; i<=Size-1; i++) a[i]=i;
    }

}


bool CheckArray(int* a1, int* a2, const int Size)
{
    
if (a1 && a2)
    
{
        
for (int i=0; i<=Size-1; i++)
            
if (a1[i]!=a2[i]) return false;
    }

    
else if (a1 || a2) return false;
    
return true;
}


TESTCASE(ArrayConstructorAssign, 
"ArrayConstructor")
{
    
int a[30];
    InitArray(a, 
30);
    
int dims[3];
    dims[
0]=2;
    dims[
1]=3;
    dims[
2]=5;

    Array
<int3> a1;
    EXPECT_TRUE(a1.Dimensions
!=0"DefaultConstructor");
    Array
<int3> a2=NewArray[2][3][5];
    InitArray(a2.Elements, a2.Size);
    EXPECT_TRUE(CheckArray(dims, a2.Dimensions, 
3&& CheckArray(a, a2.Elements, a2.Size), "NewArrayConstructor");
    Array
<int3> a3=a2;
    EXPECT_TRUE(CheckArray(dims, a3.Dimensions, 
3&& CheckArray(a, a3.Elements, a3.Size), "CopyConstructor");
    Array
<int2> a4=a3[1];
    EXPECT_TRUE(CheckArray(dims
+1, a4.Dimensions, 2&& CheckArray(a+15, a4.Elements, a4.Size), "CopyConstructor operator[]");
    Array
<int1> a5=a3[1][1];
    EXPECT_TRUE(CheckArray(dims
+2, a5.Dimensions, 1&& CheckArray(a+20, a5.Elements, a5.Size), "CopyConstructor operator[]");
    Array
<int1> a6=a5;
    EXPECT_TRUE(CheckArray(dims
+2, a6.Dimensions, 1&& CheckArray(a+20, a6.Elements, a6.Size), "CopyConstructor");

    EXPECT_TRUE(a2[
1][1][0]==20"operator[]");
    EXPECT_TRUE((a2[
1][1][0]=30)==30"operator=");
}


TESTCASE(ArrayAssign, 
"Array::operator=")
{
    
int a1[30];
    InitArray(a1, 
30);
    
int dims1[3];
    dims1[
0]=2;
    dims1[
1]=3;
    dims1[
2]=5;

    
int a2[8];
    InitArray(a2, 
8);
    
int dims2[3];
    dims2[
0]=2;
    dims2[
1]=2;
    dims2[
2]=2;

    Array
<int3> Array1=NewArray[2][3][5];
    InitArray(Array1.Elements, Array1.Size);
    Array
<int3> Array2=Array1;

    Array
<int3> Array3=NewArray[2][2][2];
    InitArray(Array3.Elements, Array3.Size);
    Array1
=Array3;
    EXPECT_TRUE(CheckArray(dims2, Array1.Dimensions, 
3&& CheckArray(a2, Array1.Elements, Array1.Size), "operator=");
    EXPECT_TRUE(Array1[
0][1][1]==3"operator[]");

    Array
<int2> Array4=Array1[0];
    Array
<int1> Array5=Array1[0][1];
    Array5[
1]=9;
    EXPECT_TRUE(Array1[
0][1][1]==9 && Array3[0][1][1]==9 && Array4[1][1]==9"operator=");

    Array3
=Array2;
    EXPECT_TRUE(CheckArray(dims1, Array3.Dimensions, 
3&& CheckArray(a1, Array3.Elements, Array3.Size), "operator=");
}


TESTCASE(ArrayClone, 
"Array::Clone")
{
    
int a[30];
    InitArray(a, 
30);
    
int dims[3];
    dims[
0]=2;
    dims[
1]=3;
    dims[
2]=5;

    Array
<int3> a1=NewArray[2][3][5];
    InitArray(a1.Elements, a1.Size);
    Array
<int3> a2=a1.Clone();
    EXPECT_TRUE(CheckArray(dims, a2.Dimensions, 
3&& CheckArray(a, a2.Elements, a2.Size), "Clone");
    a1[
0][0][0]=100;
    EXPECT_TRUE(a1[
0][0][0]==100 && a2[0][0][0]==0"operator=");
}

Array源碼:

#ifndef ARRAY_H
#define ARRAY_H

#include 
<memory.h>

namespace Lyt
{
    template
<int _DimensionCount>
    
class ArrayDimension
    
{
    
public:
        
int Data[_DimensionCount+1];

        ArrayDimension()
        
{
            
for (int i=0; i<=_DimensionCount-1; i++) Data[i]=0;
        }


        ArrayDimension(
const int Dimension, int* PrevDimensions)
        
{
            Data[_DimensionCount
-1]=Dimension;
            memcpy(Data, PrevDimensions, 
sizeof(int)*(_DimensionCount-1));
        }


        ArrayDimension
<_DimensionCount+1> operator[](const int Dimension)
        
{
            
return ArrayDimension<_DimensionCount+1>(Dimension, Data);
        }


        
int GetSize()const
        
{
            
int Result=1;
            
for (int i=0; i<=_DimensionCount-1; i++) Result*=Data[i];
            
return Result;
        }

    }
;

    
extern ArrayDimension<0> NewArray; 

    template
<typename _Type, int _DimensionCount>
    
class Array
    
{
    
protected:
        
void RefIncrease()
        
{
            
if (RefCount) (*RefCount)++;
        }


        
void RefDecrease()
        
{
            
if (RefCount)
            
{
                
if (--(*RefCount)==0)
                
{
                    delete RefCount;
                    delete[] (Dimensions
-DimensionsIndex);
                    
if (Elements) delete[] (Elements-ElementsIndex);
                    RefCount
=0;
                    Dimensions
=0;
                    Elements
=0;
                    Size
=0;
                    ElementsIndex
=0;
                    DimensionsIndex
=0;
                }

            }

        }

    
    
public:
        
int* RefCount;
        
int* Dimensions;
        _Type
* Elements;
        
int Size;
        
int ElementsIndex;
        
int DimensionsIndex;

        Array()
        
{
            RefCount
=new int(1);
            Dimensions
=new int[_DimensionCount];
            Elements
=0;
            Size
=0;
            ElementsIndex
=0;
            DimensionsIndex
=0;
        }


        Array(
const Array<_Type, _DimensionCount>& Object)
        
{
            RefCount
=Object.RefCount;
            Dimensions
=Object.Dimensions;
            Elements
=Object.Elements;
            Size
=Object.Size;
            ElementsIndex
=Object.ElementsIndex;
            DimensionsIndex
=Object.DimensionsIndex;
            RefIncrease();
        }


        Array(
const ArrayDimension<_DimensionCount> Dims)
        
{
            RefCount
=new int(1);
            Dimensions
=new int[_DimensionCount];
            memcpy(Dimensions, Dims.Data, 
sizeof(int)*_DimensionCount);
            Size
=Dims.GetSize();
            Elements
=new _Type[Size];
            ElementsIndex
=0;
            DimensionsIndex
=0;
        }


        
~Array()
        
{
            RefDecrease();
        }


        Array
<_Type, _DimensionCount>& operator=(const Array<_Type, _DimensionCount>& Object)
        
{
            RefDecrease();
            RefCount
=Object.RefCount;
            Dimensions
=Object.Dimensions;
            Elements
=Object.Elements;
            Size
=Object.Size;
            ElementsIndex
=Object.ElementsIndex;
            DimensionsIndex
=Object.DimensionsIndex;
            RefIncrease();
            
return *this;
        }


        Array
<_Type, _DimensionCount-1> operator[](const int Index)
        
{
            RefIncrease();
            Array
<_Type, _DimensionCount-1> Result;
            delete Result.RefCount;
            Result.RefCount
=RefCount;
            Result.Size
=Size/Dimensions[0];
            Result.Dimensions
=Dimensions+1;
            Result.Elements
=Elements+Index*Result.Size;
            Result.ElementsIndex
=ElementsIndex+Index*Result.Size;
            Result.DimensionsIndex
=DimensionsIndex+1;
            
return Result;
        }


        Array
<_Type, _DimensionCount> Clone()const
        
{
            Array
<_Type, _DimensionCount> Result;
            memcpy(Result.Dimensions, Dimensions, 
sizeof(int)*(_DimensionCount));
            Result.Size
=Size;
            Result.Elements
=new _Type[Size];
            memcpy(Result.Elements, Elements, 
sizeof(int)*(Size));
            
return Result;
        }

    }
;

    template
<typename _Type>
    
class Array<_Type, 1>
    
{
    
protected:
        
void RefIncrease()
        
{
            
if (RefCount) (*RefCount)++;
        }


        
void RefDecrease()
        
{
            
if (RefCount)
            
{
                
if (--(*RefCount)==0)
                
{
                    delete RefCount;
                    delete[] (Dimensions
-DimensionsIndex);
                    
if (Elements) delete[] (Elements-ElementsIndex);
                    RefCount
=0;
                    Dimensions
=0;
                    Elements
=0;
                    Size
=0;
                    ElementsIndex
=0;
                    DimensionsIndex
=0;
                }

            }

        }

    
    
public:
        
int* RefCount;
        
int* Dimensions;
        _Type
* Elements;
        
int Size;
        
int ElementsIndex;
        
int DimensionsIndex;

        Array()
        
{
            RefCount
=new int(1);
            Dimensions
=new int[1];
            Elements
=0;
            Size
=0;
            ElementsIndex
=0;
            DimensionsIndex
=0;
        }


        Array(
const Array<_Type, 1>& Object)
        
{
            RefCount
=Object.RefCount;
            Dimensions
=Object.Dimensions;
            Elements
=Object.Elements;
            Size
=Object.Size;
            ElementsIndex
=Object.ElementsIndex;
            DimensionsIndex
=Object.DimensionsIndex;
            RefIncrease();
        }


        Array(
const ArrayDimension<1> Dims)
        
{
            RefCount
=new int(1);
            Dimensions
=new int[];
            memcpy(Dimensions, Dims.Data, 
sizeof(int));
            Size
=Dims.GetSize();
            Elements
=new _Type[Size];
            ElementsIndex
=0;
            DimensionsIndex
=0;
        }


        
~Array()
        
{
            RefDecrease();
        }


        Array
<_Type, 1>& operator=(const Array<_Type, 1>& Object)
        
{
            RefDecrease();
            RefCount
=Object.RefCount;
            Dimensions
=Object.Dimensions;
            Elements
=Object.Elements;
            Size
=Object.Size;
            ElementsIndex
=Object.ElementsIndex;
            DimensionsIndex
=Object.DimensionsIndex;
            RefIncrease();
            
return *this;
        }


        _Type
& operator[](const int Index)
        
{
            
if (Index<0 || Index>=Dimensions[0]) throw L"越界訪問";
            
else return Elements[Index];
        }


        _Type 
operator[](const int Index)const
        
{
            
if (Index<0 || Index>=Dimensions[0]) throw L"越界訪問";
            
else return Elements[Index];
        }


        Array
<_Type, 1> Clone()const
        
{
            Array
<_Type, 1> Result;
            mencpy(Result.Dimensions, Dimensions, 
sizeof(int));
            Result.Size
=Size;
            Result.Elements
=new _Type[Size];
            memcpy(Result.Elements, Elements, 
sizeof(int)*(Size));
            
return Result;
        }

    }
;
}


#endif
歡迎各位繼續(xù)噴~
posted on 2009-10-13 14:16 Lyt 閱讀(1769) 評論(9)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)結(jié)構(gòu)

FeedBack:
# re: 很傻很天真之Array——解決方法
2009-10-13 16:34 | 遠(yuǎn)古毛利人
樓主可以參考一下boost::multiarray的實(shí)現(xiàn)  回復(fù)  更多評論
  
# re: 很傻很天真之Array——解決方法
2009-10-13 17:32 | 陳梓瀚(vczh)
應(yīng)該是讓Array的構(gòu)造函數(shù)接受多一點(diǎn)東西才對,而不是把什么都放到public里面。  回復(fù)  更多評論
  
# re: 很傻很天真之Array——解決方法
2009-10-13 17:38 | 陳梓瀚(vczh)
而且你的Array<i>想用Array<i-1>的時(shí)候,應(yīng)該在Array<i>里面friend那個(gè)Array<i+1>才對,怎么能friend那個(gè)Array<-1>呢,你搞反了。  回復(fù)  更多評論
  
# re: 很傻很天真之Array——解決方法
2009-10-13 20:11 | 陳昱(CY)
很強(qiáng)大,接下來應(yīng)該實(shí)現(xiàn)tuple了  回復(fù)  更多評論
  
# re: 很傻很天真之Array——解決方法
2009-10-14 11:38 | 欲三更
再來個(gè)迭代器吧, 這樣就能方便使用那些算法了.  回復(fù)  更多評論
  
# re: 很傻很天真之Array——解決方法
2009-10-14 16:22 | 暗涌
不錯(cuò),學(xué)習(xí)了
另外:
Array<_Type, 1> Clone()const
{
Array<_Type, 1> Result;
mencpy(Result.Dimensions, Dimensions, sizeof(int)); // memcpy筆誤了
Result.Size=Size;
Result.Elements=new _Type[Size];
memcpy(Result.Elements, Elements, sizeof(int)*(Size));
return Result;
}

  回復(fù)  更多評論
  
# re: 很傻很天真之Array——解決方法
2009-10-14 16:37 | 暗涌
lz,我用friend class Array<_Type, _DimensionCount-1>是可以的哦,但是要記住在特化的Array里面也要加friend class Array<_Type, 0>  回復(fù)  更多評論
  
# re: 很傻很天真之Array——解決方法
2009-10-14 16:40 | 伊莎貝兒女裝
是的數(shù)據(jù)庫反反復(fù)復(fù)反反復(fù)復(fù)  回復(fù)  更多評論
  
# re: 很傻很天真之Array——解決方法
2009-10-14 16:44 | 暗涌
@暗涌
Sorry, 之前沒有做訪問操作,確實(shí)不行,用+1也不行  回復(fù)  更多評論
  

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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永久免费观看| 猛男gaygay欧美视频| 国产精品免费看久久久香蕉| 亚洲国产精品一区二区www在线| 一本大道久久精品懂色aⅴ| 99国产精品99久久久久久| 久久精品最新地址| 亚洲成人在线网| 久久国产精品第一页| 亚洲欧美日韩一区二区在线| 国产亚洲福利| 午夜精品福利一区二区蜜股av| 一本色道久久综合亚洲精品高清 | 久久久久久久久久久成人| 亚洲国产经典视频| 久久精品国产久精国产思思| 韩曰欧美视频免费观看| 欧美一区成人| 香蕉乱码成人久久天堂爱免费| 欧美亚洲成人网| 欧美成人综合| 夜夜精品视频| 午夜在线一区二区| 亚洲视频一二区| 最新亚洲视频| 国产欧美日韩在线观看| 久久精品在线| 欧美粗暴jizz性欧美20| 免费视频久久| 日韩亚洲视频在线| 99视频在线精品国自产拍免费观看| 欧美日韩免费看| 欧美一区二区精品| 久久久91精品国产| 亚洲品质自拍| 国产精品国产| 亚洲欧洲一区二区三区在线观看| 国产欧美日韩视频一区二区三区| 国产美女在线精品免费观看| 久久久久久高潮国产精品视| 欧美日韩国产限制| 日韩一级大片在线| 亚洲电影第1页| 国产亚洲综合精品| 国产美女精品视频| 久久久国产一区二区| 亚洲视频在线观看网站| 亚洲国产婷婷| 久久综合伊人77777麻豆| 欧美一级二区| 久久精品国产久精国产思思| 国产日韩欧美一区二区| 女仆av观看一区| 最近看过的日韩成人| 久久久综合网| av不卡免费看| 亚洲一区二区免费看| 在线精品视频在线观看高清| 亚洲狠狠丁香婷婷综合久久久| 欧美午夜精品一区| 狼人天天伊人久久| 欧美日韩一区二区三| 久久人91精品久久久久久不卡| 欧美全黄视频| 久久亚洲风情| 国产精品一区二区视频| 亚洲国产乱码最新视频| 国产女优一区| 亚洲精品乱码久久久久久按摩观| 曰韩精品一区二区| 亚洲欧美三级在线| 亚洲天堂成人在线观看| 久久夜色精品国产欧美乱极品| 亚洲欧美日本伦理| 欧美日韩在线免费| 亚洲国产99| 亚洲国产高清高潮精品美女| 亚久久调教视频| 欧美尤物一区| 国产精品视频第一区| 亚洲视频电影在线| 在线午夜精品| 欧美久久九九| 亚洲欧洲视频在线| 日韩午夜电影av| 欧美激情bt| 亚洲日韩欧美一区二区在线| 黄色av日韩| 久久久久久久久久久一区 | 国产精品国产三级国产专播品爱网| 久久综合九色| 国内成人精品2018免费看| 亚洲欧美综合一区| 午夜视频在线观看一区二区三区| 欧美精品一区在线播放| 亚洲高清不卡一区| 亚洲国产婷婷香蕉久久久久久99| 久久精品一二三区| 美国十次了思思久久精品导航| 韩国三级电影一区二区| 欧美一区二区三区在线观看视频 | 日韩视频免费在线| 99xxxx成人网| 欧美日韩精品久久| 亚洲视频中文字幕| 欧美一区三区三区高中清蜜桃| 国产女主播在线一区二区| 欧美一区亚洲一区| 另类酷文…触手系列精品集v1小说| 韩国v欧美v日本v亚洲v| 久久久精品国产99久久精品芒果| 免费在线国产精品| 亚洲精品国精品久久99热一| 欧美激情精品久久久| 在线一区二区三区做爰视频网站| 亚洲欧美精品| 国产欧美日韩不卡免费| 久久婷婷av| 一区二区三区精品久久久| 久久精品视频在线免费观看| 亚洲国产cao| 国产精品国产精品| 久久大香伊蕉在人线观看热2| 麻豆免费精品视频| 一区二区三区回区在观看免费视频| 国产精品美女久久福利网站| 欧美一级网站| 亚洲人成网站精品片在线观看| 小处雏高清一区二区三区| 精品96久久久久久中文字幕无| 欧美另类极品videosbest最新版本 | 欧美成人精品一区二区| 亚洲日本一区二区三区| 欧美色欧美亚洲高清在线视频| 亚洲欧美综合精品久久成人| 欧美激情1区| 久久精品国产99国产精品澳门| 亚洲精品免费在线观看| 国产无遮挡一区二区三区毛片日本| 欧美本精品男人aⅴ天堂| 亚洲免费婷婷| 亚洲人成在线影院| 久久精品国产清高在天天线| 亚洲精品资源美女情侣酒店| 国产欧美日韩在线| 欧美性猛交xxxx乱大交蜜桃| 牛牛精品成人免费视频| 午夜欧美大尺度福利影院在线看| 亚洲福利视频网站| 久久久久这里只有精品| 一本久道综合久久精品| 在线观看成人网| 国产精品久久综合| 欧美韩日精品| 亚洲黄色免费电影| 欧美电影打屁股sp| 香蕉av777xxx色综合一区| 在线观看亚洲视频| 国产区在线观看成人精品| 欧美精品在线看| 久久久久91| 欧美亚洲尤物久久| 亚洲一区二区三区涩| 亚洲欧洲日韩综合二区| 美国成人直播| 久久全球大尺度高清视频| 午夜视频精品| 亚洲欧美国产日韩天堂区| 夜夜爽www精品| 亚洲第一福利社区| 激情久久影院| 狠狠综合久久av一区二区小说 | 国产精品视频导航| 欧美日韩国产小视频在线观看| 麻豆国产精品一区二区三区 | 国产综合在线视频| 国内精品视频久久| 国内外成人免费激情在线视频| 国产精品日韩久久久| 欧美亚男人的天堂| 国产精品亚洲аv天堂网| 国产精品入口福利| 国产亚洲激情在线| 一区二区在线免费观看| 尤物九九久久国产精品的特点| 激情小说另类小说亚洲欧美| 在线国产亚洲欧美| 亚洲日本在线观看| 亚洲香蕉在线观看| 久久福利影视| 欧美成人黄色小视频| 亚洲国产高清自拍| 日韩一级片网址| 亚洲欧美日韩国产一区二区三区| 欧美一区二区免费| 欧美h视频在线| 欧美午夜精品久久久久久超碰| 国产乱码精品一区二区三区五月婷| 国产午夜精品理论片a级探花|