Запутанный вывод из бесконечной рекурсии в 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(), Ниже приведены похожие ответы. Но почему?

Какова будет действительная причина?

Ответы на вопрос(7)

Ваш ответ на вопрос