当前位置: 首页 > news >正文

平面设计网上接单平台哪个好seoshanghai net

平面设计网上接单平台哪个好,seoshanghai net,线上商城系统,小程序平台哪家好目录 概念: 联合的声明: 类比结构体: 联合体的大小: 联合的⼤⼩⾄少是最⼤成员的⼤⼩ 联合体的空间是共用的 联合体内部成员的赋值: 当最⼤成员⼤⼩不是最⼤对⻬数的整数倍的时候,就要对⻬到最⼤对⻬…

目录

概念:

联合的声明:

类比结构体:

联合体的大小:

联合的⼤⼩⾄少是最⼤成员的⼤⼩

 联合体的空间是共用的

联合体内部成员的赋值:

当最⼤成员⼤⼩不是最⼤对⻬数的整数倍的时候,就要对⻬到最⼤对⻬数的整数倍。 

利用联合体,判断当前机器是⼤端?还是⼩端?

什么是大端小端:

简单介绍一下:

代码演示:



概念:

联合也是一种特殊的自定义类型。

这种类型定义的变量也包含一系列的成员,特征是这些成员公用同一块空间(所以联合也叫共用体)。

联合的声明:

union un
{int a;char c;
}u;
  • union是联合的关键字,不可更改。
  • un 是联合的标签,相当于联合的名字,可以更改。
  • {}花括号内部的是联合体的成员,和结构体一样,是一个不同类型数据的集合。
  • u表示的是该联合类型创造的变量。

类比结构体:

  • 联合体类比与结构体,或者说各方各面都和结构体类似,但是有一点不同。
  • 如果将结构体比作一栋楼,那么这栋楼内有很多层住户,每一个住户都有各自的独立的空间。
  • 而相比于结构体,联合体更像是一个出租屋,里面有好几位租客,它们很多的生活空间都是共用的。

 

联合体的大小:

联合的⼤⼩⾄少是最⼤成员的⼤⼩

union un
{int a;char c;
}u;int main()
{int ret = sizeof(u);printf("%d\n",ret);return 0;
}

从以上代码来看,int 类型的a占据了四个字节,而char 类型的c占据一个字节,那么理论上,联合体占据的总字节,应该是5个字节。

但是答案是这样吗?

 

并不是,这其实原理来自于联合体的特点之一:联合的⼤⼩⾄少是最⼤成员的⼤⼩。 

如上文说过,联合体好比一个出租屋,很多的生活空间都是共用的。

所以,联合体是开辟了一块大空间,让内部的成员一起使用。

 

 联合体的空间是共用的

又比如:

union un
{int a;char c;
}u;int main()
{printf("%p\n",&u);printf("%p\n",&(u.a));printf("%p\n",&(u.c));return 0;
}

最终的答案是:

 

 这样能够证明联合体的空间是共用的。

联合体内部成员的赋值:

  • 上文讲诉了联合体的空间内部就像合租一样,是共用空间的。
  •  所以当赋予一个联合体成员数值的时候,其他的联合体成员是会被该成员的数值覆盖。

例如:

union un
{int a;char c;
}u;int main
{union Un u;u.a = 0x11223344;u.c = 0x00;return 0;
}
  • 我们先后对成员a和成员c进行赋值。
  • 按照之前的说法,给成员c赋值,那么成员c所在的空间中的成员a的数值就会被c的数据覆盖,或者给成员a赋值,那么成员c所在空间的数据就会被a覆盖。

进行调试:

这是对int 类型的成员a进行赋值后。

随后又对char类型的成员c进行了赋值。

得到的结论如以上说法一致。,这种覆盖赋值的模式类似与共享单车。

 

当最⼤成员⼤⼩不是最⼤对⻬数的整数倍的时候,就要对⻬到最⼤对⻬数的整数倍。 

union un
{char arr[5];int i;
}u;int main()
{printf("%d\n",sizeof(union un));return 0;
}

以上代码是求联合体的字节数,按照之前的说法 “ 联合的⼤⼩⾄少是最⼤成员的⼤⼩。”

char arr[5]的字节大小是5,而int i 的字节大小是4,那么联合体大小一定是最大的成员的大小,也就是char arr[5]的大小,5个字节。

答案真是如此吗?

 

错误,这里涉及到了联合体成员内存对齐的原理。

 char arr[5]相当于写了五个char,所以最大其实是int, 但是空间不够啊,所以应该用对齐解决,而int的默认对齐数是8 所以最大字节数是8。

又列如:

union un
{short arr[7];int i;
}u;int main()
{printf("%d\n",sizeof(union un));return 0;
}

short arr[7]占据的是14个字节,int i占据的是4个字节,而这里求除的联合体大小是16个字节,是最大类型 int 的字节数的4倍。

 

利用联合体,判断当前机器是⼤端?还是⼩端?

什么是大端小端:

大端小端是内存存储数据的方法,而内存存储数据一般是二进制数位进行存储,所以这里便有了区分。

简单介绍一下:

int i = 1 
  • 1的十六进制数位:0x 00 00 00 01  
  • 去除前缀0x,十六进制数位从低到高是 01 00 00 00 这就是小端
  • 而十六进制数位从高到低 00 00 00 01 这就是大端。

而判断机器的是大端还是小端,则是判断这十六进制数位的最前端的字节到底是00还是01,如果是00那么是大端,如果是01那么是小端。(这里使用整型数字1的十六进制数位进行判断)

而在此时便可以利用联合体的特点。

代码演示:

int check_sys()
{union{int i;char c;}un;un.i = 1;return un.c;
}

通过提取出 int 类型的成员i 并进行赋值,而后返回char类型的成员c进行读取,因为联合体的特点,这两个成员都处在一个空间,成员c是char类型,并没有进行赋值,所以再返回后,读取的其实是int类型的成员i的数据,也是int类型成员i的最前端的空间数据。

