Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
0 / 0 / 0
Регистрация: 05.11.2012
Сообщений: 16

Ошибка чтения динамического массива

18.07.2016, 16:36. Показов 744. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый всем день. Есть динамический массив, в который считывается файл. После закрытия доступа к файлу для чтения и повторного обращения к динамическому массиву, появляется ошибка: Access violation at address 00403E47 in module 'Project1.exe'. read of address 00000000.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
unsigned char packet[1500] = {0xff,0xff,0xff,0xff,0xff,0xff,0x40,0x16,0x7e,0x72,0xfa,0x8e,0x23,0x21};
unsigned char *buf; //Буфер для считывания из файла
...
//---------------------------------------------------------------------------
// чтение файла
//---------------------------------------------------------------------------
unsigned char* ReadFile()
{
    AnsiString OutPacket, OutPacketS;
    Form1->OpenDialog1 -> Execute();
    AnsiString n = Form1->OpenDialog1->FileName;
    FILE *stream = fopen(n.c_str(), "rb");
    if (stream==NULL)
        ShowMessage("Ошибка открытия файла");
    else {
        int FileSize = filelength(fileno(stream));
        unsigned char *buf = new unsigned char[FileSize];
        Form1->Memo1->Lines->Add("Файл успешно открыт!");
        Form1->Memo2->Lines->Add("Размер открытого файла: " + AnsiString(FileSize) + " байт");
 
        fread(buf, 1, FileSize, stream);
 
        Form1->Memo2->Lines->Add(CounterSentPacket);
        Form1->Memo2->Lines->Add(OstatokSentPacket);
        Form1->Memo2->Lines->Add("Первые 16 байт открытого файла:\n");
        for(int i = 0; i < 16; i++) {
            OutPacket += OutPacketS.sprintf("%.2x  ",(unsigned char)buf[i]);
        }
        Form1->Memo2->Lines->Add(OutPacket);
        OutPacket = OutPacketS = "";
        Form1->Memo2->Lines->Add("Последние 16 байт открытого файла:\n");
        for(int i = 16; i > 0; i--) {
            OutPacket += OutPacketS.sprintf("%.2x  ",(unsigned char)buf[FileSize-i]);
        }
        Form1->Memo2->Lines->Add(OutPacket);
        OutPacket = OutPacketS = "";
    }
    fclose(stream);
 
    for (int i = 0, n = 14; i < 1500; i++, n++){
        packet[n]=(unsigned char)buf[i];
    }
}
//---------------------------------------------------------------------------
В чем может быть проблема?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
18.07.2016, 16:36
Ответы с готовыми решениями:

Ошибка чтения динамического массива
#pragma once #include &lt;iostream&gt; using namespace std; class Matrix { public: int size = 0; int** matrix; Matrix(int s) :...

Функция чтения из файла двумерного динамического массива
Добрый день! Необходимо написать функция чтения двумерного массива из файла. Компилятор выдает ошибку: &quot;переопределение...

Ошибка delete [] динамического массива
Здравствуйте! Задача - считать числа из файла, не зная их количества. Для этого я создал динамический массив и заполнил его следующим...

2
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33195 / 21491 / 8233
Регистрация: 22.10.2011
Сообщений: 36,878
Записей в блоге: 12
18.07.2016, 17:00
Ничего, что buf, который во второй строке, и buf, который заполняется в 17/21-ой - это разные буферы? После выхода переменной, описанной в 17-ой строке из области видимости происходит попытка прочесть данные из неинициализированной переменной, описанной во второй строке. Ожидаемый AV получен.

Чтобы решить проблему, достаточно просто убрать несколько символов:
C++
17
        buf = new unsigned char[FileSize];
И да, все-таки нужно проверять, есть ли в buf столько символов, сколько из него пытаются читать, а то при попытке прочесть после ошибки открытия файла будет та же самая ошибка в рантайме.

Кстати, в 40-ой/41-ой строке есть цикл. Подумай, чему будет равно n, когда i == 1499. А потом посмотри, какой размер у массива packet.
1
0 / 0 / 0
Регистрация: 05.11.2012
Сообщений: 16
19.07.2016, 08:24  [ТС]
Спасибо большое. Я и не обратил внимания, что буферы разные... Теперь все хорошо. Насчет массива packet, я не так копирнул, его размер 1514.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
19.07.2016, 08:24
Помогаю со студенческими работами здесь

Ошибка в обработке динамического массива
Здравствуйте всем. Переделывал этот код для динамических массивов: procedure Gauss(n:integer;a:mas;var x:mass); var l:array of...

Ошибка заполнения динамического массива
Я создал массив, потом заполнил, а когда вывел мне показало &quot;dddd&quot;, а дальше абракадабра. почему так и как это исправить? int len =...

Ошибка создания динамического массива
Задача создать динамический массив размерность и элементы вводятся с клавиатуры, программа выдает ошибку.Подскажите в чем проблема? Вот...

Ошибка чтения данных массива из файла
Доброго времени суток, первый раз работаю с записью-чтением данных в файл, нужно сделать запись бинарной. За основу брал примеры с...

Ошибка чтения или обнуление массива объектов
Суть, есть абстрактный класс А от него наследие идет к классу B extends A, B еще и implements Serializable. (public class B extends A...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение/ Перевод https:/ / **********/ gallery/ thinkpad-x220-tablet-porn-gzoEAjs . . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru