Последнее сообщение об ошибке и сопутствующая информация
lasterror будет удален в будущей версии. Можно получить информацию о любой ошибке, которая была сгенерирована путем ловли MException. Смотрите информацию о Получении Об Исключениях в документации Основ программирования.
s = lasterror
s = lasterror(err)
s = lasterror('reset')
s = lasterror возвращает структуру s, содержащий информацию о новой ошибке, выпущенной MATLAB. Структура возврата содержит следующие поля:
| Имя поля | Описание |
|---|---|
| Символьный массив, содержащий текст сообщения об ошибке. |
| Символьный массив, содержащий идентификатор сообщения сообщения об ошибке. Если последняя ошибка, выпущенная MATLAB, не имела никакого идентификатора сообщения, то поле |
| Информация о предоставляющем структуры о местоположении ошибки. Структура имеет поля |
lasterror возвращается, структура может содержать дополнительные поля в будущих версиях MATLAB.
Поля структуры, возвращенной в stack,
| Имя поля | Описание |
|---|---|
| Имя файла, в котором появляется функция, генерирующая ошибку. Это поле является пустым символьным вектором, если нет никакого файла. |
| Имя функции, в котором произошла ошибка. Если это - первичная функция в файле, и имя функции отличается от имени файла, |
| Номер строки файла, в котором произошла ошибка. |
Смотрите Идентификаторы сообщений в документации Основ программирования MATLAB для получения дополнительной информации о синтаксисе и использовании идентификаторов сообщений.
s = lasterror(err) устанавливает последнюю информацию об ошибке на сообщение об ошибке и идентификатор, заданный в структуре err. Последующие вызовы lasterror возвращают эту новую информацию об ошибке. Дополнительная структура возврата s содержит информацию о предыдущей ошибке.
s = lasterror('reset') устанавливает последнюю информацию об ошибке на состояние по умолчанию. В этом состоянии поля message и identifier структуры возврата являются пустыми символьными векторами, и поле stack 0 1 структура.
Сохраните следующий код MATLAB в файле под названием average.m:
function y = average(x)
% AVERAGE Mean of vector elements.
% AVERAGE(X), where X is a vector, is the mean of vector elements.
% Nonvector input results in an error.
check_inputs(x)
y = sum(x)/length(x); % The actual computation
function check_inputs(x)
[m,n] = size(x);
if (~((m == 1) || (n == 1)) || (m == 1 && n == 1))
error('AVG:NotAVector', 'Input must be a vector.')
endТеперь запустите функцию. Поскольку эта функция требует, чтобы векторный вход, передавая скалярное значение ей обеспечил ошибку. Ошибка происходит в стандартной подпрограмме check_inputs:
average(200) Error using average>check_inputs (line 11) Input must be a vector. Error in average (line 5) check_inputs(x)
Получите эти три поля от lasterror:
err = lasterror
err =
message: [1x61 char]
identifier: 'AVG:NotAVector'
stack: [2x1 struct]
Отобразите текст сообщения об ошибке:
msg = err.message
msg =
Error using average>check_inputs (line 11)
Input must be a vector.Отобразите поля, содержащие информацию о stack. err.stack 2 1 структура, потому что это предоставляет информацию о провальной стандартной подпрограмме check_inputs и также внешняя, первичная функция average:
st1 = err.stack(1,1)
st1 =
file: 'd:\matlab_test\average.m'
name: 'check_inputs'
line: 11
st2 = err.stack(2,1)
st2 =
file: 'd:\matlab_test\average.m'
name: 'average'
line: 5Как правило, имя вашей первичной функции должно совпасть с именем файла, который содержит эту функцию. Если эти имена отличаются, MATLAB использует имя файла в поле name структуры stack.
lasterror часто используется в сочетании с функцией MException.rethrow в операторах try, catch. Например,
try do_something catch do_cleanup rethrow(lasterror) end
MathWorks® постепенно переходит обработку ошибок MATLAB к объектно-ориентированной схеме, которая основана на классе MException. Несмотря на то, что поддержка lasterror, как ожидают, продолжится, использование статического метода MException.last MException предпочтительно.
lasterror и MException.last, как гарантируют, всегда не возвратят идентичные результаты. Например, MException.last обновляет свое ошибочное состояние только при непойманных ошибках, где lasterror может обновить свое ошибочное состояние при любой ошибке, отловлено ли это или нет.
MException | MException.last | MException.rethrow | assert | dbstack | error | lastwarn | try, catch