Форум программистов, компьютерный форум CyberForum.ru

Union что из себя представляет? - C++

Восстановить пароль Регистрация
 
 
Рейтинг: Рейтинг темы: голосов - 145, средняя оценка - 4.79
VintProg
 Аватар для VintProg
7 / 7 / 0
Регистрация: 24.06.2009
Сообщений: 44
27.08.2010, 11:33     Union что из себя представляет? #1
Читал много книг и там про него не чего не было сказано, парни объясните мне пожалуйста для чего он?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
27.08.2010, 11:33     Union что из себя представляет?
Посмотрите здесь:

Union C++
Union C++
Union с явными указателями или void*- что выбрать? C++
Union C++
Что из себя представляет допустим поток ввода/вывода C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
iama
 Аватар для iama
1249 / 974 / 48
Регистрация: 30.07.2010
Сообщений: 5,297
27.08.2010, 11:45     Union что из себя представляет? #2
Объединение (англ. union) в программировании — структура данных, члены которой расположены по одному и тому же адресу. Поэтому размер объединения равен размеру его наибольшего члена. В любой момент времени объединение хранит значение только одного из членов.
непонятно-то что?
VintProg
 Аватар для VintProg
7 / 7 / 0
Регистрация: 24.06.2009
Сообщений: 44
27.08.2010, 11:46  [ТС]     Union что из себя представляет? #3
И смысл?
Mencey
 Аватар для Mencey
145 / 92 / 7
Регистрация: 22.07.2010
Сообщений: 424
27.08.2010, 11:48     Union что из себя представляет? #4
Вот что по этому поводу думает справочник по C:

Из справочника по C
1.2.8. Объединения (смеси)
Объединение подобно структуре, однако в каждый момент времени может использоваться (или другими словами быть ответным) только один из элементов объединения. Тип объединения может задаваться в следующем виде:

union { описание элемента 1;
...
описание элемента n; };

Главной особенностью объединения является то, что для каждого из объявленных элементов выделяется одна и та же область памяти, т.е. они перекрываются. Хотя доступ к этой области памяти возможен с использованием любого из элементов, элемент для этой цели должен выбираться так, чтобы полученный результат не был бессмысленным.

Доступ к элементам объединения осуществляется тем же способом, что и к структурам. Тег объединения может быть формализован точно так же, как и тег структуры.

Объединение применяется для следующих целей:

- инициализации используемого объекта памяти, если в каждый момент времени только один объект из многих является активным;

- интерпретации основного представления объекта одного типа, как если бы этому объекту был присвоен другой тип.

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

Пример:

union { char fio[30];
char adres[80];
int vozrast;
int telefon; } inform;
union { int ax;
char al[2]; } ua;

При использовании объекта infor типа union можно обрабатывать только тот элемент который получил значение, т.е. после присвоения значения элементу inform.fio, не имеет смысла обращаться к другим элементам. Объединение ua позволяет получить отдельный доступ к младшему ua.al[0] и к старшему ua.al[1] байтам двухбайтного числа ua.ax .
VintProg
 Аватар для VintProg
7 / 7 / 0
Регистрация: 24.06.2009
Сообщений: 44
27.08.2010, 11:53  [ТС]     Union что из себя представляет? #5
Ясно теперь, а для чего его можно использовать?
Mencey
 Аватар для Mencey
145 / 92 / 7
Регистрация: 22.07.2010
Сообщений: 424
27.08.2010, 11:58     Union что из себя представляет? #6
VintProg, для экономия памяти.
Например:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
// Объединение
union A {
  int a;
  float b;
  double c;
};
 
// Структура
struct B {
  int a;
  float b;
  double c;
};
sizeof( union A ) бадет равен sizeof( double ), а
sizeof( struct B ) будет равен sizeof( int ) + sizeof( float ) + sizeof( double ).
fasked
Эксперт C++
 Аватар для fasked
4925 / 2505 / 180
Регистрация: 07.10.2009
Сообщений: 4,306
Записей в блоге: 1
27.08.2010, 12:09     Union что из себя представляет? #7
Цитата Сообщение от Mencey Посмотреть сообщение
sizeof( struct B ) будет равен sizeof( int ) + sizeof( float ) + sizeof( double ).
Не совсем так. Надо учитывать выравнивание.
Mencey
 Аватар для Mencey
145 / 92 / 7
Регистрация: 22.07.2010
Сообщений: 424
27.08.2010, 12:18     Union что из себя представляет? #8
Цитата Сообщение от fasked Посмотреть сообщение
Не совсем так. Надо учитывать выравнивание.
Но всеравно sizeof( A ) < sizeof( B )!
alex_x_x
бжни
 Аватар для alex_x_x
2441 / 1646 / 84
Регистрация: 14.05.2009
Сообщений: 7,163
27.08.2010, 12:29     Union что из себя представляет? #9
если у вас из десяти структур одновременно используется только одна, то имеет смысл объеденить их в union, можно даже в безымянный, хотя в с++ его реже используют
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
27.08.2010, 13:03     Union что из себя представляет? #10
Всё-таки, по-моему, юнион со структурами сравнивать не очень корректно, ибо обычно структуры создаются так, чтобы использовались все их элементы. Вообще сколько кода видел, никто не использовал юнионы. Так что зачастую они не нужны.
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9373 / 5423 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
27.08.2010, 17:21     Union что из себя представляет? #11
Цитата Сообщение от VintProg Посмотреть сообщение
Ясно теперь, а для чего его можно использовать?
Ну применение-то всему можно найти... Вот к примеру програмка, определяющая порядок байт в системе (первый младший / первый старший):
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <stdio.h>
 
union {
    unsigned short sh;
    unsigned char bt[sizeof(short)];
} un;
 
int main(void){
    if ( sizeof(short) != 2 ){
        printf("Too long size for short type.\n");
        return 1;
    }
    un.sh = 0x0102;
    printf("%s endian\n", ( un.bt[0] == 1 ) ? "Big" : "Little");
 
    return 0;
}
Mencey
 Аватар для Mencey
145 / 92 / 7
Регистрация: 22.07.2010
Сообщений: 424
27.08.2010, 18:33     Union что из себя представляет? #12
Цитата Сообщение от silent_1991 Посмотреть сообщение
Так что зачастую они не нужны.
Вы неправы их хоть и редко используют, но вещь нужная!
daniilorain
👻👻👻
 Аватар для daniilorain
17 / 24 / 11
Регистрация: 22.04.2016
Сообщений: 166
18.06.2016, 19:01     Union что из себя представляет? #13
Прошу прощения за некропостинг, мало ли найдутся такие люди, как и я, ищущие ответ, где может пригодится union.
Эта программа выводит ASCII-код введённой буквы (из книги Шилдта):
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
45
46
47
48
49
50
51
52
53
54
55
#include <iostream>
#include <ctime>
 
using namespace std;
 
struct byte {
    unsigned a : 1;
    unsigned b : 1;
    unsigned c : 1;
    unsigned d : 1;
    unsigned e : 1;
    unsigned f : 1;
    unsigned g : 1;
    unsigned h : 1;
};
 
union bits {
    char ch;
    struct byte bit;
} ascii;
 
void disp_bits(bits b);
 
int main() {
    setlocale(0, "");
 
    do {
        cin >> ascii.ch;
        cout << ":";
        disp_bits(ascii);
    } while (ascii.ch != 'q');
 
    cin.get();
    return 0;
}
 
void disp_bits(bits b) {
    if (b.bit.h) cout << "1";
    else cout << "0";
    if (b.bit.g) cout << "1";
    else cout << "0";
    if (b.bit.f) cout << "1";
    else cout << "0";
    if (b.bit.e) cout << "1";
    else cout << "0";
    if (b.bit.d) cout << "1";
    else cout << "0";
    if (b.bit.c) cout << "1";
    else cout << "0";
    if (b.bit.b) cout << "1";
    else cout << "0";
    if (b.bit.a) cout << "1";
    else cout << "0";
    cout << "\n";
}
AmirAfendin
0 / 0 / 0
Регистрация: 26.11.2015
Сообщений: 3
20.06.2016, 15:31     Union что из себя представляет? #14
я как раз сейчас через гугл попал на эту тему и твой пост вроде бы вовремя но этот код просто агония, это вобще C++? Что за "unsigned a : 1;" для начала? впервые вижу
Raali
572 / 276 / 12
Регистрация: 06.07.2013
Сообщений: 917
Завершенные тесты: 1
20.06.2016, 15:37     Union что из себя представляет? #15
Цитата Сообщение от AmirAfendin Посмотреть сообщение
unsigned a : 1
это битовое поле - первый бит из восьми в структуре byte
daniilorain
👻👻👻
 Аватар для daniilorain
17 / 24 / 11
Регистрация: 22.04.2016
Сообщений: 166
21.06.2016, 19:11     Union что из себя представляет? #16
Нажимайте на кнопку с синей галочкой вниз, я ведь ваше сообщение случайно увидел
Это битовое поле. Здесь переменные a,b,c...h занимают каждые по 1 биту.
Они нужны здесь для того, чтобы вывести код введённой буквы. Символ занимает 1 байт, то есть 8 бит (в некоторых системах 1 байт = 9 бит, но это оффтоп), в union как раз используются 8 символов, которые занимаются по 1 биту, то есть 1 * 8 = 8 бит они занимают в общем, что соответствует одному символу, который будет введён и записан в union. Символы представляются для компьютера в виде последовательности 0,1 (как и всё остальное), так вот в этот union для компьютера записались нули и единицы. И так как введённый символ ch и структура с битовыми полями занимаются одну область памяти, то нули и единицы можно считать.
01100001 -- двоичное представление символа 'a'
Миниатюры
Union что из себя представляет?  
Evg
Эксперт С++Автор FAQ
 Аватар для Evg
16843 / 5264 / 323
Регистрация: 30.03.2009
Сообщений: 14,159
Записей в блоге: 26
21.06.2016, 19:51     Union что из себя представляет? #17
Цитата Сообщение от easybudda Посмотреть сообщение
Вот к примеру програмка, определяющая порядок байт в системе
С точки зрения стандарта такое поведение незаконное, т.к. нельзя писать в одно поле union'а, а читать из другого. Хотя постфактум такой код будет работать везде (а может быть почти везде)
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9373 / 5423 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
21.06.2016, 21:02     Union что из себя представляет? #18
Цитата Сообщение от Evg Посмотреть сообщение
Хотя постфактум такой код будет работать везде (а может быть почти везде)
Это пример из книжки "UNIX разработка сетевых приложений".
silent_1991
Эксперт C++
4938 / 3014 / 149
Регистрация: 11.11.2009
Сообщений: 7,024
Завершенные тесты: 1
21.06.2016, 21:46     Union что из себя представляет? #19
Цитата Сообщение от easybudda Посмотреть сообщение
Это пример из книжки "UNIX разработка сетевых приложений".
И тем не менее, книжка "UNIX разработка сетевых приложений" - не стандарт языка, не правда ли?) И оговорка о том, что стандарт говорит, что подобное действие - UB, здесь вполне уместна.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
21.06.2016, 21:54     Union что из себя представляет?
Еще ссылки по теме:

C++ Что из себя представляют типы данных?
Что из себя представляет код в стеке, и как его использовать C++
STL Вектор Копирование элемнтов себя из себя C++

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

Или воспользуйтесь поиском по форуму:
Evg
Эксперт С++Автор FAQ
 Аватар для Evg
16843 / 5264 / 323
Регистрация: 30.03.2009
Сообщений: 14,159
Записей в блоге: 26
21.06.2016, 21:54     Union что из себя представляет? #20
Вообще эта тема несколько раз уже проскакивала на форуме. Есть такое понятие, которое на бытовом языке называется "strict aliasing rules". В стандарте конкретно таких слов нету, но есть некий смысл, из которого следует, что указатели на разные типы данных, исключая указатель на char*, должны смотреть на разную память. И косвенно (или даже прямо) оттуда вытекают ограничения в работе с union'ами. С ходу я в стандарте это место не смог найти. После отпуска поищу на работе, у меня где-то это было выписано
Yandex
Объявления
21.06.2016, 21:54     Union что из себя представляет?
Ответ Создать тему
Опции темы

Текущее время: 04:20. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru