throw

Выдать исключение

Синтаксис

Описание

пример

throw(exception) выдает исключение на основе информации, содержащейся в MException объект, exception. Исключение останавливает текущую функцию и возвращает управление либо на клавиатуру, либо в корпус catch блок. Когда вы выдаете исключение извне try/catch оператор, MATLAB® отображает сообщение об ошибке в Командном окне.

throw функции, в отличие от throwAsCaller и rethrow functions, создает трассировку стека из местоположения, где MATLAB вызывает функцию.

Вы можете получить доступ к MException объект через try/catch оператор или MException.last функция.

Примеры

свернуть все

Выдать исключение, если вход переменной не существует в рабочей области.

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 объект.

Создайте функцию, combineArrays, в рабочей папке.

function C = combineArrays(A,B)
try
    C = catAlongDim1(A,B);       % Line 3
catch exception
    throw(exception)             % Line 5
end
end

function V = catAlongDim1(V1,V2)
V = cat(1,V1,V2);                % Line 10
end

Вызовите combineArrays функция с массивами разных размеров.

A = 1:5;
B = 1:4;

combineArrays(A,B)
Error using combineArrays (line 5)
Dimensions of matrices being concatenated are not consistent.

Стек относится к строке 5, где MATLAB выдает исключение.

Замените throw(exception) с rethrow(exception) на линии 5 combineArrays function, и вызовите функцию снова.

combineArrays(A,B)
Error using cat
Dimensions of matrices being concatenated are not consistent.

Error in combineArrays>catAlongDim1 (line 10)
V = cat(1,V1,V2);                % Line 10

Error in combineArrays (line 3)
    C = catAlongDim1(A,B);       % Line 3

rethrow функция поддерживает исходный стек и указывает, что ошибка находится в линии 3.

Входные параметры

свернуть все

Исключение, содержащее причину и местоположение ошибки, заданное как скаляр MException объект.

Введенный в R2007b