Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.86/29: Рейтинг темы: голосов - 29, средняя оценка - 4.86
0 / 0 / 0
Регистрация: 15.10.2014
Сообщений: 30

Чтение файла с данными типа real. Тип real в билдере или как его "обойти"?

26.10.2015, 09:28. Показов 6353. Ответов 41
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Читаю файл в структуру,

C++
1
2
3
4
5
6
7
8
9
double Fdat;
 
struct STR
       {
        ...
 
       } rec
 
read( Fdat,(char *)&rec,sizeof(rec));
но данные на выходе получаются, вежливо говоря, не совсем те, которые должны. Описание струкруты самого файла у меня есть. Подозреваю, что проблема в том, что в структуре читаемого файла присутствует тип Real, 6 байт, а в билдере, как я понял, нет этого типа, есть float или double по 4 и 8 байт соответственно. Помимо этого, ещё в файле есть IUNT и UDINT, я их объявляю как unsigned int и unsigned long int, и это верно, если не ошибаюсь.
Читаю другие файлы другой структуры, где нет вещественного типа (и Fdat как int идёт), и всё как надо читается.
Верно ли я понял причину (real) и что можно сделать, какой тип объявить вместо real? Если все же double, то как читать 6 байт? Пробовал сделать так

C++
1
read( Fdat,(char *)&rec,sizeof(rec)-(sizeof(float))/2); // типа отнимаем 2 лишних байта
, но результата положительного это не дало. Помогите, пожалуйста. Спасибо.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
26.10.2015, 09:28
Ответы с готовыми решениями:

Нельзя преобразовать тип function(dlina: real): real к real
program Kolco; function dlina(a1,b1,a2,b2:real):real; begin dlina:=sqrt(sqr(a1-b1)+sqr(a2-b2)); end; function...

Ошибка: Нельзя преобразовать тип function x real real к real
Здравствуйте, не могу понять как исправить ошибку (строка 32) var a,b,e,h,xi,fi,ln1,ln2:real; s:longint; n,i:integer; ...

Нельзя преобразовать тип function(x real) real к real
program Simpson; var x,a,b,h,s:real; n:integer; function Y(t:real):real; begin Y:=(exp(x*ln(exp)))/(x+5); end;

41
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
26.10.2015, 09:47
Real - это вещественный тип из древнего Паскаля. Где ты взял такие файлы?
В C++ такого нет. Нужно делать преобразование в double. Вот с этим ознакомься: http://www.shikadi.net/modding... ascal_Real
Там пример для C# - переделай для C++.
0
0 / 0 / 0
Регистрация: 15.10.2014
Сообщений: 30
26.10.2015, 10:36  [ТС]
Цитата Сообщение от nmcf Посмотреть сообщение
Real - это вещественный тип из древнего Паскаля. Где ты взял такие файлы?
В C++ такого нет. Нужно делать преобразование в double. Вот с этим ознакомься: http://www.shikadi.net/modding... ascal_Real
Там пример для C# - переделай для C++.
Да вроде бы не древние файлы. Есть программа, которая генерирует эти файлы, написана точно в какой-то объектно-ориентированной среде. Наверное, Delphi, в нем же тоже есть Real?
Мне показали структуру генерируемых файлов, там именно что Real, UINT, UDINT, Bool.

Я так понимаю, приведенный вами код в ссылке надо в какую-нибудь функцию переписать и потом как-то использовать... Как-то... Господи, ну за что мне это)
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
26.10.2015, 10:54
Ну оформи как функцию. Только придётся 2 варианта структуры иметь - одну для считывания, а вторую с double для дальнейшей обработки.
0
0 / 0 / 0
Регистрация: 15.10.2014
Сообщений: 30
26.10.2015, 11:08  [ТС]
Цитата Сообщение от nmcf Посмотреть сообщение
Ну оформи как функцию. Только придётся 2 варианта структуры иметь - одну для считывания, а вторую с double для дальнейшей обработки.
А та, которая для считывания, как будет выглядеть? Вместо Double что будет? И в каком месте использовать функцию, и какие параметры в нее передавать?
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
26.10.2015, 11:57
C++
1
char real48[6];
C++
1
double convert_real_to_double(char real48[]);
0
 Аватар для Fulcrum_013
