170 похожих чатов

Добрый день! Может кто-то помочь расшифровать вывод от GC, получившийся

в результате падения? Программа паникует со словами fatal error: found pointer to free object. Я так понимаю, это значит, что я куда-то спрятал указатель на объект, который GC подобрал, хотя у меня в коде этот указатель ещё будет использоваться (первый вопрос: правильно ли я понял суть ошибки?).
Вместе с паникой мне выводится большая таблица с, насколько я понял, памятью, которой пользовалась моя программа, и её статусом (в контексте GC). Таблица имеет следующий вид
0x... alloc marked
0x... free unmarked
И т.п. Проблемный указатель в ней записан так:
0xFOO free marked zombie
FOO: BAR <my/project/package.SomeFunction.func1+0> BAZ
Здесь FOO, BAR и BAZ - какие-то шестнадцатеричные числа. FOO - это, насколько я понимаю, как раз таки указатель, который был подобран GC. Знает ли кто-то,
1) что значат числа BAR и BAZ (BAZ похоже тоже на адрес указателя, но на пару десятков килобайт дальше FOO, а BAR значительно меньше и поэтому не похоже на адрес);
2) что значит запись в <>? Это указание на место, в котором обнаружен указатель на освобождённую память? Что в таком случае значит func1+0 (func1 - это вроде бы первая анонимная функция в скоупе SomeFunction, а что такое +0)?

4 ответов

6 просмотров

Как спрятали?

Arseny-Khoroshilov Автор вопроса
Zver
Как спрятали?

Долго объяснять, специфика задачи заставляет обмазываться кучей небезопасных практик. Но до недавнего времени всё работало довольно стабильно. Если вкратце, из C приходит память на структуру, в которую кладётся указатель на гошный объект (я знаю, что cgo сильно против таких махинаций, но...). Варианта "переделать архитектуру чтобы не заниматься такой ересью" к сожалению в данный момент нет. Для начала хочется понять всю информацию, которая содержится в crash report, а потом думать, как грамотнее это пофиксить.

Arseny-Khoroshilov Автор вопроса
Arseny Khoroshilov
Долго объяснять, специфика задачи заставляет обмаз...

Интересно, что указатель, отмеченный как zombie в репорте - это не указатель на объект, который мы отправляем в C, а указатель на 80 байт дальше (размер отправляемого объекта - 16 байт).

Arseny-Khoroshilov Автор вопроса

Отбой, мне кажется, я разобрался. Запись в <> - это не указание на функцию, где мы находим проблемный объект, а указание на сам проблемный объект. Т.е. GC потёр анонимную функцию, которая на самом деле тоже лежит в сишной памяти. Накинул на неё runtime.KeepAlive, вроде бы работает стабильно.

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

Обсуждают сегодня

Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
32
Хотел бы спросить у знающих, правильную ли я выбрал книгу для начала изучения ассемблера Юрова В.И ? Или есть более лучшие книги для начала обучения?
Botsman
25
Книга Юрова В.И пойдёт для обучения?
Botsman
24
$params = [ 'formid' => 'feedbackForm', 'formTpl' => '@CODE: <form class="form-validate" data-id="ajax_form"> <fieldset class="margin-bottom-md"> ...
Pathologic
1
Подскажите пожалуйста, а я могу вот такую штуку использовать? rpc, только реализованное в реббите https://www.rabbitmq.com/tutorials/tutorial-six-php ( или https://habr.com/ru...
Artyom
11
а мы ещё не созрели до того, чтобы создать отдельный чатик про настройку редакторов?
Cheese Syrowiecki
16
И ещё вопрос: можно ли типа как на дос как-то запариться и с помощью прерываний выводить текст, вместо функции printf ?
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
34
Всем привет! У меня почему-то по-разному отображается TListView в Debug и Release режимах (FireMonkey)! При запуске под Win приложения TListView заливается программо. в Debug ...
Александр COM
8
Ладно, ещё тупого спрошу. Код должен банально вывести значение регистра на консоль, на деле же не выводя ничего, просто оставляя нерабочую консоль (открыта, ничего не написан...
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
25
Парни, спасайте. RAD Studio 12 творит какую-то дичь. У меня есть метод (event), который вызывает другой метод, т.е. он состоит из 1-й строки вызова. Ставлю бряк на event, запу...
Eugene Krasnikov (ᴊɪɴ x)
3
Карта сайта