簡體   English   中英

指向成員函數的指針數組:使其工作

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM