目录
MException函数的功能是捕获错误信息。
检测到错误并抛出异常的任何 MATLAB® 代码都构造一个 MException 对象。该 MException 对象包含有关错误的可检索信息。MATLAB 可以抛出预定义异常或您构造的异常。
- ME = MException(errID,msgtext,A1,...,An)
- ME = MException(errID,msgtext)
ME = MException(errID,msgtext) 捕获有关特定错误的信息,并将信息存储在 MException 对象 ME 中。MException 对象是使用错误标识符 errID 和错误消息 msgtext 构造的。
通过 ME = MException(errID,msgtext,A1,...,An),可以使用文本或数值 A1,...,An 设置错误消息的格式,以便在运行时替换 msgtext 中的转换设定符。
错误标识符,指定为字符向量或字符串标量。将错误标识符用于异常处理可以更好地识别错误来源或控制在程序中选择的异常子集。
错误标识符包括一个或多个组件字段和一个助记键字段。各字段必须用冒号分隔。例如,具有组件字段 component 和助记键字段 mnemonic 的错误标识符指定为 'component:mnemonic'。
组件字段通常指定可能出现各种错误的产品或功能。例如,错误标识符 'MATLAB:TooManyInputs' 有组件字段 MATLAB,这意味着在 MATLAB 中抛出异常。可以重用同一个助记键 TooManyInputs,只要在它前面加上不同组件即可。例如,如果想要每当调用函数时使用过多的输入就在工具箱中抛出异常,可以使用 'MyToolbox:TooManyInputs'。
错误标识符的助记键字段通常是特定于错误问题的标记。例如,当报告由于在 MATLAB 中使用模糊语法而导致的错误时,您可以将错误标识符指定为 'MATLAB:ambiguousSyntax'。
对象函数
throw | 引发异常 |
MException.last | 返回最后未捕获的异常 |
rethrow | 重新引发以前捕获的异常 |
throwAsCaller | 引发异常,如同发生在调用函数内 |
addCause | 记录异常的其他原因 |
addCorrection | 提供异常的建议修复 |
getReport | 获取异常的错误消息 |
创建 MException 对象来捕获关于输入错误的信息。
- errID = 'myComponent:inputError';
- msgtext = 'Input does not have the expected format.';
-
- ME = MException(errID,msgtext)
- ME =
- MException with properties:
-
- identifier: 'myComponent:inputError'
- message: 'Input does not have the expected format.'
- cause: {}
- stack: [0x1 struct]
- Correction: []
同时使用 msgtext 和 A1,...,An 输入参数来创建错误消息。
- errID = 'MATLAB:test';
- msgtext = 'There are %d errors on this page';
- A1 = 10;
-
- ME = MException(errID,msgtext,A1)
- ME =
- MException with properties:
-
- identifier: 'MATLAB:test'
- message: 'There are 10 errors on this page'
- cause: {}
- stack: [0x1 struct]
- Correction: []
如果工作区中没有输入变量名称,则会引发异常。
- str = input('Type a variable name: ','s');
- if ~exist(str,'var')
- ME = MException('MyComponent:noSuchVariable', ...
- 'Variable %s not found',str);
- throw(ME)
- end
在命令提示符处,输入工作区中不存在的任何变量。例如,输入 notaVariable。
Variable notaVariable not found
由于 notVariable 不在您的工作区中,MATLAB 会创建并抛出一个 MException 对象。
使用 try, catch 访问在 MException 对象中捕获的信息。
创建文件 myfile.m,其中包含对 surf 函数的不带输入的调用。(此函数调用会导致异常,用于演示目的。)捕获 MATLAB 在 MException 对象 ME 中抛出的异常,并通过访问 ME 的 message 属性来显示错误消息。
- try
- surf
- catch ME
- disp('Error Message:')
- disp(ME.message)
- end
- Error Message:
- Not enough input arguments.
提取错误标识符。
- ME.identifier
- ans =
-
- 'MATLAB:narginchk:notEnoughInputs'
查询 stack 属性的内容。在此示例中,调用堆栈表示为一个 2×1 结构体数组。
- for i = 1:numel(ME.stack)
- ME.stack(i)
- end
- ans =
-
- struct with fields:
-
- file: 'matlabroot\toolbox\matlab\graph3d\surf.m'
- name: 'surf'
- line: 49
-
-
- ans =
-
- struct with fields:
-
- file: 'c:\myMATLABfiles\myfile.m'
- name: 'myfile'
- line: 2
stack 的第一个元素显示发生异常的文件名 (surf.m)、函数名称 (surf) 和行号 (49)。stack 的第二个元素显示调用脚本中出现异常的名称和行号。
捕获通过调用不存在的函数 notaFunction 生成的异常。如果该函数未定义,会发出警告并为输出赋值 0。
- try
- a = notaFunction(5,6);
- catch ME
- if strcmp(ME.identifier,'MATLAB:UndefinedFunction')
- warning('Function is undefined. Assigning a value of 0.');
- else
- rethrow(ME)
- end
- end
- Warning: Function is undefined. Assigning a value of 0.
对 notaFunction 的调用本身会导致错误。使用 try 和 catch 时,此代码捕获未定义的函数异常并将其重新打包为警告,这样 MATLAB 就可以继续执行后续命令。如果捕获的异常具有不同的错误标识符,则 MATLAB 会重新引发该异常。