|
Программист
|
||||||
Ошибка при работе с динамической памятью - 'Invalid pointer operatoion'08.07.2011, 23:36. Показов 2085. Ответов 18
Метки нет (Все метки)
Столкнулся с такой проблемой - код исполняется правильно, но при закрытие программы вываливается ошибка(скрин прилогается). Я нашёл строку(67) на которую он ругается, но с первого взгляда там всё чисто и проблемы я не вижу. Буду признателен за совет, тк уже долго мучаюсь(...
Сразу прошу прощения за дилетантское оформление, только учусь.
0
|
||||||
| 08.07.2011, 23:36 | |
|
Ответы с готовыми решениями:
18
Ошибка invalid pointer Компонент Label - ошибка Invalid pointer operation |
|
594 / 532 / 76
Регистрация: 22.03.2011
Сообщений: 1,585
|
|||
| 08.07.2011, 23:50 | |||
|
ну вероятно на выход за границы массива ругается есть fgets(); http://www.cplusplus.com/refer... dio/fgets/
0
|
|||
|
Программист
|
|
| 09.07.2011, 00:10 [ТС] | |
|
Спасибо за ответ, да с fgets() вы абсолютно правы, ещё есть fscanf(), но топорная реализация не должна влиять на эту ошибку...
Не могли бы указать номер строки которая вас не устроила, и написать какое значение даёт выход за пределы массива?
0
|
|
|
251 / 145 / 21
Регистрация: 14.06.2010
Сообщений: 340
|
|
| 09.07.2011, 00:24 | |
|
Во всех случаях не <=, а <
Последний элемент в цикле - и есть выход за границы
0
|
|
|
Программист
|
||
| 09.07.2011, 00:42 [ТС] | ||
|
Питекантроп, во всех случаях? До последнего цикла всё отлажено, там проблем с памятью быть не должно. Если сделать везде неравенство строгими, то будет нарушена логика и работать ничего правильно не будет.
Если вы имели ввиду последний цикл, то при заме неравенств
0
|
||
|
251 / 145 / 21
Регистрация: 14.06.2010
Сообщений: 340
|
|
| 09.07.2011, 00:47 | |
|
0
|
|
|
Программист
|
|
| 09.07.2011, 01:02 [ТС] | |
|
Прошу простить мне мою глупость, но что-то я вас не очень понимаю(
Вы имеете ввиду индекс последнего инициализированного значения? почему это он count-1? и как это может влиять?(хотя там такого быть не должно) Укажите пожалуйста номера строк которые нужно править и как. В чём ошибка?( Вероятно я что-то не так понимаю, напишите пожалуйста поподробнее, не хочется повторять эту ошибку в дальнейшем...
0
|
|
|
251 / 145 / 21
Регистрация: 14.06.2010
Сообщений: 340
|
||
| 09.07.2011, 01:13 | ||
|
res[count] уже за границами! А вы во всех циклах к нему обращаетесь. Поэтому нужно или сделать во ВСЕХ циклах строгое неравенство, чтоб не было ошибки, либо создавать массивы на один элемент больше char *res = new char [count+1];
0
|
||
|
Программист
|
|
| 09.07.2011, 01:20 [ТС] | |
|
Питекантроп, не помогло, видимо ошибка не в этом...
На всякий случай поясню свои действия. Я посчитал количество символов в файле, но счёт шёл с единицы, то есть получившийся count был на единицу больше чем нужно для задания массива под хранение всего файла. Поэтому я понижаю его count--; и теперь массив выделяется ровно под размер файла( включая '\0').
0
|
|
|
251 / 145 / 21
Регистрация: 14.06.2010
Сообщений: 340
|
|
| 09.07.2011, 01:29 | |
|
0
|
|
|
Программист
|
||||||||||||||||
| 09.07.2011, 01:40 [ТС] | ||||||||||||||||
0
|
||||||||||||||||
|
251 / 145 / 21
Регистрация: 14.06.2010
Сообщений: 340
|
|||
| 09.07.2011, 01:48 | |||
|
0
|
|||
|
Программист
|
|||
| 09.07.2011, 01:54 [ТС] | |||
|
Ну у меня же значение count2 уменьшается сразу после получения и на всём оставшемся участке программы не изменяется, так что
0
|
|||
|
|
|
| 09.07.2011, 02:45 | |
|
i <= count2-1;
0
|
|
|
251 / 145 / 21
Регистрация: 14.06.2010
Сообщений: 340
|
|||||||||||
| 09.07.2011, 03:38 | |||||||||||
|
Whiteha,
загрузку из файла в мемо в билдере можно так
![]() Если хотите самостоятельно разбить по строкам, то во вам такой код
1
|
|||||||||||
|
Программист
|
|
| 09.07.2011, 11:58 [ТС] | |
|
Хоть я так и не понял где у меня там шёл выход, но спасибо за науку
![]() Всё действительно можно расписать гораздо проще чем я расписал, LoadFromFile() я не пользовался, ибо хотел лишний раз поработать с массивами и перестать наконец выходить за их пределы(задача носит учебный характер). Ну а ваш код в 21 строку, работает, но выводит пару мусорных строк. P.S. Не теряю надежды, что меня ткнут носом в моём коде на ошибку и покажут исправление...
0
|
|
|
251 / 145 / 21
Регистрация: 14.06.2010
Сообщений: 340
|
||||||||
| 09.07.2011, 16:59 | ||||||||
Или можете просто расставлять мессаджбоксы в разных местах кода, чтоб узнать до куда доходит код. Application->MessageBoxA("блаблабла","",0);
1
|
||||||||
|
Программист
|
|
| 10.07.2011, 22:00 [ТС] | |
|
Питекантроп, эта версия полностью рабочая, спасибо=)
А со своим кодом - у меня весь код проходит и всё выполняется без ошибок, ошибка возникает лишь при завершении программы, закрытие формы. От ошибки избавляет лишь "закоменчивание" 67 строки, но почему это так мне выяснить не удалось. Добавлено через 23 часа 27 минут Ещё актуально(напомню, мучаюсь в учебных целях, альтернативные варианты - хорошо, но я очень хочу понять в чём просчёт и как его устранить).
0
|
|
| 10.07.2011, 22:00 | |
|
Помогаю со студенческими работами здесь
19
Что за ошибка "invalid pointer addition" Что за ошибка "invalid pointer addition" Ошибка "invalid pointer addition" Ошибка "Invalid pointer addition" Ошибка в коде при работе с динамической памятью Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица.
Задача: зафиксировать три левых колонки в отчете.
Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка)
/ / . . .
|
Настройки VS Code
Loafer 13.04.2026
{
"cmake. configureOnOpen": false,
"diffEditor. ignoreTrimWhitespace": true,
"editor. guides. bracketPairs": "active",
"extensions. ignoreRecommendations": true,
. . .
|
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2.
Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива.
Было так:. . .
|
|
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: реализовать контроль корректности заполнения дат назначения. . .
|
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html
Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
|
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
|
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях.
Задача: при копировании документа очищать определенные реквизиты и табличную. . .
|