如果孩子类的对象调用了 __index,那么将继承表成员存储到孩子类中。

我的目标是通过使用全尺寸的多重继承并具有以下能力:不仅可以将它们继承到其他类,还可以通过 new() 构造函数继承到实例自身。如果我在类或对象中调用一个丢失的值,而这个值是一个函数,我希望将它存储到类中以供以后使用,但不在对象/实例中(在大量实例的类中实现相同的函数时会出现性能问题)。

目前,我正在使用一个非常类似于官方教程系列中提到的 createClass(...) 函数来创建从几乎任意数量的父类继承的类:

它将索引元方法传递给新创建的类,该元方法在所有父类中搜索指定的丢失键,并将其存储以供后续在调用类中使用。这个工作方式是按照意图进行的,即使在搜索巨大的嵌套继承层次结构时也是如此。现在,让我们介绍一个具有基本构造函数的简单类:

如果我们使用以下代码调用此继承和类实现,则会发现在创建类的新实例时未调用该类的 __index 元方法(比较输出的表地址),即使对象的 __index 元方法从其(父级)类中请求缺失的值/函数,该类此时没有这样的值/函数。显然,这种差异不会触发类本身的 __index 元方法,这使我感到困惑。如果请求类/表的缺失值,无论从脚本的哪个部分请求,我都会认为它总是被调用。

  1. 为什么在给定的示例中没有调用 MyClass__index 元方法?
  2. 我该如何实现它(尽可能少地更改代码)?

欢迎您的建议!

点赞
用户2167276
用户2167276

我找到了答案,但并没有完全理解它。看起来,当调用类new的构造函数时,必须将类本身传递给它。这样,我就可以直接操作代表类的self变量。但是我仍然不清楚为什么我能够从类和其父项继承到类实例/对象,而无法访问对象“__index”元方法中的任何其他操作的类。

这个类定义最终完成了任务:

local P = {};
local MyClass = P;

-- 必须在创建其新对象时传递类本身(不知为何...)
function P:new ()
    local pub = {};
    local priv = {};
    setmetatable(pub, {__index = function (t, k)
        local v = P[k];
        --将函数存储在内的类之后使用(避免重复)
        --将所有继承变量放入对象本身
        if (type(v) == "function")
            self[k] = v;
        else
            t[k]    = v;
        end
        return v;
    end});

    pub.testSelf = function () print("testSelf") end;
    priv.testPriv = "testPriv!";

    function pub.accessPriv ()
        return priv;
    end

    return pub;
end

function P.TEST ()
    print("calling TEST");
end
2014-04-21 11:27:36