2014-05-18 243 views
0

我試圖專注模板類成員函數:模板專業化

在valueinput.h

namespace Gui 
    { 
    template<class T> 
    class ValueInput:public TextInput 
     { 
     public:   
      static ValueInput* create(Gui& gui_obj,uint32_t style_0,uint32_t style_1 
       ,Window* parent,T& obj) 
       {return new ValueInput(gui_obj,style_0,style_1,parent,obj);} 

      //Polymorphic implementation inherited from 
      //TextInput that needs specialization depending on T 
      void valueUpdate(); 

      //Polymorphic implementation inherited from 
      //TextInput that needs specialization depending on T 
      void displayUpdate(); 

     protected: 
      ValueInput(Gui& gui_obj,uint32_t style_0,uint32_t style_1,Window* parent 
       ,T& obj):TextInput(gui_obj,style_0,style_1,parent),ptr_obj(&obj) 
       {} 

     private: 
      T* ptr_obj; 
     }; 
    } 

在valueinput.cpp

template<> 
void Gui::ValueInput<double>::displayUpdate() 
    { 
    Dialog::messageDisplay(this,{STR("Display Update"),Herbs::LogMessage::Type::INFORMATION},STR("Test")); 
    } 

template<> 
void Gui::ValueInput<double>::valueUpdate() 
    { 
    Dialog::messageDisplay(this,{STR("Value Update"),Herbs::LogMessage::Type::INFORMATION},STR("Test")); 
    } 

編譯器輸出:

g++ "valueinput.cpp" -g -municode -Wall -c -std=c++11 -o "__wand_targets_dbg\valueinput.o" 

valueinput.cpp:21:45: error: specialization of 'void Gui::ValueInput::displayUpdate() [with T = double]' in different namespace [-fpermissive]

valueinput.cpp:21:6: error: from definition of 'void Gui::ValueInput::displayUpdate() [with T = double]' [-fpermissive]

valueinput.cpp:27:43: error: specialization of 'void Gui::ValueInput::valueUpdate() [with T = double]' in different namespace [-fpermissive]

valueinput.cpp:27:6: error: from definition of 'void Gui::ValueInput::valueUpdate() [with T = double]' [-fpermissive]

有什麼不對?

+0

@πάνταῥεῖ顯式特化的實現可以放在'cpp'文件中。 – Constructor

+0

@Constructor但是,然後他們需要出現在正確的命名空間,但。 –

+0

@πάνταῥεῖ當然你是對的。 – Constructor

回答

1

重寫代碼在你valueinput.cpp文件以下列方式:

namespace Gui 
{ 
    template<> 
    void ValueInput<double>::displayUpdate() 
    { 
     Dialog::messageDisplay(this,{STR("Display Update"),Herbs::LogMessage::Type::INFORMATION},STR("Test")); 
    } 

    template<> 
    void ValueInput<double>::valueUpdate() 
    { 
     Dialog::messageDisplay(this,{STR("Value Update"),Herbs::LogMessage::Type::INFORMATION},STR("Test")); 
    } 
} 

如果你想使用它們valueinput.cpp文件之外,不要忘記在valueinput.h頭文件來聲明這些專業:

namespace Gui 
{ 
    template<class T> 
    class ValueInput : public TextInput 
    { 
     // ... 
    }; 

    template<> 
    void ValueInput<double>::displayUpdate(); 

    template<> 
    void ValueInput<double>::valueUpdate(); 

} 

編輯:我不知道你的變體是否符合標準。但這裏是從標準小報價([temp.expl.spec] 14.7.3/8):

A template explicit specialization is in the scope of the namespace in which the template was defined. [ Example:

namespace N { 
    template<class T> class X { /* ... */ }; 
    template<class T> class Y { /* ... */ }; 

    template<> class X<int> { /* ... */ };  // OK: specialization 
               // in same namespace 
    template<> class Y<double>;     // forward declare intent to 
               // specialize for double 
} 

template<> class N::Y<double> { /* ... */ }; // OK: specialization 
               // in same namespace 

— end example ]

不幸的是它是關於類模板特,不是關於功能模板特或類的功能部件特模板。

+0

所以編譯器無法理解Gui在這種情況下是一個命名空間。爲什麼? – user877329

+0

@ user877329我不知道。但*鏗鏘3.4 * [編譯此類代碼](http://rextester.com/MGIAX36625)。可能它是* gcc *中的一個錯誤。 – Constructor

+0

@ user877329請參閱我的除了您可能感興趣的標準引用的答案。 – Constructor