nargin,nargout,varargout以及varargin的用法

Nargin

nargin是用来判断输入变量个数的函数,这样就可以针对不同的情况执行不同的功能。通常可以用他来设定一些默认值,如下面的函数。

例子,函数test1的功能是输出a和b的和。如果只输入一个变量,则认为另一个变量为0,如果两个变量都没有输入,则默认两者均为0。

function y=test1(a,b)
if nargin==0
    a=0;b=0;
elseif nargin==1
    b=0;
end
y=a+b;

Nargout

   nargin是用来判断输出变量个数的函数。

Tip:nargin和nargout本身都是函数,不是变量,所以不能赋值,也不能显示。

 

Varargin

摘自:http://blog.csdn.net/yefengnidie/article/details/4522002

 在写《用Matlab演示Parzen窗法》的时候,我还不知道怎样在m中设计可变参数函数。

      后来阅读一些m自带函数源码时发现了它的秘密,只要将最后一个参数设置为varargin,就可以实现。

      例如,写了一个函数:function test(varargin)

      那么在这个函数里,varargin就是一个cell数组,它包含了用户输入的参数。下面是一个例子:

function test(varargin)
disp(['nargin is ' num2str(nargin)]);
for v=1:numel(varargin)
      disp(['varargin{' num2str(v) '} class is ' class(varargin{v})]);
end

      完全就是使用cell数组的方法来处理用户输入的个数不定的参数,如果我们这样调用这个函数:

>> test()

      会得到结果:

nargin is 0

      表示用户输入参数个数为0个,就是没有输入参数。

      如果这样调用:

>> test(1,'a',uint8(32),'123456');

      会得到结果:

nargin is 4
varargin{1} class is double
varargin{2} class is char
varargin{3} class is uint8
varargin{4} class is char

      表示用户输入了4个参数,第一个是double类型,第二个是char类型,第三个是uint8类型,第四个也是char类型。

      也就是说,只要把函数的参数列表的最后一个参数写成varargin,就可以在函数内部以访问cell数组的方式来获取可变参数的信息。

Varargout

  Varargout和Varargin的功能正好相反!

posted @ 2012-01-29 15:48  梦不醒  阅读(1346)  评论(0编辑  收藏  举报