- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
C11 中的
Alignas
没有像我预期的那样工作。这是我的代码:
#include <inttypes.h>
#include <stdalign.h>
#include <stdio.h>
struct A
{
alignas(int32_t) int16_t a;
int16_t b;
};
struct B
{
int16_t a;
alignas(int32_t) int16_t b;
};
struct C
{
int16_t a;
int32_t b;
};
struct D
{
int32_t a;
int16_t b;
};
int main(void)
{
printf("%zu, %zu\n", alignof(int16_t), sizeof(int16_t));
printf("%zu, %zu\n", alignof(int32_t), sizeof(int32_t));
printf("%zu, %zu\n", alignof(struct A), sizeof(struct A));
printf("%zu, %zu\n", alignof(struct B), sizeof(struct B));
printf("%zu, %zu\n", alignof(struct C), sizeof(struct C));
printf("%zu, %zu\n", alignof(struct D), sizeof(struct D));
}
输出:
2, 2
4, 4
4, 4
4, 8
4, 8
4, 8
我希望所有这些结构的大小都相同。为什么 struct A
与 struct B
的大小不同?我是否误解了 alignas
的工作原理?
最佳答案
假设 int16_t
需要 2 字节对齐,int32_t
需要 4 字节对齐。
struct A
{
alignas(int32_t) int16_t a;
int16_t b;
};
这的自然布局是 2 个字节用于 a
,2 个字节用于 b
,以及整个结构的 2 字节对齐。
但是 alignas(int32_t)
引入了额外的约束:a
必须在 4 字节边界上对齐。这会强制整个结构在 4 字节边界上对齐。但是 a
的大小仍然只有 2 个字节,所以 b
可以紧接着放在 (4n+2) 字节边界上,没有填充。在 b
的 2 个字节之后,我们在 4n+4 上,即再次在 4 字节边界上。这意味着我们不需要在 b
之后进行填充:我们可以立即启动该结构的另一个实例。
总而言之,我们有一个没有填充的结构(sizeof (struct A)
是其成员大小的总和,4)及其第一个成员的对齐方式,4。
struct B
{
int16_t a;
alignas(int32_t) int16_t b;
};
这里的情况不同:a
本身只强制 2 字节对齐。但是现在 b
必须在 4 字节边界上对齐,所以整个结构必须在 4 字节边界上对齐,并且在 a
之后插入 2 个字节的填充>。到目前为止,我们有 2 个字节用于 a
,2 个字节的填充,2 个字节用于 b
,这使我们到达了 (4n+6)(即 4n+2)字节边界。我们需要到达开始的状态,因此在 b
之后插入另外 2 个字节的填充以确保我们在 4 字节边界处结束。
总而言之,我们最终得到 2 + 2 字节的填充和 2 + 2 字节的内容,大小为 8。
关于C - alignas 没有给出预期的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38033406/
当 alignas 与 inline static 成员变量一起使用时,MSVC 会抛出错误,而 Clang 不会。哪一个是正确的? clang 的标志:-O2 -std=c++2a。 MSVC 的标
C11 中的 Alignas 没有像我预期的那样工作。这是我的代码: #include #include #include struct A { alignas(int32_t) int
我不习惯在互联网上发布任何问题,所以如果我做错了什么,请告诉我。 简而言之 如何在 CPU 缓存行大小为 64 字节的 64 位架构上正确防止错误共享? C++ 'alignas' 关键字和简单字节数
如何使用 malloc(或 new,因为在大多数实现中 new 是用 malloc 实现的,不确定标准对对齐的说法,而 new 除了数据必须与最高标量对齐之外)与一种类型对齐要求设置为高于系统上的最大
根据 cppreference.com 对齐说明符 (C++11 起) 指定类型或对象的对齐要求。 语法 alignas( 表达式 ) alignas( type-id ) alignas( pack
我最近了解了结构的大小和对齐方式。我非常熟悉 alignas() 说明符的使用方法和工作原理。我已经看到了正确使用的例子(关于语义,而不是现实生活中的用例)以及它改变类型/变量大小的方式。 但是,我不
我想在缓存边界上过度对齐我的类型,所以我使用了alignas: struct alignas(64) W { }; 这编译得很好。但是,令我惊讶的是,当我尝试分配一堆 W 时,它们不是 64 字节对齐
在 32 位 x86 linux 上运行以下代码时,我得到了意想不到的结果(编译器标志:g++ -std=c++14 -m32)。我试过 gcc 和 clang。 #include using na
我正在尝试使用 alignas 作为类成员的指针,坦率地说,我不确定我应该把它放在哪里。 例如: class A { private: int n; alignas(64) doubl
我很难找到有关 GCC 的 aligned-new 警告和 gcc -faligned-new 选项的更多信息。在 gcc 7.2.0 上编译(没有 --std=c++17)并尝试定义一个对齐的结构,
我正在尝试扩展对齐说明符中的参数包。我无法正确使用语法。这是一个简单的例子: #include #include template struct C { using Tuple_Type
在以下结构中: struct alignas(?) test { int32_t f1; // 4 bytes int8_t f2; // 1 byte int8_t f3;
我正在使用 gcc 4.9.2,我正在尝试正确对齐静态初始化的数组以用于 AVX。以下是由于对齐问题导致段错误的代码要点: #include #include struct B { ali
使用Eclipse配合MinGW(version:4.8.1)编译如下代码片段,可以通过,但Eclipse仍然报错:“此行有多个标记 - 无法解析类型‘alignas’” template void
在32位机器中,一个内存读取周期得到4个字节的数据。 因此,对于下方缓冲区的读取,读取下面提到的 128 个 bytes 缓冲区需要 32 个读取周期。 char buffer[128]; 现在,假设
我有一个数组,用作 T 类型对象的底层内存: char memory[sizeof T]; . . . new(memory) T(whatever); 如何确保 memory 与 T 对象正确对齐?
我的问题很简单; alignas 说明符是否与“new”一起使用?也就是说,如果定义了一个struct是对齐的,那么在分配new的时候会对齐吗? 最佳答案 在 C++17 之前,如果你的类型的对齐方式
#include using namespace std; int main() { alignas(double) unsigned char c[1024]; // array of
我现在使用共享内存。 我无法理解 alignof 和 alignas。 cppreference不清楚: alignof 返回“对齐”,但什么是“对齐”?为要对齐的下一个 block 添加的字节数?填
我无法理解 alignas 的目的是什么和 alignof关键字是,我不太确定我完全理解对齐是什么。 据我了解,如果内存地址可被 n 整除,则它与 n 字节对齐,也就是说,可以通过一次计算“n”个字节
我是一名优秀的程序员,十分优秀!