реклама на сайте
подробности

 
 
> Вопрос скорее по Си
_Артём_
сообщение Jun 1 2007, 15:17
Сообщение #1


Гуру
******

Группа: Свой
Сообщений: 2 128
Регистрация: 21-05-06
Пользователь №: 17 322



В программе объявлен такой тип данных
Код
#define MAX_DATA_SIZE 128
struct TStructure {
    unsigned char DataSize;// размер данных
    unsigned char Data[MAX_DATA_SIZE];
};


Соответственно есть переменные такого типа:
Код
struct TStructure st1={
    3,
    {1,2,3}
};
struct TStructure st1={
    1,
    {1}
};


Структуры должны хранится в программной памяти и загружаться в ОЗУ соответственно ситуации.
Проблема в том, что Data может быть разной длины (от 1 до 128), то есть программная память зря расходуется.
Как определить структуру, чтобы поле Data имела размер не больше чем требуется?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
singlskv
сообщение Jun 1 2007, 22:15
Сообщение #2


дятел
*****

Группа: Свой
Сообщений: 1 681
Регистрация: 13-05-06
Из: Питер
Пользователь №: 17 065



Цитата(_Артём_ @ Jun 1 2007, 19:17) *
Структуры должны хранится в программной памяти и загружаться в ОЗУ соответственно ситуации.
Проблема в том, что Data может быть разной длины (от 1 до 128), то есть программная память зря расходуется.

Может быть я конечно не все понял, но в чем вобще проблема ?
Копирование из флеш в рам в вашей ситуации все равно придется делать "ручками"
Ну дык и кто мешает просто забить в памяти кусок максимального объема типа
Код
#define MAX_DATA_SIZE 128
struct {
    unsigned char DataSize;// размер данных
    unsigned char Data[MAX_DATA_SIZE];
} currStruct;

и по необходимости переносить в нее из флеш.
Ну или просто, если уж у Вас структуры хранятся в флеш то это наверное константы ?
тогда просто организуйте доступ к ним без копирования в память
Go to the top of the page
 
+Quote Post
_Артём_
сообщение Jun 1 2007, 22:33
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 2 128
Регистрация: 21-05-06
Пользователь №: 17 322



Цитата(singlskv @ Jun 2 2007, 01:15) *
Может быть я конечно не все понял, но в чем вобще проблема ?
Копирование из флеш в рам в вашей ситуации все равно придется делать "ручками"
Ну дык и кто мешает просто забить в памяти кусок максимального объема типа
Код
#define MAX_DATA_SIZE 128
struct {
    unsigned char DataSize;// размер данных
    unsigned char Data[MAX_DATA_SIZE];
} currStruct;

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


Проблема в том, что программной памяти жалко (и так не хватает), это обстоятельство и не позволяет "просто забить в памяти кусок максимального объема типа".
Go to the top of the page
 
+Quote Post
tag
сообщение Jun 4 2007, 08:03
Сообщение #4


Частый гость
**

Группа: Свой
Сообщений: 151
Регистрация: 21-02-06
Пользователь №: 14 561



Цитата(_Артём_ @ Jun 2 2007, 01:33) *
Проблема в том, что программной памяти жалко (и так не хватает), это обстоятельство и не позволяет "просто забить в памяти кусок максимального объема типа".

...непонятно, предполагается что структура размещается в ОЗУ, а не в программной памяти и данные в нее заносятся из flash... у вас нехватка какой памяти программ или ОЗУ данных?
Go to the top of the page
 
+Quote Post
_Артём_
сообщение Jun 4 2007, 21:14
Сообщение #5


Гуру
******

Группа: Свой
Сообщений: 2 128
Регистрация: 21-05-06
Пользователь №: 17 322



Цитата(tag @ Jun 4 2007, 11:03) *
...непонятно, предполагается что структура размещается в ОЗУ, а не в программной памяти и данные в нее заносятся из flash... у вас нехватка какой памяти программ или ОЗУ данных?


