Heap & Stack Java
Я знаю, что ссылки на объекты создаются в памяти стека а сами объекты в куче. В коде ниже я пытаюсь переполнить кучу создавая большое количество объектов Main(), используя зацикленность в конструкторе, и вместо outOfMemoryError получаю stackOverflow.
public class Main {
public Main() {
new Main();
}
public static void main(String args) {
new Main();
}
}
Почему? Как мне переполнить кучу?
java
|
показать ещё 2 комментария
Я знаю, что ссылки на объекты создаются в памяти стека а сами объекты в куче. В коде ниже я пытаюсь переполнить кучу создавая большое количество объектов Main(), используя зацикленность в конструкторе, и вместо outOfMemoryError получаю stackOverflow.
public class Main {
public Main() {
new Main();
}
public static void main(String args) {
new Main();
}
}
Почему? Как мне переполнить кучу?
java
1
Стек намного меньше кучи.
– Кирилл Малышев
5 часов назад
сделайте так, чтобы один объект съедал 100мб
– Stranger in the Q
5 часов назад
1
Вот, например OutOfMemoryError ideone.com/XjmuMf
– Кирилл Малышев
5 часов назад
@Кирилл а чем я в моем случае так переполняет стек?
– CapitaNemo
5 часов назад
рекурсия порождает на стеке адреса возврата
– Stranger in the Q
4 часа назад
|
показать ещё 2 комментария
Я знаю, что ссылки на объекты создаются в памяти стека а сами объекты в куче. В коде ниже я пытаюсь переполнить кучу создавая большое количество объектов Main(), используя зацикленность в конструкторе, и вместо outOfMemoryError получаю stackOverflow.
public class Main {
public Main() {
new Main();
}
public static void main(String args) {
new Main();
}
}
Почему? Как мне переполнить кучу?
java
Я знаю, что ссылки на объекты создаются в памяти стека а сами объекты в куче. В коде ниже я пытаюсь переполнить кучу создавая большое количество объектов Main(), используя зацикленность в конструкторе, и вместо outOfMemoryError получаю stackOverflow.
public class Main {
public Main() {
new Main();
}
public static void main(String args) {
new Main();
}
}
Почему? Как мне переполнить кучу?
java
java
задан 5 часов назад
CapitaNemoCapitaNemo
1075
1075
1
Стек намного меньше кучи.
– Кирилл Малышев
5 часов назад
сделайте так, чтобы один объект съедал 100мб
– Stranger in the Q
5 часов назад
1
Вот, например OutOfMemoryError ideone.com/XjmuMf
– Кирилл Малышев
5 часов назад
@Кирилл а чем я в моем случае так переполняет стек?
– CapitaNemo
5 часов назад
рекурсия порождает на стеке адреса возврата
– Stranger in the Q
4 часа назад
|
показать ещё 2 комментария
1
Стек намного меньше кучи.
– Кирилл Малышев
5 часов назад
сделайте так, чтобы один объект съедал 100мб
– Stranger in the Q
5 часов назад
1
Вот, например OutOfMemoryError ideone.com/XjmuMf
– Кирилл Малышев
5 часов назад
@Кирилл а чем я в моем случае так переполняет стек?
– CapitaNemo
5 часов назад
рекурсия порождает на стеке адреса возврата
– Stranger in the Q
4 часа назад
1
1
Стек намного меньше кучи.
– Кирилл Малышев
5 часов назад
Стек намного меньше кучи.
– Кирилл Малышев
5 часов назад
сделайте так, чтобы один объект съедал 100мб
– Stranger in the Q
5 часов назад
сделайте так, чтобы один объект съедал 100мб
– Stranger in the Q
5 часов назад
1
1
Вот, например OutOfMemoryError ideone.com/XjmuMf
– Кирилл Малышев
5 часов назад
Вот, например OutOfMemoryError ideone.com/XjmuMf
– Кирилл Малышев
5 часов назад
@Кирилл а чем я в моем случае так переполняет стек?
– CapitaNemo
5 часов назад
@Кирилл а чем я в моем случае так переполняет стек?
– CapitaNemo
5 часов назад
рекурсия порождает на стеке адреса возврата
– Stranger in the Q
4 часа назад
рекурсия порождает на стеке адреса возврата
– Stranger in the Q
4 часа назад
|
показать ещё 2 комментария
1 ответ
1
текущие
по дате публикации
голоса
На каждый вызов функции в памяти выделяется кусок стека. В нём хранятся адрес возврата в вызывающую функцию, локальные ссылки, примитивные переменные и, возможно, другая служебная информация. При выходе из функции стек очищается. Но из-за рекурсии вы не выходите из функции, пока не перестанете вызывать функцию саму из себя. Соответственно, размер стека стремительно растёт и возникает его переполнение.
Чтобы добиться ошибки OutOfMemoryError
, объекты должны занимать в памяти слишком много места. Обычно эта ошибка возникает либо из-за выделения слишком большого куска памяти (например, огромный массив)
static int arr = new int[1000000000];
либо из-за утечек памяти.
Как правило, размер стека намного меньше размера кучи. Если размер стека обычно измеряют мегабайтами или десятками мегабайт, то размер кучи может достигать сотен мегабайт или нескольких гигабайт. Именно поэтому, у вас программа падает с ошибкой StackOverflowError
.
сразу бы так ответили, а не в комментариях, теперь понял, спасибо вам)
– CapitaNemo
4 часа назад
добавить комментарий |
Ваш ответ
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "609"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "на платформе u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "Пользовательский контент попадает под действие u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003eлицензии cc by-sa 3.0u003c/au003e с u003ca href="https://stackoverflow.com/legal/content-policy"u003eуказанием ссылки на источникu003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Зарегистрируйтесь или войдите
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
var $window = $(window),
onScroll = function(e) {
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom)) {
StackExchange.using('gps', function() { StackExchange.gps.track('embedded_signup_form.view', { location: 'question_page' }); });
$window.unbind('scroll', onScroll);
}
};
$window.on('scroll', onScroll);
});
Регистрация через Google
Регистрация через Facebook
Регистрация через почту
Отправить без регистрации
Необходима, но никому не показывается
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fru.stackoverflow.com%2fquestions%2f956181%2fheap-stack-java%23new-answer', 'question_page');
}
);
Отправить без регистрации
Необходима, но никому не показывается
1 ответ
1
текущие
по дате публикации
голоса
1 ответ
1
текущие
по дате публикации
голоса
текущие
по дате публикации
голоса
текущие
по дате публикации
голоса
На каждый вызов функции в памяти выделяется кусок стека. В нём хранятся адрес возврата в вызывающую функцию, локальные ссылки, примитивные переменные и, возможно, другая служебная информация. При выходе из функции стек очищается. Но из-за рекурсии вы не выходите из функции, пока не перестанете вызывать функцию саму из себя. Соответственно, размер стека стремительно растёт и возникает его переполнение.
Чтобы добиться ошибки OutOfMemoryError
, объекты должны занимать в памяти слишком много места. Обычно эта ошибка возникает либо из-за выделения слишком большого куска памяти (например, огромный массив)
static int arr = new int[1000000000];
либо из-за утечек памяти.
Как правило, размер стека намного меньше размера кучи. Если размер стека обычно измеряют мегабайтами или десятками мегабайт, то размер кучи может достигать сотен мегабайт или нескольких гигабайт. Именно поэтому, у вас программа падает с ошибкой StackOverflowError
.
сразу бы так ответили, а не в комментариях, теперь понял, спасибо вам)
– CapitaNemo
4 часа назад
добавить комментарий |
На каждый вызов функции в памяти выделяется кусок стека. В нём хранятся адрес возврата в вызывающую функцию, локальные ссылки, примитивные переменные и, возможно, другая служебная информация. При выходе из функции стек очищается. Но из-за рекурсии вы не выходите из функции, пока не перестанете вызывать функцию саму из себя. Соответственно, размер стека стремительно растёт и возникает его переполнение.
Чтобы добиться ошибки OutOfMemoryError
, объекты должны занимать в памяти слишком много места. Обычно эта ошибка возникает либо из-за выделения слишком большого куска памяти (например, огромный массив)
static int arr = new int[1000000000];
либо из-за утечек памяти.
Как правило, размер стека намного меньше размера кучи. Если размер стека обычно измеряют мегабайтами или десятками мегабайт, то размер кучи может достигать сотен мегабайт или нескольких гигабайт. Именно поэтому, у вас программа падает с ошибкой StackOverflowError
.
сразу бы так ответили, а не в комментариях, теперь понял, спасибо вам)
– CapitaNemo
4 часа назад
добавить комментарий |
На каждый вызов функции в памяти выделяется кусок стека. В нём хранятся адрес возврата в вызывающую функцию, локальные ссылки, примитивные переменные и, возможно, другая служебная информация. При выходе из функции стек очищается. Но из-за рекурсии вы не выходите из функции, пока не перестанете вызывать функцию саму из себя. Соответственно, размер стека стремительно растёт и возникает его переполнение.
Чтобы добиться ошибки OutOfMemoryError
, объекты должны занимать в памяти слишком много места. Обычно эта ошибка возникает либо из-за выделения слишком большого куска памяти (например, огромный массив)
static int arr = new int[1000000000];
либо из-за утечек памяти.
Как правило, размер стека намного меньше размера кучи. Если размер стека обычно измеряют мегабайтами или десятками мегабайт, то размер кучи может достигать сотен мегабайт или нескольких гигабайт. Именно поэтому, у вас программа падает с ошибкой StackOverflowError
.
На каждый вызов функции в памяти выделяется кусок стека. В нём хранятся адрес возврата в вызывающую функцию, локальные ссылки, примитивные переменные и, возможно, другая служебная информация. При выходе из функции стек очищается. Но из-за рекурсии вы не выходите из функции, пока не перестанете вызывать функцию саму из себя. Соответственно, размер стека стремительно растёт и возникает его переполнение.
Чтобы добиться ошибки OutOfMemoryError
, объекты должны занимать в памяти слишком много места. Обычно эта ошибка возникает либо из-за выделения слишком большого куска памяти (например, огромный массив)
static int arr = new int[1000000000];
либо из-за утечек памяти.
Как правило, размер стека намного меньше размера кучи. Если размер стека обычно измеряют мегабайтами или десятками мегабайт, то размер кучи может достигать сотен мегабайт или нескольких гигабайт. Именно поэтому, у вас программа падает с ошибкой StackOverflowError
.
ответ дан 4 часа назад
Кирилл МалышевКирилл Малышев
5,2151420
5,2151420
сразу бы так ответили, а не в комментариях, теперь понял, спасибо вам)
– CapitaNemo
4 часа назад
добавить комментарий |
сразу бы так ответили, а не в комментариях, теперь понял, спасибо вам)
– CapitaNemo
4 часа назад
сразу бы так ответили, а не в комментариях, теперь понял, спасибо вам)
– CapitaNemo
4 часа назад
сразу бы так ответили, а не в комментариях, теперь понял, спасибо вам)
– CapitaNemo
4 часа назад
добавить комментарий |
Спасибо за ваш ответ на Stack Overflow на русском!
- Пожалуйста, убедитесь, что публикуемое сообщение отвечает на поставленный вопрос. Предоставьте как можно больше деталей, расскажите про проведенное исследование!
Но избегайте …
- Просьб помощи, уточнений или ответов на темы не относящиеся к вопросу.
- Ответов основанных на мнениях; приводите аргументы основанные только на реальном опыте.
Также, обратите внимание на заметку в справочном центре о том, как писать ответы.
Зарегистрируйтесь или войдите
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
var $window = $(window),
onScroll = function(e) {
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom)) {
StackExchange.using('gps', function() { StackExchange.gps.track('embedded_signup_form.view', { location: 'question_page' }); });
$window.unbind('scroll', onScroll);
}
};
$window.on('scroll', onScroll);
});
Регистрация через Google
Регистрация через Facebook
Регистрация через почту
Отправить без регистрации
Необходима, но никому не показывается
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fru.stackoverflow.com%2fquestions%2f956181%2fheap-stack-java%23new-answer', 'question_page');
}
);
Отправить без регистрации
Необходима, но никому не показывается
Зарегистрируйтесь или войдите
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
var $window = $(window),
onScroll = function(e) {
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom)) {
StackExchange.using('gps', function() { StackExchange.gps.track('embedded_signup_form.view', { location: 'question_page' }); });
$window.unbind('scroll', onScroll);
}
};
$window.on('scroll', onScroll);
});
Регистрация через Google
Регистрация через Facebook
Регистрация через почту
Отправить без регистрации
Необходима, но никому не показывается
Зарегистрируйтесь или войдите
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
var $window = $(window),
onScroll = function(e) {
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom)) {
StackExchange.using('gps', function() { StackExchange.gps.track('embedded_signup_form.view', { location: 'question_page' }); });
$window.unbind('scroll', onScroll);
}
};
$window.on('scroll', onScroll);
});
Регистрация через Google
Регистрация через Facebook
Регистрация через почту
Отправить без регистрации
Необходима, но никому не показывается
Зарегистрируйтесь или войдите
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
var $window = $(window),
onScroll = function(e) {
var $elem = $('.new-login-left'),
docViewTop = $window.scrollTop(),
docViewBottom = docViewTop + $window.height(),
elemTop = $elem.offset().top,
elemBottom = elemTop + $elem.height();
if ((docViewTop elemBottom)) {
StackExchange.using('gps', function() { StackExchange.gps.track('embedded_signup_form.view', { location: 'question_page' }); });
$window.unbind('scroll', onScroll);
}
};
$window.on('scroll', onScroll);
});
Регистрация через Google
Регистрация через Facebook
Регистрация через почту
Регистрация через Google
Регистрация через Facebook
Регистрация через почту
Отправить без регистрации
Необходима, но никому не показывается
Необходима, но никому не показывается
Необходима, но никому не показывается
Необходима, но никому не показывается
Необходима, но никому не показывается
Необходима, но никому не показывается
Необходима, но никому не показывается
Необходима, но никому не показывается
Необходима, но никому не показывается
1
Стек намного меньше кучи.
– Кирилл Малышев
5 часов назад
сделайте так, чтобы один объект съедал 100мб
– Stranger in the Q
5 часов назад
1
Вот, например OutOfMemoryError ideone.com/XjmuMf
– Кирилл Малышев
5 часов назад
@Кирилл а чем я в моем случае так переполняет стек?
– CapitaNemo
5 часов назад
рекурсия порождает на стеке адреса возврата
– Stranger in the Q
4 часа назад