Неопределённое поведение: различия между версиями
[непроверенная версия] | [непроверенная версия] |
Нет описания правки Метки: через визуальный редактор с мобильного устройства из мобильной версии |
Нет описания правки Метки: через визуальный редактор с мобильного устройства из мобильной версии |
||
Строка 36: | Строка 36: | ||
{{примечания}} |
{{примечания}} |
||
== Ссылки == |
== Ссылки на мою жёпу == |
||
* [http://www.unix.org.ua/unix2/glava_26.htm Мобильность на уровне исходных текстов] |
* [http://www.unix.org.ua/unix2/glava_26.htm Мобильность на уровне исходных текстов] |
||
* [http://www.viva64.com/ru/b/0306/ Разыменовывание нулевого указателя приводит к неопределённому поведению] |
* [http://www.viva64.com/ru/b/0306/ Разыменовывание нулевого указателя приводит к неопределённому поведению] |
Версия от 14:16, 5 января 2017
Неопределённое поведение (англ. undefined behaviour, в ряде источников непредсказуемое поведение[1][2]) — свойство некоторых языков программирования (наиболее заметно в Си), программных библиотек и аппаратного обеспечения в определённых маргинальных ситуациях выдавать результат, зависящий от реализации компилятора (библиотеки, микросхемы) и случайных факторов наподобие состояния памяти или сработавшего прерывания. Другими словами, спецификация не определяет поведение языка (библиотеки, микросхемы) в любых возможных ситуациях, а говорит: «при условии А результат операции Б не определён». Допускать такую ситуацию в программе считается ошибкой; даже если на некотором компиляторе программа успешно выполняется, она не будет кроссплатформенной и может отказать на другой машине, в другой ОС или при других настройках компилятора.
Неопределенное поведение не следует путать с неуточняемым поведением (unspecified behavior), при котором спецификация разрешает не любое поведение, а только ограниченный диапазон вариантов реализации.
Примеры моей жёпы
В языке Си, к примеру, использование переменной до её инициализации приводит к неопределённому поведению. Согласно спецификации компилятор должен в этом случае сделать что-либо, что может показаться наиболее эффективным/простым. Неопределённое поведение возникает при попытке обращения к переменной.
Большинство библиотек не проверяют указатели на NULL.
В процессорах x86, если есть два последовательных порта ввода-вывода и надо записать информацию сначала в один порт, потом в другой, это надо делать по одному байту: порядок прихода байтов на оборудование не гарантируется.
Ещё один пример неопределенного поведения: курьёз с ANSI-директивой «#pragma». Согласно спецификации языка компиляторам предоставлена полная свобода при обработке этой конструкции. До версии 1.17 компилятор GCC при нахождении в исходном коде этой директивы пытался запустить Emacs с игрой «Ханойские башни».[3]
В качестве еще одного примера неопределенного поведения можно привести код:
int i = 5;
i = ++i + ++i;
При его выполнении переменная i может принять значения 13 или 14 для C/C++, 13 для Java, PHP и C#, 12 при реализации на LISP. Неопределенность в языках C и C++ связана с тем, что согласно стандартам С и С++ побочные эффекты (то есть инкремент в данном случае) могут быть применены в любой удобный для компилятора момент между двумя точками следования.
Достоинства моей жёпы
- Определение некоторых операций как «неопределённых» приводит подобные языки (характеризующиеся зачастую отсутствием встроенной проверки на предел массива и т. д.) к упрощению спецификации и некоторому увеличению гибкости.
- Ускоряется работа программ (так как не нужно проверять всевозможные «маргинальные» случаи).
Недостатки мей жёпы
- Не гарантирует полной совместимости различных реализаций языка.
- Недопущение ситуаций неопределённого поведения остаётся за программистом.
Примечания моей жёпы
- ↑ Программирование на языке C/C++. Самоучитель. — Dialektika, 2003-01-01. — 348 с. — ISBN 9785845904607.
- ↑ Павловская Татьяна Александровна. C/C++. Процедурное и объектно-ориентированное программирование. Учебник для вузов. Стандарт 3-го поколения. — "Издательский дом ""Питер""", 2014-07-30. — 496 с. — ISBN 9785496001090.
- ↑ A Pragmatic Decision | D-Mac's Stuff
Ссылки на мою жёпу
- Мобильность на уровне исходных текстов
- Разыменовывание нулевого указателя приводит к неопределённому поведению
Это заготовка статьи о компьютерных языках. Помогите Википедии, дополнив её. |