Нехватка у меня памяти программ(это к слову).
Вариант Сергея Борща почему-то в С++ глючит (то работает, то нет).
Наверное буду использовать другие варианты (скорее всего двоичный массив нужной длины).

Пожалуй, тему пора закрывать - сказано более, чем достаточно...
Всем спасибо.
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Jun 5 2007, 08:14
Сообщение #6


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



А про С++ в вопросе не было!
Цитата(_Артём_ @ Jun 5 2007, 00:14) *
Вариант Сергея Борща почему-то в С++ глючит (то работает, то нет).
Как заставить Американца прыгнуть с моста? Встретить его на мосту и убедить, что он разорен. Как заставить француза прыгнуть с моста? Встретить его на мосту и убедить, что жена ему изменяет. Как заставить русского прыгнуть с моста? Встретить его на мосту и сказать "А вы знаете, здесь прыгать с моста запрещено!"
Цитата(Сергей Борщ @ Jun 1 2007, 21:20) *
4) В С++ такое уже не прокатит.
В С++ такое не работает по простой причине: при наследовании данные производной структуры (которая в С++ есть частный случай класса) располагаются вслед за данными родителя. А если размер родителя неизвестен, компилятор не сможет иметь доступ к данным производного класса. А сказать "от этого класса наследников не будет никогда" возможности нет. Как сделать на С++ то, что вы хотите, да еще с инициализацией через {} - не знаю sad.gif Могу предложить два варианта - 1) массив структур сам по себе, структура из размера и указателя на массив. Да, лишний указатель, зато можно писать a = pArray[n].member; 2) не указывать размер, а в конце масива добавлять элемент с каким-либо признаком конца структуры (например если одно из полей - указатель, то он равен нулю.
Код
class terminal_t
{
public:
    terminal_t() {};
    static void process();
private:
    static bool read_input(char c);
public:

private:
    ................
    struct dictionary_t
    {
        char Name[10];
        void (*Action)(void);
        uint8_t StackRequired;
    } static const __flash Dictionary[];
} static Terminal;

#define    TERMINAL_DICTIONARY                      \
terminal_t::dictionary_t const __flash terminal_t::Dictionary[] =   \
{                                                                    \
    { "HEX",        ns_terminal::SetHex,     0},             \
    { "DECIMAL",    ns_terminal::DECIMAL,    0},             \
    { ".",          ns_terminal::UDOT,       1},             \
    { "@",          ns_terminal::Reference,  1},             \
    { "!",          ns_terminal::Dereference, 2},            \
    {"DUMP",        ns_terminal::DUMP,       2},             \

#define    TERMINAL_DICTIONARY_END                  \
    {0,        0 }                                    \
};


TERMINAL_DICTIONARY
    {"v",    readADC, 0},
    {"IDUMP",   RAM_DUMP, 2},
    {"RDUMP",   XROM_DUMP, 3},
    {"XDUMP",   XRAM_DUMP, 2},
    {"X!",      writeRAM, 2},
    {"X@",      readRAM, 1},
    {"RB!",     writeROM_byte, 3},
    {"R!",      writeROM, 3},
    {"R@",      readROM, 2},
    {"SN",      SN, 0},
TERMINAL_DICTIONARY_END
Да, на каждую структуру лишний элемент, но не нужно вручную перед компиляцией считать количество элементов, а значит и ошибиться невозможно. И те же самые Dictionary[n].Action();


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
ReAl
сообщение Jun 5 2007, 10:17
Сообщение #7


Нечётный пользователь.
******

Группа: Свой
Сообщений: 2 033
Регистрация: 26-05-05
Из: Бровари, Україна
Пользователь №: 5 417



Цитата(Сергей Борщ @ Jun 5 2007, 10:14) *
В С++ такое не работает по простой причине: при наследовании данные производной структуры (которая в С++ есть частный случай класса) располагаются вслед за данными родителя. А если размер родителя неизвестен, компилятор не сможет иметь доступ к данным производного класса.

Более того, даже без учёта incomplete array порядок размещения полей гарантируется только если у класса нет чередования модификаторов доступа (public/protected/private), нет виртуальных функций и базовых классов.

Т.е. тут порядок в памяти будет как написано
class foo {
int i;
int j;
int k;
};

а тут уже "не гарантируется", хотя и, вероятнее всего, будет всё нормально.
struct moo {
int i;
protected:
int j;
public:
int k;
};

gcc без ключа полного соответствия стандарту (--pedantic) пропускает incomplete arrays и вроде бы всё нормально компилирует... Но при этом не ругается даже если вывести потомка.

На мой взгляд, если уж припёрло, лучше бы такое выделить в отдельный чисто-С-шный модуль и обернуть в вызовы (чтобы сами структуры наружу даже не блестели). Или таки разориться на указатели в структурах а массивы держать отдельно.


--------------------
Ну, я пошёл… Если что – звоните…
Go to the top of the page
 
+Quote Post
Oldring
сообщение Jun 5 2007, 11:06
Сообщение #8


Гуру
******

Группа: Свой
Сообщений: 3 041
Регистрация: 10-01-05
Из: Москва
Пользователь №: 1 874



Цитата(ReAl @ Jun 5 2007, 14:17) *
На мой взгляд, если уж припёрло, лучше бы такое выделить в отдельный чисто-С-шный модуль и обернуть в вызовы (чтобы сами структуры наружу даже не блестели). Или таки разориться на указатели в структурах а массивы держать отдельно.


Если уж совершенно приперло с памятью - хранить все в одномерном байтовом массиве, и разориться на написание программы - упаковщика, порождающего сишный исходник с этим байтовым массивом. При наличии особого упорства и энтузиазма такой упаковщик можно породить даже на системе сишных макросов.


--------------------
Пишите в личку.
Go to the top of the page
 
+Quote Post
rezident
сообщение Jun 5 2007, 11:09
Сообщение #9


Гуру
******

Группа: Свой
Сообщений: 10 920
Регистрация: 5-04-05
Пользователь №: 3 882



Цитата(Oldring @ Jun 5 2007, 17:06) *
Если уж совершенно приперло с памятью - хранить все в одномерном байтовом массиве, и разориться на написание программы - упаковщика, порождающего сишный исходник с этим байтовым массивом.

Я это предлагал в самом начале, но меня обругали за такое предложение sad.gif
Go to the top of the page
 
+Quote Post
Oldring
сообщение Jun 5 2007, 11:44
Сообщение #10


Гуру
******

Группа: Свой
Сообщений: 3 041
Регистрация: 10-01-05
Из: Москва
Пользователь №: 1 874



Цитата(rezident @ Jun 5 2007, 15:09) *
Я это предлагал в самом начале, но меня обругали за такое предложение sad.gif


Не переживайте - собеседники просто знают толк в извращениях biggrin.gif


--------------------
Пишите в личку.
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- _Артём_   Вопрос скорее по Си   Jun 1 2007, 15:17
- - rezident   ИМХО, забейте на эту структуру! Объявите одно...   Jun 1 2007, 15:28
|- - _Артём_   Цитата(rezident @ Jun 1 2007, 18:28) P.S....   Jun 1 2007, 15:44
||- - rezident   Цитата(_Артём_ @ Jun 1 2007, 21:44) Данны...   Jun 1 2007, 16:30
||- - _Артём_   Цитата(rezident @ Jun 1 2007, 19:30) Вы с...   Jun 1 2007, 16:49
|- - zltigo   Цитата(rezident @ Jun 1 2007, 18:28) ИМХО...   Jun 1 2007, 17:17
|- - rezident   Цитата(zltigo @ Jun 1 2007, 23:17) Соверш...   Jun 1 2007, 18:43
|- - zltigo   Цитата(rezident @ Jun 1 2007, 21:43) Стру...   Jun 1 2007, 19:00
|- - defunct   Цитата(rezident @ Jun 1 2007, 21:43) Чита...   Jun 1 2007, 21:24
|- - Сергей Борщ   Цитата(defunct @ Jun 2 2007, 00:24) сравн...   Jun 2 2007, 08:43
|- - defunct   Цитата(Сергей Борщ @ Jun 2 2007, 11:43) С...   Jun 2 2007, 12:40
|- - ReAl   Цитата(defunct @ Jun 2 2007, 15:40) Под o...   Jun 2 2007, 13:52
|- - defunct   Цитата(ReAl @ Jun 2 2007, 16:52) Т.е. раз...   Jun 2 2007, 16:42
|- - defunct   Цитата(ReAl @ Jun 2 2007, 16:52) (кстати,...   Jun 2 2007, 18:53
- - _artem_   первый элемент структуры (для всех структур) можно...   Jun 1 2007, 15:44
- - defunct   Как вариант - использовать "open array" ...   Jun 1 2007, 15:48
|- - Сергей Борщ   Цитата(defunct @ Jun 1 2007, 18:48) Как в...   Jun 1 2007, 18:20
|- - rezident   Цитата(Сергей Борщ @ Jun 2 2007, 00:20) 3...   Jun 2 2007, 18:24
|- - zltigo   Цитата(rezident @ Jun 2 2007, 21:24) Кста...   Jun 2 2007, 19:00
||- - rezident   Цитата(zltigo @ Jun 3 2007, 01:00) The ar...   Jun 2 2007, 19:16
||- - zltigo   ЦитатаЭта цитата означает что... Да. Цитата(rezide...   Jun 2 2007, 19:27
|- - Сергей Борщ   Цитата(rezident @ Jun 2 2007, 21:24) Кста...   Jun 2 2007, 19:52
|- - zltigo   Цитата(Сергей Борщ @ Jun 2 2007, 22:52) И...   Jun 2 2007, 20:11
|- - Сергей Борщ   Цитата(zltigo @ Jun 2 2007, 23:11) А каки...   Jun 2 2007, 20:37
|- - zltigo   Цитата(Сергей Борщ @ Jun 2 2007, 23:37) А...   Jun 2 2007, 21:38
- - sensor_ua   IMHO, лучше массивы не пытаться укладывать в струк...   Jun 1 2007, 16:23
|- - defunct   Цитата(sensor_ua @ Jun 1 2007, 19:23) IMH...   Jun 1 2007, 17:14
- - SasaVitebsk   Наверное присоединюсь к defunct и zltigo. И структ...   Jun 1 2007, 17:50
|- - zltigo   Цитата(_Артём_ @ Jun 5 2007, 00:14) Вариа...   Jun 4 2007, 21:27
||- - _Артём_   Цитата(zltigo @ Jun 5 2007, 00:27) Ой...   Jun 5 2007, 20:20
||- - zltigo   Цитата(_Артём_ @ Jun 5 2007, 23:20) Приво...   Jun 5 2007, 20:30
||- - _Артём_   Цитата(zltigo @ Jun 5 2007, 23:30) Ну и п...   Jun 5 2007, 21:22
- - sensor_ua   Цитатаприсваивать указателю на такую структуру адр...   Jun 2 2007, 12:41
- - sensor_ua   Если нужно, то указателем вполне пожно пользоватьс...   Jun 2 2007, 14:33
- - SasaVitebsk   Честно говоря я уже в рассуждениях несколько потер...   Jun 2 2007, 17:44
- - rezident   Цитата(Сергей Борщ)Или динамическое выделение памя...   Jun 2 2007, 20:31


Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 22nd July 2025 - 20:03
Рейтинг@Mail.ru


Страница сгенерированна за 0.01519 секунд с 7
ELECTRONIX ©2004-2016