用枚舉類型作爲數組下標

  在開發中,經常會用到一些數組,它裏面存放一定數量(已知,不是太多)的特定元素。在使用數字表示的數組下標訪問數組中元素的時候,根本不知道該元素是否是需要的那個元素,而且使代碼可讀性降低,甚至還會出現下標越界的危險。
    比如,現在有如下的繼承體系:
class CShape;

class CSquare : public CShape;

class CRectangle : public CShape;

class CCircle : public CShape;

class CEllipse : public CShape;
    現在需要一個數組來存放每種形狀的對象的指針。最簡單的就是使用下面的代碼定義數組並給數組元素賦值:
CShape * arrShape[4];

arrShape[
0= new CSquare();
arrShape[
1= new CRectangle();
arrShape[
2= new CCircle();
arrShape[
3= new CEllipse();
     這樣的代碼當然沒有什麼問題。
    可是每次要得到一個長方形的對象指針的時候,都要用arrShape[1]來訪問。這樣的代碼可讀性非常差:如果不看前面的數組賦值代碼,根本不可能知道arrShape[1]裏面存放的是什麼。
    而且,一不小心就會寫錯數組下標而導致下標越界的錯誤。C++在編譯階段是不檢查下標越界的,所以下標越界的錯誤只會在運行時被暴露出來。如果出現錯誤的代碼跟定義數組和給數組元素賦值的代碼相隔較遠的話,查找起來也比較麻煩。
    另外,這段代碼的擴展性也很差:如果在這個繼承體系中加入了三角形,那麼數組定義和給數組元素賦值的代碼都要修改。
    有什麼好方法避免上面所說到的種種缺點嗎?當然有,那就是用枚舉定義有意義的數組下標。
    針對上面的例子,可以定義出如下的一個枚舉類型:
enum ShapeIndex
{
    eSqure,
    eRectangle,
    eCircle,
    eEllipse,
    eShapeCount
};
    數組定義和賦值使用下面的代碼:
CShape* arrShape[eShapeCount];

arrShape[eSquare] 
= new CSquare();
arrShape[eRectangle] 
= new CRectangle();
arrShape[eCircle] 
= new CCircle();
arrShape[eEllipse] 
= new CEllipse();
    這樣每次要得到一個橢圓的對象指針的時候,可以使用arrShape[eEllipse]來訪問。通過eEllipse這個有意義的數組下標,該數組元素指針所指的對象一目瞭然。
    如果對數組的訪問都使用這種方法,就可以有效的避免數組下標越界的錯誤。

    另外,這種方法使數組有很好的可擴展性。如果在這個繼承體系中加入了其他子類,只要在枚舉中eShapeCount前面加上相應的項即可,數組定義的代碼根本不用修改(當然不能忘了添加數組元素賦值的代碼)。

原文出處:http://blog.csdn.net/starlee/article/details/1774117

發佈了52 篇原創文章 · 獲贊 178 · 訪問量 32萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章