|
34 / 34 / 4
Регистрация: 19.02.2013
Сообщений: 118
|
|||||||||||
приведение типов указателей13.03.2013, 01:02. Показов 5147. Ответов 8
Метки нет (Все метки)
Задача у меня простая. Нужно побитно оперировать с числом unsigned int и на каких-то этапах заносить его в массив.
для начала я решил, что пусть хотя бы это число выводится в memo элементик на форме. написал код:
[c++ Error] UnitMain.cpp (61): E2109 Not an allowed type чтобы знать что проблема не в memo(int числа выводит без проблем), сделал так:
По интернету лазил, ничего такого, чтоб сразу заработало не нашел. Помогите пожалуйста Спасибо
0
|
|||||||||||
| 13.03.2013, 01:02 | |
|
Ответы с готовыми решениями:
8
Отличие приведение типов указателей Приведение типов умных указателей
|
|
~ Эврика! ~
1258 / 1007 / 74
Регистрация: 24.07.2012
Сообщений: 2,002
|
|
| 13.03.2013, 01:05 | |
|
Чуваааак... От (unsigned int*) в строке pntr= (unsigned int*)&Manth[0]; тип указателя pntr не поменяется. Приведение надо писать там, где указатель разыменовывается, в строке number=*pntr;
0
|
|
|
Модератор
8978 / 6744 / 921
Регистрация: 14.02.2011
Сообщений: 23,854
|
||||||||||||
| 13.03.2013, 01:12 | ||||||||||||
|
у меня например вот это
что равно
1
|
||||||||||||
|
34 / 34 / 4
Регистрация: 19.02.2013
Сообщений: 118
|
||||||
| 13.03.2013, 01:12 [ТС] | ||||||
|
по указателям я всякой инфы набрался тут
попробовал:
0
|
||||||
|
Модератор
8978 / 6744 / 921
Регистрация: 14.02.2011
Сообщений: 23,854
|
|||||
| 13.03.2013, 01:20 | |||||
|
посмотри на битовые поля
http://www.c-cpp.ru/books/bitovye-polya а потом используй union объединение Добавлено через 3 минуты пытаемся указатель
1
|
|||||
|
34 / 34 / 4
Регистрация: 19.02.2013
Сообщений: 118
|
||||
| 13.03.2013, 02:06 [ТС] | ||||
Так что, похоже, даже если бы я всё-таки нашёл способ приведения типа указателя, я бы получил совсем не то что рассчитывал. Выходом из этой ситуации видятся битовые поля
Но меня смущает ряд ограничений приведенных в упомянутой статье:
1. Что такое union и чем оно отличается от struct? 2. Если нельзя получить адрес элемента структуры, можно ли получить адрес всей структуры? 3. Невозможность побитного использования памяти (за исключением битовых полей) исходит от ОС или от архитектуры процессора?
0
|
||||
|
Модератор
8978 / 6744 / 921
Регистрация: 14.02.2011
Сообщений: 23,854
|
||||||||||||||||||||||||
| 13.03.2013, 02:49 | ||||||||||||||||||||||||
|
попробую своими словами если ты напишешь так
теперь ты можешь записать int
во первых структура занимает память равную сумме её членов а объединение сколько занимает самый большой во вторых в структуре каждый член отдельно а в объединении это одно и тоже грубо говоря это разные представления памяти но если тебе нужен массив то проще было сделать так
есть микроконтроллеры которые позволяют работать с битами и там в С есть тип bit Добавлено через 20 минут про объединения http://www.c-cpp.ru/books/obedineniya
2
|
||||||||||||||||||||||||
|
34 / 34 / 4
Регистрация: 19.02.2013
Сообщений: 118
|
|||||||||||
| 15.03.2013, 02:01 [ТС] | |||||||||||
|
ValeryS Большое Человеческое Вам спасибо! Я разобрался
Насколько я понял, битовые поля придумали для компактного хранения баз данных. Если оперативная память не предполагает побитного считывания, то значит должен быть встроенный программный или аппаратный метод компоновки битовых полей, который можно использовать для имитации побитного доступа в байте. В частности, если обьявить структуру с однобитовыми полями внутри обьединения получаем побитный доступ: Например:
В то время как:
(Непонятно зачем есть bool, если он по сути char) Словом, респект всем откликнувшимся Вопрос закрыт
0
|
|||||||||||
|
4226 / 1796 / 211
Регистрация: 24.11.2009
Сообщений: 27,562
|
||
| 15.03.2013, 08:48 | ||
|
0
|
||
| 15.03.2013, 08:48 | |
|
Помогаю со студенческими работами здесь
9
Приведение указателей Приведение указателей Приведение указателей в стиле си
Приведение типов Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
|||
|
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11
— это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
|
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11
Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
|
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
|
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/
O1rJuneU_ls
https:/ / vkvideo. ru/ video-115721503_456239114
|
|
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ВВЕДЕНИЕ
Введу сокращения:
аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
|
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi
ветка по-частям.
коммит Create переделка под биомассу. txt
вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
|
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ *
Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях.
Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её.
Последовательность действий:. . .
|
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
|