我正在为我的 classA 制作一个通用 subsref,它有一个属性 attrA,它是一个 classB 实例。到目前为止,它正在工作,它让我可以做类似的事情
x = objA.attr1.methB(),
这就是我最初想做的事情。
function this = Class1(varargin)
this.attrA = ClassB()
this = class(this,'ClassA')
function this = ClassB()
this.AttrB1 = 'valueB1'
this.AttrB2 = 'valueB2'
function out = methB
out = this.AttrB2
我偶然发现的问题是:当在我的 subsref 中执行对方法的调用时,我会这样做(检测它是一个方法等之前已完成):
methName = index(1).subs;
args = index(2).subs;
if iscell(args)
varargout = {feval(methName,this,args{:})};
else
varargout = {feval(methName,this,args)};
end %end if iscell
问题是当methName方法支持可变数量的输出时,这个varargout不等价于[x,y,...](输出的数量应该在subsref的调用中赋值,所以methName总是返回单个输出,这并不总是我想要的(几乎,但并非总是如此)。
我如何让 methName 知道我想要多少输出?(我不想将 N 作为参数传递)。
我在想像创建一个字符串str='[out1,out2,out3...]'
然后做类似的事情
eval([
str ...
'= {feval(methName,this,args{:})};'...
])
但我一直认为必须有一种更优雅的方式来做到这一点。