• Python与C储存方式的区别


    在Alex视频课程中得知Python中:

    a=2

    b=a

    a=3

    该过程中的内存储存方式为:

    1、先再内存中开栈存储2这个数据的空间

    2、a指向数据为2的内存空间地址

    3、b=a 此时b指向2的内存空间的地址

    4、a=3 内存中开栈存储3这个数据的空间

    5、此时a=3中,a重新指向数据为3的内存地址

    总结:Python是动态语言,变量只是对象的引用

    并在VC中作简单的测试

    int i=1;
    int y=i;
    i=2;

    在调试过程中得知

    int i=1;            mov     dword ptr [ebp-4],1    //可以看出 当i=1赋值时候,在内存开栈,把1存入相应地址中

    int y=i;            mov      eax,dword ptr [ebp-4]    //此时先把内存地址中的数据赋值给累加器eax

                          mov      dword ptr [ebp-8],eax    //再把累加器中的数据赋值给y的地址中

    i=2;                mov      dword ptr [ebp-4],2        //当i=2重新赋值的时候,就把2赋值给i原来的地址中

    后来通过网上查阅得知

    因为动态语言Python不同于静态语言C,其变量只是对象的引用

    这其实是十分基本的问题,通过查阅Python的解释器的工作原理知道原因。只是第一次接触动态语言,还不是很熟悉。但是对于原理性的东西不妨先放到学完基本Python后再次研究,这对学习的效率会提高更多。

  • 相关阅读:
    Struts2的OGNL的用法
    详解DataTable DataSet以及与数据库的关系
    ModBus 协议
    STM32串口接收中断溢出问题解决
    STM32 GD32 时钟设置
    STM32 中断
    STM32 中断系统
    STM32中断系统(NVIC和EXTI)
    STM32中断系统
    GD32E230 GPIO 时钟
  • 原文地址:https://www.cnblogs.com/jasonsou/p/7599420.html
Copyright © 2020-2023  润新知