Russian Belarusian English German Japanese Ukrainian

Longjmp

CuBook05

Функция

Выполняет нелокальный переход.
 
Синтаксис

#include <setjmp.h>
void longjmp(jmp_buf jmpb, int retval);
 
Прототип

setjmp.h
 
Описание

Вызов функции longjmp восстанавливает состояние задачи, которое было установлено при последнем вызове функции setjmp с аргументом jmpb. Затем она возвращает значение retval также, как и функция setjmp.

Состояние задачи представляет собой следующее:
  • все сегментные регистры (CX,DS,ES,SS);
  • переменные-регистры (SI,DI);
  • указатель стека (SP);
  • указатель базы (BP);
  • флаги.
Состояние задачи является достаточно полным, так что функции setjmp и longjmp могут быть использованы как инструмент для организации сопрограмм. Данные подпрограммы могут быть полезны для работы с ошибками и исключительными ситуациями, происходящими в низкоуровневых подпрограммах прикладных программ.

Перед использованием функции longjmp необходимо вызвать функцию setjmp. Программа вызывающая setjmp и устанавливающая jmpb должна оставаться активной и не должна возвращать управления до вызова longjmp. Если это случится, то результат непредсказуем.

Функция longjmp не может посылать значение 0. Если 0 посылается в retval, то он заменяется на 1.

Примечание. Функции setjmp и longjmp нельзя использовать для реализации оверлейных программ. Обычно setjmp и longjmp сохраняют и восстананавливают все, необходимые для реализации сопрограмм, однако для управления оверлеями необходимо следить за стеком, причем подразумевается, что стек один. При реализации сопрограмм вы обычно используете два стека, или две части одного стека, и поэтому администратор оверлеев не сможет корректно их отслеживать.

Вы можете иметь задачи, работающие в фоновом режиме, которые используют свой стек, или свой раздел общего стека, однако вы должны быть уверены, что они не используют оверлеев, и вы не должны использовать оверлейные версии setjmp и longjmp для переключения на эти фоновые задачи.
 
Возвращаемое значение

Нет.
 
Переносимость

Функция поддерживаются на системах UNIX и стандартом ANSI C. Функция не совместима с Windows.
 
Пример

#include <stdio.h>
#include <setjmp.h>

int main(void)
{
jmp_buf jumper;
int value;
value = setjmp(jumper);
if (value != 0) {
printf("longjmp со значением %d\n", value);
exit(value);
}
printf("Вызов подпрограммы ... \n");
subroutine();
}
subroutine()
{
longjmp(jumper,l);
}
Если заметили ошибку, выделите фрагмент текста и нажмите Ctrl+Enter

Добавить комментарий


Защитный код Обновить