我需要将 returnValue 传递给方法作为参数传递的参数,并在完成函数id时调整原始的var值。所以使用 ReferenceArgumentHelper 类。
当 returnValue 被无意删除(当它是一个节点,即字符串)并且valgrind检测到它时,代码中出现了什么问题。 callMethod(“onFunctionExit”调用Qore脚本方法,我可以看到正确的 returnValue 值。我怀疑它在退出 onFunctionExit 时被删除了 > ReferenceArgumentHelper 被销毁。 rah.getArg()引用引用变量,因此不应在 callMethod 中删除它。
DLLLOCAL ThreadDebugEnum callMethod(const char* name, const ThreadDebugEnum defaultResult, QoreProgram *pgm, int paramCount, AbstractQoreNode** params, ExceptionSink* xsink) {
int rv;
QoreListNode* l = new QoreListNode();
qore_program_to_object_map_t::iterator i = qore_program_to_object_map.find(pgm);
if (i == qore_program_to_object_map.end()) {
return defaultResult;
}
i->second->ref();
l->push(i->second);
for (int i=0; i<paramCount; i++) {
if (params[i])
params[i]->ref();
l->push(params[i]);
}
rv = qo->intEvalMethod(name, l, xsink);
l->deref(xsink);
return (ThreadDebugEnum) rv;
}
DLLLOCAL virtual ThreadDebugEnum onFunctionExit(QoreProgram *pgm, const StatementBlock *blockStatement, QoreValue& returnValue, ExceptionSink* xsink) {
AbstractQoreNode* params[2];
params[0] = getLocation(blockStatement);
ReferenceArgumentHelper rah(returnValue.takeNode(), xsink); // grab node from returnValue and pass to helper
params[1] = rah.getArg(); // caller owns ref
ThreadDebugEnum rv = callMethod("onFunctionExit", DBG_SB_RUN, pgm, 2, params, xsink);
AbstractQoreNode* rc = rah.getOutputValue(); // caller owns ref
returnValue.assign(rc); // takes reference
// returnValue.ref();
}
return rv;
}
深入研究时,我不明白为什么编译器对 /lib/ReferenceArgumentHelper.cpp 中的代码感到满意:
struct lvih_intern {
LocalVar lv;
ExceptionSink* xsink;
ReferenceNode* ref;
DLLLOCAL lvih_intern(AbstractQoreNode* val, ExceptionSink* xs) : lv("ref_arg_helper", 0), xsink(xs) {
printd(5, "ReferenceArgumentHelper::ReferenceArgumentHelper() instantiating %p (val: %p type: '%s') \n", &lv, val, val ? val->getTypeName() : "n/a");
lv.instantiate(val); <--------------
VarRefNode* vr = new VarRefNode(strdup("ref_arg_helper"), VT_LOCAL);
vr->ref.id = &lv;
ref = new ReferenceNode(vr, 0, vr, 0);
}
class LocalVar {
....
DLLLOCAL void instantiate(QoreValue nval) const {
方法调用中将 AbstractQoreNode * 转换为 QoreValue 的原因是什么?我没有找到一个超载的运营商。我正在查看引用的确切情况。
答案 0 :(得分:3)
**编辑**
长话短说,ReferenceArgumentHelper
是错误的;它没有使用多年,也没有更新。该课程已修复,我希望能解决你的问题。
感谢您指出这一点,如果您对此问题或受影响代码的修复有任何进一步的问题,请与我们联系。