1、前言git
本節,咱們將學習C語言庫中數據存儲方式,並經過編寫代碼肯定當前系統的數據存儲方式。github
2、簡介面試
1.大端模式ide
大端模式是指數據的高字節保存在內存的低地址中,而數據的低字節保存在內存的高地址中。學習
2.小端模式指針
小端模式是指數據的高字節保存在內存的高地址中,而數據的低字節保存在內存的低地址中。code
3.爲何會有大小端之分?blog
爲何會有大小端模式之分呢?這是由於在計算機系統中,咱們是以字節爲單位的,每一個地址單元都對應着一個字節,一個字節爲 8bit。可是在C語言中除了8bit的char以外,還有16bit的short型,32bit的long型(要看具體的編譯器),另外,對於位數大於 8位的處理器,例如16位或者32位的處理器,因爲寄存器寬度大於一個字節,那麼必然存在着一個如何將多個字節安排的問題。所以就致使了大端存儲模式和小端存儲模式。內存
4.圖例說明get
圖中表示數據0x12345678的數據存儲方式。
3、實例
1.指針方式
#include <stdio.h> int is_big_endian(void) { int val = 0x12345678; char data = 0; data = ((char*)&val)[0]; if (0x12 == data) { return 1; }else if(0x78 == data) { return 0; } } int main(void) { if (1 == is_big_endian()) { printf("system is large endian!\r\n"); }else if (0 == is_big_endian()) { printf("system is small endian!\r\n"); } return 0; }
執行結果以下:
2.共用體方式
#include <stdio.h> union udata { int a; char b; }data; int is_big_endian(void) { data.a = 0x12345678; if (0x12 == data.b) { return 1; }else if (0x78 == data.b) { return 0; } } int main(void) { if (1 == is_big_endian()) { printf("system is large endian!\r\n"); }else if (0 == is_big_endian()) { printf("system is small endian!\r\n"); } return 0; }
執行結果以下:
4、結語
如您在使用過程當中有任何問題,請加QQ羣進一步交流,也能夠github提Issue。
QQ交流羣:906015840 (備註:物聯網項目交流)
github倉庫地址:https://github.com/solitary-sand/c
一葉孤沙出品:一沙一世界,一葉一菩提