检查嵌套函数中的参量数目
本主题介绍将 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