您好,登錄后才能下訂單哦!
在C++中,沒有內置的super
關鍵字來直接調用父類的方法。然而,C++支持通過使用作用域解析運算符::
來顯式地調用父類的方法。以下是一些高級策略,用于在C++中模擬super
調用的行為:
class Base {
public:
void foo() {
// ...
}
};
class Derived : public Base {
public:
void bar() {
// 調用父類的foo方法
Base::foo();
}
};
template <typename Derived>
class Base {
public:
void foo() {
// ...
}
};
class Derived : public Base<Derived> {
public:
void bar() {
// 調用基類的foo方法
static_cast<Base<Derived>*>(this)->foo();
}
};
注意:雖然CRTP在某些情況下非常有用,但它也可能導致代碼難以理解和維護。因此,在使用它之前,請確保您了解其優缺點。
class Base {
public:
void foo() {
// ...
}
};
class Derived : public Base {
public:
void bar() {
// 使用函數對象調用父類的foo方法
std::function<void()> superFoo = [this]() { Base::foo(); };
superFoo();
}
};
或者使用lambda表達式:
class Derived : public Base {
public:
void bar() {
// 使用lambda表達式調用父類的foo方法
auto superFoo = [this]() { Base::foo(); };
superFoo();
}
};
這些策略都可以用來模擬super
調用的行為,但每種策略都有其優缺點。在選擇最適合您需求的方法時,請考慮代碼的可讀性、可維護性和性能。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。