NullPointerException
s - исключения, возникающие при попытке использовать ссылку, которая указывает на отсутствие местоположения в памяти (null), как если бы она ссылалась на объект. Вызов метода по нулевой ссылке или попытка получить доступ к полю нулевой ссылки вызовет функцию NullPointerException
. Они наиболее распространены, но другие способы перечислены на странице NullPointerException
javadoc.
Вероятно, самый быстрый пример кода, который я мог бы придумать для иллюстрации NullPointerException
, be:
public class Example {
public static void main(String[] args) {
Object obj = null;
obj.hashCode();
}
}
В первой строке внутри main
я явно устанавливаю ссылку Object
obj
равной null
. Это означает, что у меня есть ссылка, но она не указывает на какой-либо объект. После этого я пытаюсь обработать ссылку так, как если бы она указывала на объект, вызывая метод на нем. Это приводит к NullPointerException
, потому что нет кода для выполнения в местоположении, на которое указывает ссылка.
(Это техничность, но я думаю, что она упоминает: ссылка, которая указывает на null, равна 't то же, что и указатель C, указывающий на недопустимую ячейку памяти. Нулевой указатель буквально не указывает на в любом месте , который отличается от указаний на местоположение, которое оказывается недопустимым.)
Ой, я не знаю, я никогда несу чушь записанный код, который вызывает Переполнение стека;)
Redmond.Microsoft.Core.Windows.Start()
Пролог
p:-p.
= 5 символов
тогда запускают его и запрашивают p
, я думаю, что это является довольно маленьким и исчерпывает стек в прологе.
запрос просто переменной в swi прологе производит:
? - X. %... 1,000,000............ 10,000,000 лет спустя % %>> 42 < < (последний выпуск дает вопрос)
, и вот другая fork-бомба удара:: () {: |:&};:
Я думаю, что это будет работать в (непроверенном) Java:
enum A{B.values()}
enum B{A.values()}
Должен переполниться в статической инициализации, прежде чем это даже получит шанс перестать работать из-за отсутствия основных (Строка []).
Ruby:
def i()i()end;i()
(17 символов)
real n(0)
n(1)=0
end
или
call main
end
Второй случай зависит от компилятора; для GNU Fortran его нужно будет скомпилировать с -fno-underscoring
.
(Оба счетчика включают обязательные символы новой строки)
Python:
import sys
sys.setrecursionlimit(sys.maxint)
def so():
so()
so()
eval(t="eval(t)")
t="Execute(t)":Execute(t)