Запутанный вывод из бесконечной рекурсии в try-catch
Рассмотрим следующий код.
public class Action {
private static int i=1;
public static void main(String[] args) {
try{
System.out.println(i);
i++;
main(args);
}catch (StackOverflowError e){
System.out.println(i);
i++;
main(args);
}
}
}
Я получаю, я ценю до4338
правильно. После ловлиStackOverflowError
Выход подключается следующим образом.
4336
4337
4338 // up to this point out put can understand
433943394339 // 4339 repeating thrice
434043404340
4341
434243424342
434343434343
4344
4345
434643464346
434743474347
4348
434943494349
435043504350
Рассмотреть возможностьЖить демо здесь. Работает правильно доi=4330
, Собственно как это случилось?
FYI:
Я сделал следующий код, чтобы понять, что здесь происходит.
public class Action {
private static int i = 1;
private static BufferedWriter bw;
static {
try {
bw = new BufferedWriter(new FileWriter("D:\\sample.txt"));
} catch (IOException e) {
e.printStackTrace();
}
}
public static void main(String[] args) throws IOException {
bw.append(String.valueOf(i)+" ");
try {
i++;
main(args);
} catch (StackOverflowError e) {
bw.append(String.valueOf(i)+" ");
i++;
main(args);
}
}
}
Сейчас предыдущего номера нет. теперь значениеi
вплоть до16824744
исправь и беги дальше. Я прыгаю это может прибегает к стоимостиi=2,147,483,647
(максимальное значение int) без проблем.
Существует некоторая проблема сprintln()
, Ниже приведены похожие ответы. Но почему?
Какова будет действительная причина?