标签:int 区分 端的 保存 0x78 地址 内存 大小 include
话不多说,直接插入代码。
以 int a = 0x12345678为例
请注意,0x12是数据的高地址,0x78是数据的低地址。
如果是大端,在内存中(按照低地址内存到高地址内存),保存如下:0x12,0x34,0x56,0x78
即数据的高地址保存在内存的低地址,按照保存顺序,是符合阅读习惯的。
比如你敲击int a = 0x12345678的代码,肯定是按照12345678的顺序输入。
如果读取这4字节的内存,显示的和你输入的一样,就是大端。
如果是小段,在内存中(按照低地址内存到高地址内存),保存如下:0x78,0x56,0x34,0x12
即数据的低地址保存在内存的低地址,按照保存顺序,需要转换才能按照写的顺序进行阅读。
#include <windows.h> #include <iostream> #include <string> using namespace std; static union { char c[4]; unsigned long l; } endian_test = { { 'l', '?', '?', 'b' } }; #define ENDIANNESS ((char)endian_test.l) int main() { cout<<"大小端: "<<ENDIANNESS<<endl; int a = 0x12345678; cout<<"a地址 "<<&a<<endl; char str[4]; memcpy(str,(&a),4); cout<<"str地址 "<<&str<<endl; cout<<"以下输出str"<<endl; for(int i=0;i<4;i++) { printf("%x %x\n",str[i],(str+i)); } cout<<"以下输出a"<<endl; printf("%x %x\n",*(char*)(&a),(char*)(&a)); printf("%x %x\n",*((char*)(&a)+1),((char*)(&a)+1)); printf("%x %x\n",*((char*)(&a)+2),((char*)(&a)+2)); printf("%x %x\n",*((char*)(&a)+3),((char*)(&a)+3)); }
运行结果如图:
标签:int,区分,端的,保存,0x78,地址,内存,大小,include 来源: https://www.cnblogs.com/dayq/p/15819736.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。