Overload inherited methods in an Rcpp class(重载RCPP类中继承的方法)
本文介绍了重载RCPP类中继承的方法的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有两个类A
,父类和子类。
B
重载A
中的方法。问题是,在RCPP模块中公开类B
时,方法getval
不会重载,尽管使用指向B::getval
的指针再次显式公开了它。
是由于RCPP中的错误、限制还是我还不知道什么原因?
class A
{
public:
A(int val) : val(val) {}
int getval()
{
Rcout << "I am A" << endl;
return val;
}
private:
int val;
};
class B : public A
{
public:
using A::A;
int getval()
{
Rcout << "I am B" << endl;
return A::getval();
}
};
RCPP_MODULE(rg)
{
using namespace Rcpp;
class_<A>("A")
.constructor<int>()
.method("getval", &A::getval);
class_<B>("B")
.derives<A>("A")
.constructor<int>()
.method("getval", &B::getval);
}
推荐答案
如果我在简单的C++程序中使用上面的基本示例(在问题中),如下所示:
int main()
{
A a(42);
B b(43);
cout << a.getval() << endl;
cout << b.getval() << endl;
}
使用正确的方法。但是,对于Rcpp
,父类A
必须将方法getval
声明为virtual
:
virtual int getval()
事实上,将B
中的相同方法声明为virtual
也很好。在R
中,它最终将按预期工作:
a <- A$new(42)
b <- B$new(43)
然后:
a$getval()
I am A
[1] 42
b$getval()
I am B
I am A
[1] 43
请注意,I am B
下的消息I am A
是预期的,因为在我的示例中,我显式调用A::getval
。
这篇关于重载RCPP类中继承的方法的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:重载RCPP类中继承的方法


基础教程推荐
猜你喜欢
- 设计字符串本地化的最佳方法 2022-01-01
- 如何定义双括号/双迭代器运算符,类似于向量的向量? 2022-01-01
- 调用std::Package_TASK::Get_Future()时可能出现争用情况 2022-12-17
- 什么是T&&(双与号)在 C++11 中是什么意思? 2022-11-04
- 运算符重载的基本规则和习语是什么? 2022-10-31
- 您如何将 CreateThread 用于属于类成员的函数? 2021-01-01
- C++ 标准:取消引用 NULL 指针以获取引用? 2021-01-01
- C++,'if' 表达式中的变量声明 2021-01-01
- C++ 程序在执行 std::string 分配时总是崩溃 2022-01-01
- 如何在 C++ 中处理或避免堆栈溢出 2022-01-01