• <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>

            旅途

            如果想飛得高,就該把地平線忘掉

            在類的頭文件中保存靜態變量

            當設計開發一個類的時候,程序員通常需要在類的內部定義一些靜態變量。在通常情況下,你會在一個類的頭文件中定義一個靜態變量并在源代碼程序中初始化,如下所示:??


            // File.h
            class File
            {
            // . . . code
            private:
            static char DELIMETER;
            }
            // File.cpp
            char File:ELIMETER = "/";

            然而,這一方法并不適用于模板類。模板類通常位于頭文件中。生成一個原文件并沒有太多的用處,因為你不能為所用的模板參數初始化。
            // Array.h
            template< class T>;
            class Array
            {
            // . . .
            private:
            // hold all instances of this type (T) in an array
            static std::vector< Array< T>; *>; s_aAllInstances;
            };
            // Array.cpp
            // illegal C++
            template< class T>;
            std::vector< Array< T>; >; Array< T>;::s_aAllInstances;
            然而,C++允許靜態函數在模板中操作,而在一個靜態函數中,你可以調用一個靜態變量。
            如下所示:
            template< class T>;
            class Array
            {
            //...
            private:
            typedef std::vector< Array< T>;*>; ElementsArray;
            static ElementsArray & s_Elements()
            {
            static ElementsArray s_array;
            return s_array;
            }
            };
            這一技巧功能非常強大,因為對于Array< int>;,你必須提供Array< int>;::s_Elements;對于rArray< std::string>;,你必須擔任 Array< std::string>;::s等。

            這里你必須完成下面的兩個步驟:

            在模板類中必須有一個模板函數(不是變量);我們建議你以變量名的形式來為它命名。
            在模板函數中添加靜態數據。
            下面的范例包含了Array< T>;類,這一類在內部里把每一數組定義為類型T。當某一類型被生成或刪除時,它會顯示出數組元素個數及其類型。
            #include <vector>;
            #include <algorithm>;
            #include <iostream>;
            template< class T>;
            struct Type;
            template<>;
            struct Type< int>;
            {
            static const char * name() { return "int"; }
            };
            template<>;
            struct Type< long>;
            {
            static const char * name() { return "long"; }
            };
            template<>;
            struct Type< std::string>;
            {
            static const char * name() { return "std::string"; }
            };
            template<>;
            struct Type< float>;
            {
            static const char * name() { return "float"; }
            };
            /*
            holds internal references to its objects
            (of Type T)
            */
            template< class T>;
            class Array
            {
            public:
            Array()
            { AddMe(); }

            Array( const Array &
            { AddMe(); }

            ~Array()
            { DeleteMe(); }

            private:
            void AddMe()
            {
            s_Elements().push_back( this);
            std::cout
            << "We have added one element of type "
            << Type< T>;::name() << std::endl;
            std::cout
            << "We have now " << s_Elements().size()
            << " " << Type< T>;::name() << " elements" << std::endl;
            }

            void DeleteMe()
            {
            ElementsArray::iterator itFound =
            std::find( s_Elements().begin(), s_Elements().end(), this);
            if ( itFound != s_Elements().end())
            {
            s_Elements().erase( itFound);
            }
            std::cout
            << "We have deleted one element of type "
            << Type< T>;::name() << std::endl;
            std::cout
            << "We have now " << s_Elements().size()
            << " " << Type< T>;::name() << " elements" << std::endl;
            }
            private:
            // note: we're treating it as an internal variable
            typedef std::vector< Array< T>;*>; ElementsArray;
            static ElementsArray & s_Elements()
            {
            static ElementsArray s_array;
            return s_array;
            }

            };

            int main(int argc, char* argv[])
            {
            Array< int>; int1;
            Array< int>; int2;
            Array< long>; long1;
            Array< long>; long2;
            Array< std::string>; str1;
            Array< std::string>; str2;
            Array< float>; float1;
            Array< float>; float2;
            Array< float>; float3;
            Array< int>; int3;
            Array< long>; long3;
            Array< std::string>; str3;
            return 0;
            }

            posted on 2007-09-06 01:54 旅途 閱讀(810) 評論(0)  編輯 收藏 引用 所屬分類: C/C++

            国产成人久久精品麻豆一区| 色播久久人人爽人人爽人人片aV| 久久久久亚洲av成人无码电影| 久久九九免费高清视频 | 亚洲中文字幕无码久久2017| 日本欧美久久久久免费播放网| 国产精品一久久香蕉国产线看观看 | 无码国内精品久久人妻蜜桃 | 久久这里只有精品久久| 思思久久99热免费精品6| 久久中文骚妇内射| 久久精品18| 久久国产乱子伦免费精品| 久久久久亚洲av成人网人人软件 | 久久久久人妻一区精品性色av| 久久久中文字幕| 99精品国产99久久久久久97 | 久久久婷婷五月亚洲97号色| 精品久久久久久无码中文野结衣| 蜜臀av性久久久久蜜臀aⅴ麻豆 | 国产精品亚洲综合久久| 国产成人AV综合久久| 久久久久久久久久久精品尤物| 天天久久狠狠色综合| 亚洲精品乱码久久久久66| 久久久久久久久久久免费精品| 国产婷婷成人久久Av免费高清 | 亚洲国产高清精品线久久| 久久国产综合精品五月天| 国产午夜久久影院| 777久久精品一区二区三区无码| 一级做a爰片久久毛片16| 亚洲色欲久久久综合网| 少妇熟女久久综合网色欲| 久久综合伊人77777| 久久中文字幕无码专区| 国产激情久久久久影院老熟女| 婷婷综合久久狠狠色99h| 久久综合综合久久97色| 免费观看成人久久网免费观看| 久久青青草原国产精品免费|