2083 / 1574 / 169
Регистрация: 14.12.2014
Сообщений: 13,614
26.10.2015, 12:12
Цитата Сообщение от nmcf Посмотреть сообщение
это вещественный тип из древнего Паскаля. Где ты взял такие файлы?
Он 6 байтный. Обходится финтом с ушами с конверсией путем вырезания бит, сдвигания частей и последующего склеивания в double или float(если потеря точности несущественна).

Добавлено через 5 минут
Цитата Сообщение от Jaydens_Blues Посмотреть сообщение
Наверное, Delphi, в нем же тоже есть Real?
В Delphi есть
Delphi
1
type Real = Double;
А для совместимости существует встроенный тип
Real48 т.е на дельфе можно сделать конвертор файлов без всяких финтов ушами.
0
0 / 0 / 0
Регистрация: 15.10.2014
Сообщений: 30
26.10.2015, 12:52  [ТС]
Цитата Сообщение от Fulcrum_013 Посмотреть сообщение
А для совместимости существует встроенный тип
Real48 т.е на дельфе можно сделать конвертор файлов без всяких финтов ушами.
Да просто программа, генерирующая файлы, сторонняя, нет возможности в ней что-то исправить. Можно подробнее про финт ушами?
PS. То есть, если писалось не на паскале, то real=double= 8 байт? Но почему тогда не прокатывает...
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
26.10.2015, 13:00
Jaydens_Blues, с момента как я тебе ссылку дал прошло много времени, можно было уже давно всё сделать. Никакого автоматического чудо-преобразования нет - функцию делай.
0
 Аватар для Fulcrum_013
2083 / 1574 / 169
Регистрация: 14.12.2014
Сообщений: 13,614
26.10.2015, 13:04
Цитата Сообщение от Jaydens_Blues Посмотреть сообщение
То есть, если писалось не на паскале
А точно не на паскале? Она вообще под винды? До Delphi кстати еще был фрэймверк OWL тоже под винды.
Цитата Сообщение от Jaydens_Blues Посмотреть сообщение
нет возможности в ней что-то исправить
А в ней и не надо. Можно сделать дельфовский модулек для подгрузки и даже выгрузки в ее формат вообще без финтов ушами.

Добавлено через 2 минуты
Цитата Сообщение от nmcf Посмотреть сообщение
Никакого автоматического чудо-преобразования нет - функцию делай.
В дельфе есть, смысл примерно такой:
Delphi
1
2
3
4
5
6
7
var
    a:double;
    b:real48;
begin
    read(File,b);
    a:=b;
end;
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
26.10.2015, 13:04
Fulcrum_013, не склоняй человека к использованию всякой древней хрени. Пусть C++ пользуется.
0
 Аватар для Fulcrum_013
2083 / 1574 / 169
Регистрация: 14.12.2014
Сообщений: 13,614
26.10.2015, 13:12
Цитата Сообщение от nmcf Посмотреть сообщение
Пусть C++ пользуется.
А я ему что говорю? Пишет дельфовский модулек где делает преобразование штатными средствами, прикрепляет в проект и все прекрасно компилится. Он то С++ Builder пользует.
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
26.10.2015, 13:12
Вот функция. Пользуйся.
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
#include <cmath>
 
double convert_real_to_double(char real48[])
{
    double exponentbase = 129;
    double exponent = real48[0] - exponentbase; // The exponent is offset so deduct the base.
     
    // Now Calculate the mantissa
    double mantissa = 0.0;
    double value = 1.0;
    // For Each Byte.
    for (int i = 5; i >= 1; i--)
    {
        int startbit = 7;
        if (i == 5)
        { startbit = 6; } //skip the sign bit.
     
        //For Each Bit
        for (int j = startbit; j >= 0; j--)
        {
            value = value / 2;// Each bit is worth half the next bit but we're going backwards.
            if (((real48[i] >> j) & 1) == 1) //if this bit is set.
            {
                mantissa += value; // add the value.
            }
     
        }
    }
     
    if (mantissa == 1.0 && real48[0] == 0) // Test for null value
        return 0.0;
     
    if ((real48[5] & 0x80) == 1) // Sign bit check
        mantissa = -mantissa;
     
    return (1 + mantissa) * pow(2.0, exponent);
}
0
 Аватар для Fulcrum_013
