要確定數據佔用多少位元組存儲,需要認真進行分析,區分起來有如下內容需要注意:
1、是否是簡單數據類型。簡單數據類型包括系統自帶的int、float、double、char、long、long
long、short等,對於這類型數據,要知道佔用的存儲位元組數,只需要對其進行sizeof(類型)即可。
2、復雜數據類型:這類包括數組、聯合(union)、結構體。數組的情況有一些特殊,如果你的數組是在作用域內定義,直接sizeof(數組名)可以獲取數組所佔位元組數,但是如果作為參數傳入函數,無法使用這種方法。聯合所佔位元組數為其中所有元素中最大的一個所佔的位元組數。結構體的所佔位元組數用sizeof(結構體)可以求得。
3、注意:字元串數組單獨拿出來討論,如果你需要一個10位元組的字元串數組,一定記得多算一個結束符的位置。
Ⅱ 關於c語言中聯合體/共用體中數據存放的問題
你好!!!
首先我們了解聯合體的所有成員是在內存中共享一塊內存的,在某一時刻只能有一個成員使用這個內存!!!
我們來看看一個例子:
#include <stdio.h>
union
{
int i;
char x[2];
}a;
void main()
{
a.x[0] = 10;
a.x[1] = 1;
printf("%d",a.i);
}
答案:266
解釋如下:
union
{
int i;
char x[2];
}a;
在聯合體a中定義了兩種數據類型,字元數組x以及整形變數i.其中整形變數是16位的,數組大小為2的字元數組為8X2=16位。如此一來,編譯器便會為聯合體a在內存中開辟一個16位的空間,這個空間里存儲聯合體的數據,但是這個空間只有16位,它既是整形變數的數據,也是字元數組的數據。如果你的程序從字元數組的角度解析這個空間,那麼它就是兩個字元,如果你的程序從整型的角度解析這個空間,那麼它就是一個整數。
以你的程序為例子,現在已經開辟了一個16位的空間,然後我們假定現在空間還沒有被賦值,為:
00000000 00000000
那麼在運行完代碼
a.x[0] = 10;
a.x[1] = 1;
之後,16位的空間變為:
00001010 00000001
然後程序運行
printf("%d",a.i);
就是把聯合體a當成一個整數來解析,而不是字元串數組。那麼這樣一來,程序就把這16位變成了一個完整的整數:
(00000001 00001010)二進制 = (266)十進制
注意,你可以看到程序在把16位弄成整數的時候把後面八位放在了前面,前面八位放在了後面。這個反序是計算機存儲結構造成的,這個和聯合體沒有直接關系。如果感興趣的話可以參考匯編語言。
現在我們來看看,你給的例子:
union dt
{
int a;
char b;
double c;
}data;
此時的聯合體所佔的內存大小是8個位元組,接下來執行:
data.a=5;
此此時內存中就不是空的了,也就不會是你說的是隨機數,
但是輸出:printf("%lf",data.c);結果是0.000000,這個結果我還不能給你准確的解釋。但是我可以肯定這與系統把double轉換成int 和int 轉化成 double 有關!!!
暫時我只能解釋這那多!!!
Ⅲ 數組的大小數組中能夠存放多少個數組元素
這個問題 應該這么說:如果定義的是一個簡單類型的數組,例如:int my_int_array[100] ; 那麼最多能夠存放:100個元素,且每個元素的詳細大小為:sizeof(int) ;數組的合法存取下標為:my_int_array[0] -- my_int_array[99],如果超過了這個范圍,那麼就會產生數組越界,程序就會出現錯誤了。
如果定義的是一個復合類型的數組,例如:結構數組。舉例如下:
struct myself_datatype
{
char name[40] ;
int sex ;
int age ;
} myself_data ;
myself_data my_struct_array[100] ;
那麼結構數組中的每一個元素所佔的空間大小就是:sizeof(myself_data.name) + sizeof(myself_data.sex) + sizeof(myself_data.age) 。