• <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 旅途 閱讀(808) 評論(0)  編輯 收藏 引用 所屬分類: C/C++

            成人精品一区二区久久久| 99热成人精品免费久久| 久久综合伊人77777麻豆| 亚洲狠狠综合久久| 久久精品国产只有精品2020| 久久综合给久久狠狠97色| 久久综合88熟人妻| 久久ww精品w免费人成| 久久精品中文无码资源站| 国内精品久久久久久久97牛牛| 欧美日韩精品久久久免费观看| 亚洲国产日韩欧美久久| 久久久久久久97| 无码人妻久久久一区二区三区| 亚洲国产精品无码久久一区二区| 亚洲AV日韩精品久久久久久| 久久精品aⅴ无码中文字字幕不卡 久久精品aⅴ无码中文字字幕重口 | 久久久久国产精品嫩草影院| 久久精品国产精品亜洲毛片| 色偷偷91久久综合噜噜噜噜| 日韩中文久久| 欧洲精品久久久av无码电影| 久久91精品国产91久久麻豆| 久久丝袜精品中文字幕| 久久精品国产亚洲AV忘忧草18| 亚洲AV无码久久精品色欲| 国产精品免费久久久久久久久| 欧美精品福利视频一区二区三区久久久精品 | 欧美午夜A∨大片久久| 性做久久久久久久| 久久综合九色综合97_久久久| 久久久久青草线蕉综合超碰 | 伊人久久综在合线亚洲2019| 亚洲国产高清精品线久久 | 久久精品天天中文字幕人妻| 精品多毛少妇人妻AV免费久久| 香蕉久久夜色精品国产2020| 韩国免费A级毛片久久| 久久综合久久性久99毛片| 久久99国产精品久久久| 精品国产青草久久久久福利|