• C语言块内变量回收问题


    之前有一个错误认识,错误的认为局部变量的回收是发生在函数返回时。其实在块结束时块内使用的内容就会被回收了。

    以下的实例说明了问题

    int * p[2];
    for (int i = 0; i < 2; ++i)
    {
        int item = i;
        p[i] = &item;
    }
    printf("p[0]=%p p[1]=%p
    ", p[0],p[1]);
    printf("*p[0]=%d *p[1]=%d
    ", *p[0],*p[1]);

    某次的输出(具体的内存地址会有不同,但是依然会发现p[0]与p[1]指向了同一个地方)

    p[0]=000000000023FE2C p[1]=000000000023FE2C
    *p[0]=1 *p[1]=1

    这个问题的发现过程是使用struct时懒得手动释放内存,就试图将其都放在栈中,想等函数退出时令其自动回收。结果在for块中定义的变量会不断被回收,所有的都在同一个地址处。被struct封装一下,问题会更具有迷惑性。

    typedef struct{
        int item;
    }Node;
    
    int main(int argc, char const *argv[])
    {
        Node * p[2];
        for (int i = 0; i < 2; ++i)
        {
            Node node;
            node.item = i;
            p[i] = &node;
        }
        printf("p[0]=%p p[1]=%p
    ", p[0],p[1]);
        printf("p[0]->item=%d p[1]->item=%d
    ", p[0]->item,p[1]->item);
    }


    输出如下

    p[0]=000000000023FE20 p[1]=000000000023FE20
    p[0]->item=1 p[1]->item=1
  • 相关阅读:
    文件系统
    Java的日志模块
    SQL Server 的索引结构实例
    SQL索引优化
    索引最佳实践
    SQL优化基础 使用索引(一个小例子)
    v使用索引的注意事项及常见场景、案例
    使用索引的注意事项及常见场景、案例
    SQL性能优化十条经验
    如何使用JVisualVM进行性能分析
  • 原文地址:https://www.cnblogs.com/atskyline/p/3535131.html
Copyright © 2020-2023  润新知