假设我们有两个数据结构:
struct ST1 {
char c1;
short s;
char c2;
double d;
int i;
};
"在记忆中它将是:"
32 bit - 20 bytes
0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 |
------------------------------------------------------------------------------------------
c1| PB| s | s | c1| PB| PB| PB| d | d | d | d | d | d | d | d | i | i | i | i |
64 bit - 24 bytes | 20 | 21 | 22 | 23 |
previous sequence + ---------------------
| PB | PB | PB | PB |
但是我们可以重新排列它,使这些数据适应机器字。像这样:
struct ST2 {
double d;
int i;
short s;
char c1;
char c2;
};
在这种情况下,无论是32位还是64位,它都将以相同的方式表示(16个字节):
0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 |
----------------------------------------------------------------------
d | d | d | d | d | d | d | d | i | i | i | i | s | s | ch1| ch2|
我有几个问题:
- 这可能是一个猜测,但
struct
的主要规则是在开始定义更大的变量吗? - 我理解它不能用于独立变量。像
char str[] = "Hello";
? - 填充字节,它的代码是什么?它在ASCII表中的某个位置吗?抱歉,我找不到。
- 两个结构体,所有成员都由不同地址表示在内存中,它们可以不按顺序放置在内存中吗?
- 这样的结构体:
struct ST3 { char c1; char c2; char c3;} st3;
大小为3
,如果我们将具有其他类型的成员添加到其中,它将被对齐。但为什么它没有被对齐呢?
packed
将消除填充,可能会强制成员不正确地对齐,这即使在x86上也有影响(例如,只有当double
正确对齐时才是原子访问)。 - Christoph