[英]array of pointers to member functions: make it work
在以下代碼中,我得到了錯誤:
a value of type (double*)(const double& arg) const cannot be assigned to an entity of type pt2calculateA
關於如何使其工作的任何建議?
class myClass {
private:
typedef double (*pt2calculateA)(double);
pt2calculateA calculateA[2];
public:
myClass () {
calculateA[0] = &calculateA1; //->error
calculateA[1] = &calculateA2; //->error
}
double calculateA1(const double& arg) const {
...
}
double calculateA2(const double& arg) const {
...
}
}
myClass::calculateA1()
不是函數 ; 而是一個成員函數 。 因此,這些類型自然是不兼容的。
&myClass::calculcateA1
的類型為double (myClass::*)(const double &) const
,它是成員函數指針(PTFM)。 請注意,您只能將PTMF與指向對象實例的指針(即myClass*
)一起使用。
如果更改typedef,則至少可以正確存儲指針:
typedef double (myClass::*pt2calculateA)(const double &) const;
您必須說&myClass::calculateA1
等以獲取地址。
在C ++ 11中,您可以在初始化列表中初始化數組:
myClass() : calculateA{&myClass::calculateA1, &myClass::calculateA2} { }
嘗試這個:
class myClass {
private:
typedef double (myClass::*pt2calculateA)(const double&) const;
pt2calculateA calculateA[2];
public:
myClass () {
calculateA[0] = &myClass::calculateA1;
calculateA[1] = &myClass::calculateA2;
}
double calculateA1(const double& arg) const {
// ...
}
double calculateA2(const double& arg) const {
// ...
}
};
在typedef和實際函數之間,不僅參數類型有所不同,而且一個是函數指針,而另一個是成員函數指針。 myClass::calculateA1
具有double (myClass::*)(const double& arg) const
類型double (myClass::*)(const double& arg) const
。
pt2calculateA
被聲明為函數指針,而不是成員函數指針。
看這里
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.