连续内存分配

Consecutive Memory Allocation

本文关键字:分配 内存 连续      更新时间:2023-10-16

我使用以下代码来查找数组中两个连续内存块的地址之间的差异。尽管每个项目(此处为"int"(的打印大小为 4,但包含该项目的两个连续块的地址之差为 1。差不是4吗?

#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
int main() {
    int a[10];
    for(int i=0;i<10;i++)
        cin>>a[i];
    cout<<"size of 1 block = "<<sizeof(int)<<"n";
    for(int i=1;i<10;i++){
    // cout<<"Difference between address of consecutive memory blocksn";
       cout<<" "<<&(a[i])- &(a[i-1])<<"n";
    }
    return 0;
}

输出

1 块的大小 = 4

1
1
1
1
1
1
1
1 1

"差异度量"是 int s 的数量,而不是 char s – 两个 T* 类型的指针之间的差异是它们之间类型为 T 的对象的数量。

请注意,如果

int* p = &a[k];

然后

p + (&(a[i])- &(a[i-1])) == p + 1

也就是说,将两个连续元素之间的差异相加到 p 得到p + 1 ,这正是您所期望的。

您可以通过转换为整数来获取所需的值,例如 unsigned long long

cout << " " << (unsigned long long)&a[i] - (unsigned long long)&a[i-1] << "n";

强制转换为足以unsigned int 32 位系统。

如果未强制转换,则执行指针算术,结果为 1。

这是因为指针算术。&(a[i])的类型是int*,它指向可以存储int的内存块。如果将此指针逐步执行一个,它将指向下一个可以存储另一个int的内存块。这就是为什么两个int*之间的差异1的原因。

您可以通过将int*指针类型转换为char*指针类型来打印出您尝试实现的目标,然后计算差值:

cout << (reinterpret_cast<char*>(&a[i]) - reinterpret_cast<char*>(&a[i - 1]));