2083 / 1574 / 169
Регистрация: 14.12.2014
Сообщений: 13,614
26.10.2015, 13:14
Цитата Сообщение от nmcf Посмотреть сообщение
е склоняй человека к использованию всякой древней хрени
Вот лет 20 назад такими сдвигами и масками и конвертил когда штатных средств не было, а компилятор C++ не умел компилировать паскаль.
0
0 / 0 / 0
Регистрация: 15.10.2014
Сообщений: 30
26.10.2015, 13:16  [ТС]
Цитата Сообщение от Fulcrum_013 Посмотреть сообщение
А точно не на паскале? Она вообще под винды? До Delphi кстати еще был фрэймверк OWL тоже под винды
Из-под винды, я её вижу каждый день практически, а вот её авторы не хотят общаться по её поводу, максимум дадут структуру выходных файлов глянуть)) Вариаций этой программы много, поэтому какие-то файлы легко читаются, а какие-то вот так... Вообще, цель написать одну универсальную программу, читать ею файлы хоть и с заранее известными структурами, но довольно разными
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
26.10.2015, 13:18
Цитата Сообщение от Fulcrum_013 Посмотреть сообщение
Вот лет 20 назад такими сдвигами и масками и конвертил
Ты разве не студент?
0
0 / 0 / 0
Регистрация: 15.10.2014
Сообщений: 30
26.10.2015, 13:27  [ТС]
Цитата Сообщение от nmcf Посмотреть сообщение
Вот функция. Пользуйся
Спасибо большое, буду пробовать. А если в структуре у меня массив real (будущий double), это же не принципиально?

Должно быть что-то вроде этого?
C++
1
2
read( Fdat,(char *)&rec,sizeof(rec));
data.PutElement(convert_real_to_double(rec.Progr[i]), i, j);
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
26.10.2015, 13:48
В структуре у тебя должен быть массив из 6 char в том месте, где real. А после считывания преобразуешь.
Твой пример не понял. Если в rec поле:
C++
1
char real48[6];
то функцию вызывать:
C++
1
convert_real_to_double(rec.real48)
0
0 / 0 / 0
Регистрация: 15.10.2014
Сообщений: 30
26.10.2015, 13:48  [ТС]
Ошибку incompatible types выдает, когда делаю так, как выше из своего примера.

rec.Progr[i] объявляю тоже как char в структуре, тогда выдает cannot convert int to char*.

Цитата Сообщение от nmcf Посмотреть сообщение
В структуре у тебя должен быть массив из 6 char в том месте, где real. А после считывания преобразуешь.
Твой пример не понял. Если в rec поле:
Спасибо, буду пробовать. В моем примере я просто считываемое значение вставляю в вариантный массив через PutElement.
0
 Аватар для Fulcrum_013
2083 / 1574 / 169
Регистрация: 14.12.2014
Сообщений: 13,614
26.10.2015, 13:52
Цитата Сообщение от nmcf Посмотреть сообщение
Ты разве не студент?
Да уже 15 лет как диплом получил.

Цитата Сообщение от Jaydens_Blues Посмотреть сообщение
Вообще, цель написать одну универсальную программу
В этой универсальной программе придется делать отдельную функцию для чтения каждого из видов форматов. т.к. Real них в разныъ местах как понимаю, и применять функцию конвертирования в Double к каждому полю real.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
26.10.2015, 13:52
Помогаю со студенческими работами здесь

Нельзя преобразовать тип function(x: real): real к real
Ничего не понимаю, почему нельзя? Помогите пожалуйста найти ошибку в коде. uses CRT; type function1=function(x: real): real; ...

Нельзя преобразовать тип function(x: real): real к real
Здравствуйте! Не могу написать формулу. Ошибка:Нельзя преобразовать тип function(x: real): real к real program zadacha; var...

Нельзя преобразовать тип function(x: real): real к real
var g,s,s1,s2,fi,h:real; label k; begin write('Vvedite visotu'); readln(h);k: write('Vvedite gradusi'); readln(s); ...

Заполнить одномерный массив данными типа real из текстового файла
Здравствуйте, помогите мне решить задание! Замена элементов файла. В текстовом файле, содержащем данные типа real, заменить максимальный...

Program1.pas(7) : Нельзя преобразовать тип KeyValuePair<real,integer> к real
program pomogite; var x, y: real; begin readln(x); if x=&gt;-2 and 3&gt;=x then y:=sqrt(x*x+4) else if x&gt;3 then y:=6*x+8...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru