c/c++操作访问数据,是堆中的数据快还是栈中的数据快

  这里的问题其实问的是对堆与栈的数据访问有什么不同。

  观察如下代码:

c/c++操作访问数据,是堆中的数据快还是栈中的数据快
#include<stdio.h>
#include<iostream>
using namespace std;

int main(){
    int a;
    int *pb=(int*)malloc(sizeof(int));

    a=1234;
    *pb=123456;

    return 0;
}
c/c++操作访问数据,是堆中的数据快还是栈中的数据快

  在观察汇编的情况:

  c/c++操作访问数据,是堆中的数据快还是栈中的数据快

  明显观察到,对栈数据赋值,直接将数据放到目标地址。而堆中的数据,先把pb的值放到寄存器中,再把值放到寄存器所指向的地址。

  总结:对与堆内存的访问比栈内存的访问多一个步骤。

c/c++操作访问数据,是堆中的数据快还是栈中的数据快

上一篇:【Python实战09】使用python进行数据的排序


下一篇:转载(sublime text 2 调试python时结果空白)