008_function_convention_in_Matlab中的函数约定

2024-03-28 21:04

本文主要是介绍008_function_convention_in_Matlab中的函数约定,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Matlab中的函数约定

1. 脚本与函数与文件

前面讲的所有内容,都可以在Matlab的命令行中间完成,但是我们的某一段计算,可能会希望能够多次运行,这个时候Matlab提供的基于文件约定的脚本和函数基本单元就派上了用场。

约定:Matlab中,一个文件就自动形成一个可以运行的命令或者可以调用的函数,调用方式就是文件名(去掉后缀)。

当然,脚本和函数区分的约定就在于文件头。一个文件的第一个有效行是一个function定义,那么这个文件就是一个函数,否则就是一个脚本。

在Matlab命令行中输入edit filename,就可以编辑一个文件,如果这个文件在搜索目标中不存在,那么Matlab会提示创建一个新文件。

1.1 搜索目录

上面提到的第一个概念就是搜索目录,Matlab在搜索目录中查找文件。如果使用过任何shell,那么这个概念就很熟悉了。

Matlab的搜索目录是一个cell数组,可以通过path函数查看搜索目录,通过addpathrmpath函数添加和删除搜索目录。

跟搜索路径相关的函数addpath, matlabroot, restoredefaultpath, pathtool, rehash, rmpath。利用Matalb的帮助系统查看这些函数的用法。

1.2 脚本

脚本的后缀是.m,脚本文件的第一个有效行不是function定义。

在Matlab命令行中输入文件名(去掉.m后缀),就可以运行这个脚本文件。Matlab解释器会从前到后执行文件中的所有语句。

1.3 函数

函数的后缀是.m,函数文件的第一个有效行是function定义。函数定义的语法是:

function [out1, out2, ...] = myfun(in1, in2, ...)

其中,myfun是函数名,out1, out2, ...是输出参数,in1, in2, ...是输入参数。

约定:函数文件的文件名和函数名一致,最好这么做。

函数文件的文件名是函数名,如果函数名和文件名不一致,那么Matlab解释器会根据文件名来调用函数,并且在编辑函数代码时,会提醒修改函数名称。

2. 函数

除了上面给出的函数方式,还有另外几种函数定义方式。

2.1 匿名函数

匿名函数是一种简单的函数定义方式,语法是:

f = @(x) x^2

这个语句定义了一个函数f,这个函数接受一个参数x,返回x^2

2.2 函数句柄

函数句柄是一种函数的引用方式,可以用来传递函数,或者在函数中调用函数。函数句柄的定义方式是:

f = @myfun

这个语句定义了一个函数句柄f,指向函数myfun

在某些时候,还能通过字符串来定义函数句柄,这个时候就需要用到str2func函数。

f = str2func('myfun')

在某些场合,这个函数会自动被调用,当需要得到函数句柄时,传递同名的字符串,就会自动转换为函数句柄。

f = 'myfun'

2.3 函数调用

函数调用的方式跟定义函数的语句差不多,去掉function关键字。

[out1, out2, ...] = myfun(in1, in2, ...)

约定:当函数的输入参数个数为0时,可以省略括号。

这个约定非常好玩,因为这个时候函数调用就跟变量一样。实际上,这可以用来定义常量。

function y = mypi()  % 这个括号也可以省略y = 3.14;
end

这个函数可以这样调用:

mypi

也可以在计算式中直接使用mypi, 实际计算按照其返回值进行。

在举个例子,逻辑变量truefalse就是这样类似的函数。

可以直接使用truefalse,也可以用true()false(),还可以输入参数true(n1, n2)false(n1, n2)

调用函数句柄的方式跟调用普通的函数一样,在函数句柄后面加上参数列表。

值得注意的的是,当把函数作为参数传递给另外一个函数的时候,可以使用函数句柄,也可以用@符号来访问搜索目标中的函数,还可以直接传递匿名函数,例如@(x) x^2,或者代表函数的字符串。

3. 函数的输入输出

3.1 显式的输入和输出

在利用上面的function定义函数的时候,可以指定函数的输入和输出参数。函数的输入和输出参数是通过参数列表来指定的。

function [out1, out2, ...] = myfun(in1, in2, ...)

函数的输入和输出个数可以通过narginnargout函数来获取。

nargin('myfun')
nargout('myfun')% or
nargin(@myfun) % 这个函数的输入参数个数
nargout(@myfun) % 这个函数的输出参数个数

当在一个函数的内部(就是在函数定义语句之后、对应的end之前)调用不带参数的narginnargout函数时,会返回当前函数的输入和输出参数个数。

3.2 隐式的输入和输出

函数的输入和输出可以通过参数列表来指定,也可以通过vararginvarargout来实现。组合使用这两个函数和narginnargout函数,可以实现函数的输入和输出参数的灵活控制。

function varargout = arg_copy(varargin)
fprintf('%d --> %d \n', nargin, nargout);if nargout == 0return;
elsevarargout = cell(1, nargout);
endif nargin == 0 && nargout ~= 0varargout{1:nargout} = "Not defined";return;
endif nargout <= narginvarargout(1:nargout) = varargin(1:nargout);
elsevarargout(1:nargin) = varargin(1:nargin);varargout{nargin+1:nargout} = "Not defined";
end

这个函数能够处理任意数量的输入和输出,并把输入逐一拷贝到输出。如果输入不够,那么输出就用"Not defined"来填充。

后面还要讲专门到cell数组,目前我们只需要知道cell数组是一种特殊的数组,可以存放任意类型的数据,也可以存放不同类型的数据。

而函数的输入和输出,都是采取跟cell数组类似的方式来处理的。

关于这个还值得专门写一个帖子,还有挺多好玩的东西。

4. 结论

  1. Matlab用文件来组织代码,一个文件就是一个可以运行的命令或者可以调用的函数。
  2. 函数用function或者@的方式来定义。
  3. 函数的输入和输出参数可以通过显式的参数列表来指定,也可以通过vararginvarargout来实现。
  4. 建议遵守Matlab的函数命名约定,即函数文件的文件名和函数名一致,并且把函数的输入和输出参数都写在函数定义的第一行。

这篇关于008_function_convention_in_Matlab中的函数约定的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/856691

相关文章

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

MySQL count()聚合函数详解

《MySQLcount()聚合函数详解》MySQL中的COUNT()函数,它是SQL中最常用的聚合函数之一,用于计算表中符合特定条件的行数,本文给大家介绍MySQLcount()聚合函数,感兴趣的朋... 目录核心功能语法形式重要特性与行为如何选择使用哪种形式?总结深入剖析一下 mysql 中的 COUNT

MySQL 中 ROW_NUMBER() 函数最佳实践

《MySQL中ROW_NUMBER()函数最佳实践》MySQL中ROW_NUMBER()函数,作为窗口函数为每行分配唯一连续序号,区别于RANK()和DENSE_RANK(),特别适合分页、去重... 目录mysql 中 ROW_NUMBER() 函数详解一、基础语法二、核心特点三、典型应用场景1. 数据分