Main Content

检查嵌套函数中的参量数目

本主题介绍将 vararginvarargoutnarginnargout 与嵌套函数结合使用时的特殊注意事项。

通过 vararginvarargout,您可以创建接受可变数量的输入或输出参量的函数。虽然 vararginvarargout 看上去像函数名称,但它们都是变量,不是函数。这一点很重要,因为嵌套函数与包含它们的函数共享工作区。

如果您在声明嵌套函数时未使用 vararginvarargout,则嵌套函数内的 vararginvarargout 引用外部函数的参量。

例如,在名为 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

另一方面,narginnargout 都是函数。在包含嵌套函数的任何函数内,调用 narginnargout 返回该函数的参量数量。如果嵌套函数需要外部函数中的 narginnargout 的值,将该值传递到嵌套函数。

例如,在名为 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

另请参阅

| | |