本主题介绍将 varargin、varargout、nargin、nargout 与嵌套函数结合使用时的特殊注意事项。
通过 varargin 和 varargout,可以创建接受可变数量的输入或输出参数的函数。虽然 varargin 和 varargout 看上去像函数名称,但它们都是变量,不是函数。这一点很重要,因为嵌套函数与包含它们的函数共享工作区。
如果在声明嵌套函数时未使用 varargin 或 varargout,则嵌套函数内的 varargin 或 varargout 引用外部函数的参数。
例如,在名为 showArgs.m 的文件中创建一个函数,该函数使用 varargin 并包含两个嵌套函数,一个使用 varargin,另一个不使用。
function showArgs(varargin)
nested1(3,4)
nested2(5,6,7)
function nested1(a,b)
disp('nested1: Contents of varargin{1}')
disp(varargin{1})
end
function nested2(varargin)
disp('nested2: Contents of varargin{1}')
disp(varargin{1})
end
end
调用该函数并比较这两个嵌套函数中的 varargin{1} 内容。
showArgs(0,1,2)
nested1: Contents of varargin{1}
0
nested2: Contents of varargin{1}
5
另一方面,nargin 和 nargout 都是函数。在包含嵌套函数的任何函数内,调用 nargin 或 nargout 返回该函数的参数数量。如果嵌套函数需要外部函数中的 nargin 或 nargout 的值,将该值传递到嵌套函数。
例如,在名为 showNumArgs.m 的文件中创建一个函数,该函数将主(父)函数的输入参数数量传递到嵌套函数。
function showNumArgs(varargin)
disp(['Number of inputs to showNumArgs: ',int2str(nargin)]);
nestedFx(nargin,2,3,4)
function nestedFx(n,varargin)
disp(['Number of inputs to nestedFx: ',int2str(nargin)]);
disp(['Number of inputs to its parent: ',int2str(n)]);
end
end
调用 showNumArgs 并比较父函数和嵌套函数中的 nargin 的输出。
showNumArgs(0,1)
Number of inputs to showNumArgs: 2
Number of inputs to nestedFx: 4
Number of inputs to its parent: 2