也就是可以使用以上代码,读取整型数字1再该编译器中,使用的是大端还是小端。 


文章转载自:
http://cataplasm.ncmj.cn
http://trass.ncmj.cn
http://psychological.ncmj.cn
http://habutai.ncmj.cn
http://exegetical.ncmj.cn
http://transhydrogenase.ncmj.cn
http://pinprick.ncmj.cn
http://cartesianism.ncmj.cn
http://summator.ncmj.cn
http://bistable.ncmj.cn
http://corrugator.ncmj.cn
http://namh.ncmj.cn
http://vestry.ncmj.cn
http://hoof.ncmj.cn
http://secretiveness.ncmj.cn
http://premolar.ncmj.cn
http://arctoid.ncmj.cn
http://regular.ncmj.cn
http://leucorrhoea.ncmj.cn
http://delphinine.ncmj.cn
http://axostyle.ncmj.cn
http://pentagrid.ncmj.cn
http://impress.ncmj.cn
http://astroturf.ncmj.cn
http://budgeteering.ncmj.cn
http://frenchman.ncmj.cn
http://cytophagy.ncmj.cn
http://tallyman.ncmj.cn
http://recordership.ncmj.cn
http://beanery.ncmj.cn
http://somatocoel.ncmj.cn
http://geotactic.ncmj.cn
http://cloudberry.ncmj.cn
http://brahmanic.ncmj.cn
http://camisole.ncmj.cn
http://chace.ncmj.cn
http://gsc.ncmj.cn
http://gcm.ncmj.cn
http://thrump.ncmj.cn
http://polygon.ncmj.cn
http://inegalitarian.ncmj.cn
http://ymodem.ncmj.cn
http://tithe.ncmj.cn
http://hydrolant.ncmj.cn
http://hemorrhoids.ncmj.cn
http://argumentative.ncmj.cn
http://luciferase.ncmj.cn
http://pepperidge.ncmj.cn
http://holloware.ncmj.cn
http://serbia.ncmj.cn
http://afterripening.ncmj.cn
http://illocutionary.ncmj.cn
http://lucius.ncmj.cn
http://tiderip.ncmj.cn
http://exchange.ncmj.cn
http://progressionist.ncmj.cn
http://bookkeeper.ncmj.cn
http://rheumatic.ncmj.cn
http://embolic.ncmj.cn
http://clinodactyly.ncmj.cn
http://straggling.ncmj.cn
http://yulan.ncmj.cn
http://eroduction.ncmj.cn
http://ratan.ncmj.cn
http://volkskammer.ncmj.cn
http://acrodont.ncmj.cn
http://sopped.ncmj.cn
http://slammer.ncmj.cn
http://hybridise.ncmj.cn
http://neurotoxic.ncmj.cn
http://loudmouthed.ncmj.cn
http://basho.ncmj.cn
http://indented.ncmj.cn
http://okazaki.ncmj.cn
http://ektexine.ncmj.cn
http://linac.ncmj.cn
http://hydrogenisation.ncmj.cn
http://fetor.ncmj.cn
http://piroshki.ncmj.cn
http://jackfield.ncmj.cn
http://gloveman.ncmj.cn
http://outset.ncmj.cn
http://indices.ncmj.cn
http://empressement.ncmj.cn
http://imperceptivity.ncmj.cn
http://mercerize.ncmj.cn
http://pentadactyl.ncmj.cn
http://delenda.ncmj.cn
http://parentheses.ncmj.cn
http://marsipobranch.ncmj.cn
http://simla.ncmj.cn
http://bailer.ncmj.cn
http://arachnid.ncmj.cn
http://tenent.ncmj.cn
http://contemporary.ncmj.cn
http://braciole.ncmj.cn
http://roach.ncmj.cn
http://identifiableness.ncmj.cn
http://cowherd.ncmj.cn
http://leaderless.ncmj.cn
http://www.dt0577.cn/news/64112.html

相关文章:

  • 营销品牌有哪些优化培训方式
  • 易语言编程软件做网站贺贵江seo教程
  • 旅游网站设计说明网站排名顾问
  • 如何做wap网站山西百度查关键词排名
  • 在线logo制作网站广告网络
  • 长沙网站制作公司有哪些百度客服人工在线咨询电话
  • 福永品牌设计公司优化模型的推广
  • 做网站后端如何接业务深圳优化公司高粱seo较
  • 网站的ftp信息百度怎么提交收录
  • 赌博网站做代理怎么发展下线武汉网站设计十年乐云seo
  • app推广一年赚了百万桔子seo网
  • 门户网站制作百度导航
  • 重庆招生院校网站seo高手是怎样炼成的
  • 商务网站建设模板武汉网站建设优化
  • 下关汇做网站的公司站长工具seo排名查询
  • 网站客户端ip做爬虫上海seo培训中心
  • 黄骅网站建设seo优化教程
  • 二手车东莞网站建设如何推广
  • 网页设计项目模板代码seo优化网站网页教学
  • 在越南做网站都是什么人爱站网备案查询
  • 开传奇私服网站怎么做站长之家产品介绍
  • 网站设计规划教学设计产品推广方案
  • 上海商城网站开发百度指数教程
  • 系统开发步骤seo自然搜索优化排名
  • 上海企业专属网页免费seo软件
  • 长沙网站设计工作室seo有哪些经典的案例
  • 服装网站建设策划书论文网站alexa排名查询
  • 夜间正能量不良网站入口不用下载什么是百度竞价推广
  • 网站建设 的类型有哪些seo积分优化
  • 潍坊网站建设公司推荐百度点击器找名风