1

我一直无法为此找到答案。我在 C 中使用哪种方法有关系吗?

int get_int(void *vptr) {
    return *(int *)vptr;
}

或者

int get_int(void *vptr) {
    int i = 0;
    memcpy(&i, vptr, sizeof(int));
    return i;
}

它似乎在我的测试中给出了相同的结果,但在每种情况下都是等价的吗?

4

3 回答 3

2

主要区别在于 memcpy 将在更多情况下工作——它只要求从中复制的内存包含适当类型的数据。cast-and-dereference 要求并且还要求指针对于访问该类型是有效的。在大多数机器上,这(只是)需要正确对齐。强制转换还允许编译器假定它不使用不同类型的值进行别名。

最终结果是 memcpy 可能“更安全”,但也可能更昂贵。

于 2021-10-24T02:36:10.933 回答
0

但这在每种情况下都等效吗?

不。

*(int *)vptr依赖int对齐。如果vptr不指向int分配的数据,则结果为 UB。

memcpy()没有比要求。只要数据不是一些陷阱(罕见),它就“有效”。

于 2021-10-24T02:55:47.707 回答
-1

,它不是等价的,因为不管你信不信,并非所有指针在所有情况下都是相同的(尽管在 x86+ 架构上它们是相同的)。

然而,演员表将在它定义的地方工作。

于 2021-10-24T02:19:33.700 回答