我使用 cling 并希望在环境中看到我的模板函数,所以在加载我的类的 (.L) 之后,我希望能够调用我的模板函数。
我可以为这样的模板做到这一点:
template <typename T>
static void ObjectApplyStyle(const char* styleName, T *cObj, Int_t objNum=0, Int_t verbose=0);
对于这样的函数,我在我的 LinkDef.h 文件中添加了下一个字符串:
#pragma link C++ function AliDrawStyle::ObjectApplyStyle(const char*, TGraph *, Int_t, Int_t);
#pragma link C++ function AliDrawStyle::ObjectApplyStyle(const char*, TH1 *, Int_t, Int_t);
#pragma link C++ function AliDrawStyle::ObjectApplyStyle(const char*, TF1 *, Int_t, Int_t);
所以我的问题是我怎么能做同样的事情,但是对于这样的模板功能?
template <typename T>
static T PrepareValue(const char* styleName, TString propertyName, TString elementID, TString classID, TString objectID, TString localStyle, Bool_t &status, Int_t objNum=0, Int_t verbose=0);
如果我要在 LinkDef.h 中添加这个字符串:
#pragma link C++ function <Int_t> AliDrawStyle::PrepareValue(const char*, TString, TString, TString, TString, TString, Bool_t &, Int_t, Int_t);
#pragma link C++ function <Float_t> AliDrawStyle::PrepareValue(const char*, TString, TString, TString, TString, TString, Bool_t &, Int_t, Int_t);
编译器给我警告“找不到函数”。
正如您在这里看到的我的模板函数之间的区别 - 第一个包含 T 类型的参数,但第二个具有相同的参数列表并具有不同类型的返回值。
你有什么主意吗?
除了与 Axel 的讨论:
让我们看看例子:
我的类.h
class MyClass {
public:
template <typename T>
static T Ex1();
template <typename T>
static T Ex2();
};
我的班级.cxx
#include "MyClass.h"
template <typename T>
T MyClass::Ex1(){
}
template <typename T>
T MyClass::Ex2(){
}
这就是我在 root6 中看到的:
root [0] #include "MyClass.h"
root [1] MyClass::
MyClass
operator=
~MyClass
root [1] MyClass::
.L 也是如此
root [0] .L MyClass.cxx+
root [1] MyClass::
MyClass
operator=
~MyClass
root [1] MyClass::
但是,如果我为一个函数添加显式调用: MyClass.cxx
#include "MyClass.h"
template <typename T>
T MyClass::Ex1(){
// here I added calling of template function
MyClass::Ex2<float>();
}
template <typename T>
T MyClass::Ex2(){
}
我将开始看到:
root [0] .L MyClass.cxx+
root [1] MyClass::
Ex2<float>
MyClass
operator=
~MyClass
root [1] .q
但是,如果我只使用包含,我无论如何都看不到我的功能:
root [0] #include "MyClass.h"
root [1] MyClass::
MyClass
operator=
~MyClass
谢谢!