При реализации поиска Дейкстры на графике я вызываю отдельный метод для выполнения поиска, передавая ему указатель на мои узлы и прямые значения для начальной/конечной точки и размера массива. Примечательно, что этот метод ничего не меняет в массиве узлов, он только считывает значения.
Когда я пытаюсь освободить массив узлов после этого, это вызывает SIGSEGV
int djkstra(int start, int goal, node* v, int n){
//Algorithm logic
return result;
}
int main(){ [...]
node* v = (node*)malloc(sizeof(node)*(n+1));
djkstra(start, goal, v, n);
free(v); //This throws a SIGSEGV
return 0;}
Я не могу найти в Интернете информацию о том, почему это может привести к поломке. Я также попытался добавить отдельный массив, объявленный в main (который изменяется в методе), который я также не смог освободить после этого.
Это какое-то непонятное правило C++? Я не смог найти ничего об этом в Интернете, и этот метод должен быть давно разрешен, когда я вызываю free(v).
Я приведу здесь рабочий пример для пояснения, хотя обратите внимание, что в djkstra есть еще один странный сегфолт free(), о котором мне, вероятно, придется задать еще один вопрос позже.
#include
#include
class node{
public: int edges;
public: int* pre;
public: int* cost;
public: void addpre(int i, int c){/*Insertion logic*/}
public: void destroy(){/*Frees the arrays*/}
};
int djkstra(int start, int goal, node* v, int n){
bool* visited =(bool*)malloc(sizeof(bool)*n+1);
int* costss = (int*)malloc(sizeof(int)*n+1);
for(int i=0; i
Подробнее здесь: https://stackoverflow.com/questions/798 ... -reference
Сигнал SIGSEGV после вызова метода. Как работают указатели после передачи по ссылке? ⇐ C++
Программы на C++. Форум разработчиков
1762480592
Anonymous
При реализации поиска Дейкстры на графике я вызываю отдельный метод для выполнения поиска, передавая ему указатель на мои узлы и прямые значения для начальной/конечной точки и размера массива. Примечательно, что этот метод ничего не меняет в массиве узлов, он только считывает значения.
Когда я пытаюсь освободить массив узлов после этого, это вызывает SIGSEGV
int djkstra(int start, int goal, node* v, int n){
//Algorithm logic
return result;
}
int main(){ [...]
node* v = (node*)malloc(sizeof(node)*(n+1));
djkstra(start, goal, v, n);
free(v); //This throws a SIGSEGV
return 0;}
Я не могу найти в Интернете информацию о том, почему это может привести к поломке. Я также попытался добавить отдельный массив, объявленный в main (который изменяется в методе), который я также не смог освободить после этого.
Это какое-то непонятное правило C++? Я не смог найти ничего об этом в Интернете, и этот метод должен быть давно разрешен, когда я вызываю free(v).
Я приведу здесь рабочий пример для пояснения, хотя обратите внимание, что в djkstra есть еще один странный сегфолт free(), о котором мне, вероятно, придется задать еще один вопрос позже.
#include
#include
class node{
public: int edges;
public: int* pre;
public: int* cost;
public: void addpre(int i, int c){/*Insertion logic*/}
public: void destroy(){/*Frees the arrays*/}
};
int djkstra(int start, int goal, node* v, int n){
bool* visited =(bool*)malloc(sizeof(bool)*n+1);
int* costss = (int*)malloc(sizeof(int)*n+1);
for(int i=0; i
Подробнее здесь: [url]https://stackoverflow.com/questions/79811909/sigsev-signal-after-method-call-how-do-pointers-work-after-pass-by-reference[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия