一块内存不同的访问方式

// 1.数组的便捷访问
// 一块内存两种等价的访问方式
template <typename T>
union Mat4x4 {
struct{
T m00, m01, m10, m11;
};
T m[][];
}; int main(int argc, const char * argv[])
{
Mat4x4<float> mat = {,,,}; std::cout<< mat.m00 <<std::endl;
std::cout<< mat.m[][] <<std::endl;
// output: 1
// 1
return ;
}

将变量拆成字节访问

int main(int argc, const char * argv[])
{
union Int4 {
struct {
unsigned char _1, _2, _3, _4;
};
int _int;
}; Int4 integer;
integer._int = ;
printf("%08X\n", integer._int);
printf("%02X\n", integer._1);
printf("%02X\n", integer._2);
printf("%02X\n", integer._3);
printf("%02X\n", integer._4);
// output:
// 05F5E100
// 00
// E1
// F5
//
return ;
}

判断CPU大小端问题

int big_endian (void)
{
union{
long l;
char c[sizeof(long)];
}u; u.l = ;
return (u.c[sizeof(long) - ] == );
} int main(int argc, const char * argv[])
{
//在大端格式中,字数据的高字节存储在低地址中,而字数据的低字节则存放在高地址中
//与大端存储格式相反,在小端存储格式中,低地址中存放的是字数据的低字节,高地址存放的是字数据的高字节
if(!big_endian()) {
printf("CPU是小端模式\n");
}
else {
printf("CPU是大端模式\n");
}
}
// 这样判断大小端更简洁
bool is_big_endian(void)
{
unsigned int test = 0xff000000;
return (*(unsigned char *)&test == 0xff);
}

Union的内存占用

首先内存占用肯定是要大于最大的一项,其次因为内存对齐的缘故

int main(int argc, const char * argv[])
{
// # 内存问题
union Max {
char _1;
int _4;
double _8;
char _17[];
}; printf("size: %lu\n", sizeof(Max));
// output: size: 24 return ;
}

使用注意

Union是C语言的东西,当然C++中也会有了,但是Union在C++中有些需要注意的地方。

由于union里面的东西共享内存,所以不能定义静态、引用类型的变量。

下面是错误的代码:

union Test {
static int c;
int &ref;
};

C语言中没有类的概念,更没有构造和析构函数,Union中如果存在C++对象,那么C++对象必须不能存在构造和析构函数,

默认的构造和析构不会被调用,存C++对象指针是没问题的。

union TestUnion {

    class {
public:
//去掉注释会发生错误
//TestClass() {
// printf("构造\n");
//}
//~TestClass() {
// printf("析构\n");
//} int var;
} c; }; int main(int argc, const char * argv[])
{
TestUnion t = {};
printf("var: %d\n", t.c.var);
return ;

所以,我们在C++中使用union时,尽量保持C语言中使用union的风格,尽量不要让union带有对象。

Union的妙用和注意的更多相关文章

  1. C++ Union妙用(将列表初始化用于数组元素)

    Union是个不被注意的关键字,意为联合体,这是个诡异的名字.若不是为了继承C语言,它也不会出现在C++中(虽说,union在C++中得到了扩充,完成了接近类的功能).它的作用主要是节省内存空间,在嵌 ...

  2. (C语言)共用体union的使用方法举例

    曾经在学校学习C语言的时候一直搞不懂那个共用体union有什么用的.工作之后才发现它的一些妙用,现举比例如以下: 1. 为了方便看懂代码. 比方说想写一个3 * 3的矩阵,能够这样写: [ 注:以下用 ...

  3. C语言union关键字,union和struct区别

    union 关键字的用法与struct 的用法非常类似. union 维护足够的空间来置放多个数据成员中的“一种”,而不是为每一个数据成员配置空间,在union 中所有的数据成员共用一个空间,同一时间 ...

  4. 【CSS进阶】伪元素的妙用--单标签之美

    最近在研读 <CSS SECRET>(CSS揭秘)这本大作,对 CSS 有了更深层次的理解,折腾了下面这个项目: CSS3奇思妙想 -- Demo (请用 Chrome 浏览器打开,非常值 ...

  5. SQL Server-聚焦UNIOL ALL/UNION查询(二十三)

    前言 本节我们来看看有关查询中UNION和UNION ALL的问题,简短的内容,深入的理解,Always to review the basics. 初探UNION和UNION ALL 首先我们过一遍 ...

  6. angular2系列教程(十)两种启动方法、两个路由服务、引用类型和单例模式的妙用

    今天我们要讲的是ng2的路由系统. 例子

  7. SQL 提示介绍 hash/merge/concat union

    查询提示一直是个很有争议的东西,因为他影响了sql server 自己选择执行计划.很多人在问是否应该使用查询提示的时候一般会被告知慎用或不要使用...但是个人认为善用提示在不修改语句的条件下,是常用 ...

  8. JavaScript的妙与乐(一)之 函数优化

    JavaScript的妙与乐系列文章主要是展示一些JavaScript上面比较好玩一点的特性和一些有用的技巧,里面很多内容都是我曾经在项目中使用过的一些内容(当然,未必所有技巧的使用频率都很高^_^) ...

  9. Promise的前世今生和妙用技巧

    浏览器事件模型和回调机制 JavaScript作为单线程运行于浏览器之中,这是每本JavaScript教科书中都会被提到的.同时出于对UI线程操作的安全性考虑,JavaScript和UI线程也处于同一 ...

随机推荐

  1. 问题:ldconfig

    显示加载库文件libjli.so时候出错. 解决办法 1.find / -name 'libjli.so'文件 路径在:/data0/home/app/act/jdk/jdk1.7.0_15/jre/ ...

  2. Log4j2 配置笔记(Eclipse+maven+SpringMVC)

    Log4j2相关介绍可以百度看下,这里只注重配置Log4j2 能够马上跑起来: 1.pom.xml文件中添加Log4j2的相关Maven配置信息 <!-- log4j2 --> <d ...

  3. 【环境】openSUSE安装记录 - 古董本上的windows 7和opensuse双系统

    昨天和朋友交流,提到Linux,他说可以去接触SUSE.我马上打开浏览器搜索了一下,发现SUSE是一个Linux操作系统的企业服务器的发行版,是收费的.朋友说,许多公司都用这个,他曾经给公司安装过SU ...

  4. UVALive - 7374 Racing Gems 二维非递减子序列

    题目链接: http://acm.hust.edu.cn/vjudge/problem/356795 Racing Gems Time Limit: 3000MS 问题描述 You are playi ...

  5. ubuntu10.04编译内核不显示grub菜单解决

    问题描述:        ubuntu10.04 内核版本2.6.32.28编译内核之后版本2.6.37.6,系统在编译完内核之后,不显示grub菜单 参考资料:            http:// ...

  6. weiapi2.2 HelpPage自动生成接口说明文档和接口测试功能

    在开发Webapi项目时每写完一个方法时,是不是需要添加相应的功能说明和测试案例呢?为了更简单方便的写说明接口文档和接口测试HelpPage提供了一个方便的途径. 她的大致原理是:在编译时会生成.dl ...

  7. Codeforces Round #274 (Div. 2)

    A http://codeforces.com/contest/479/problem/A 枚举情况 #include<cstdio> #include<algorithm> ...

  8. The Brain vs Deep Learning Part I: Computational Complexity — Or Why the Singularity Is Nowhere Near

    The Brain vs Deep Learning Part I: Computational Complexity — Or Why the Singularity Is Nowhere Near ...

  9. Codeforces Round #216 (Div. 2)解题报告

    又范低级错误! 只做了两题!一道还被HACK了,囧! A:看了很久!应该是到语文题: 代码:#include<iostream> #include<];    ,m2=;    ;i ...

  10. pyhton Chapter3 读文件

    使用内置函数open()打开文件,data=open("1.txt").利用data.close()关闭文件.利用data.readline()读取文件中的一行数据,然后指示读取文 ...