Что самый короткий код должен вызвать переполнение стека? [закрытый]

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, указывающий на недопустимую ячейку памяти. Нулевой указатель буквально не указывает на в любом месте , который отличается от указаний на местоположение, которое оказывается недопустимым.)

160
задан 19 revs, 9 users 62% 23 May 2017 в 12:26
поделиться

131 ответ

Ой, я не знаю, я никогда несу чушь записанный код, который вызывает Переполнение стека;)

-6
ответ дан kashifrazzaqui 23 November 2019 в 21:27
поделиться
Redmond.Microsoft.Core.Windows.Start()
-4
ответ дан 2 revs, 2 users 67% 23 November 2019 в 21:27
поделиться

Пролог

p:-p.

= 5 символов

тогда запускают его и запрашивают p

, я думаю, что это является довольно маленьким и исчерпывает стек в прологе.

запрос просто переменной в swi прологе производит:

? - X. %... 1,000,000............ 10,000,000 лет спустя % %>> 42 < < (последний выпуск дает вопрос)

, и вот другая fork-бомба удара:: () {: |:&};:

-1
ответ дан 2 revs 23 November 2019 в 21:27
поделиться

Я думаю, что это будет работать в (непроверенном) Java:

enum A{B.values()}
enum B{A.values()}

Должен переполниться в статической инициализации, прежде чем это даже получит шанс перестать работать из-за отсутствия основных (Строка []).

-1
ответ дан Daniel Spiewak 23 November 2019 в 21:27
поделиться

Ruby:

def i()i()end;i()

(17 символов)

-1
ответ дан Ashley Williams 23 November 2019 в 21:27
поделиться

Фортран, 13 и 20 символов

real n(0)
n(1)=0
end

или

call main
end

Второй случай зависит от компилятора; для GNU Fortran его нужно будет скомпилировать с -fno-underscoring .

(Оба счетчика включают обязательные символы новой строки)

0
ответ дан 23 November 2019 в 21:27
поделиться

Haskell:

main = print $ x 1 where x y = x y + 1
0
ответ дан 23 November 2019 в 21:27
поделиться

Dyalog APL

fib←{
    ⍵∊0 1:⍵
    +/∇¨⍵-1 2
}
0
ответ дан 23 November 2019 в 21:27
поделиться
int main(void) { return main(); }
0
ответ дан 23 November 2019 в 21:27
поделиться

Python:

import sys  
sys.setrecursionlimit(sys.maxint)  
def so():  
    so()  
so()
0
ответ дан 23 November 2019 в 21:27
поделиться

JavaScript (17 байтов)

eval(t="eval(t)")

VB Script (25 байтов)

t="Execute(t)":Execute(t)
0
ответ дан 23 November 2019 в 21:27
поделиться
Другие вопросы по тегам:

Похожие вопросы: