《从缺陷中学习C/C++》——6.5 变量的作用域

本节书摘来自异步社区出版社《从缺陷中学习C/C++》一书中的第6章,第6.5节,作者: 刘新浙 , 刘玲 , 王超 , 李敬娜 , ,更多章节内容可以访问云栖社区“异步社区”公众号查看。

6.5 变量的作用域

从缺陷中学习C/C++
代码示例

char *str = NULL;
    if(!str) {
        char * str = (char*) malloc (100);
        if(!str) {
            return -1;
        }
        str[0] = 'a';
    }
printf("%c\n", str[0]);

现象&结果
程序执行时出现coredump。

Bug分析
程序出现coredump的原因是代码printf("%cn",str[0])中使用的str是空指针。程序首行定义了指针str,并且赋值为NULL。然后在if(!str){}语句块中,通过代码行char str = (char) malloc (100),重新定义了str指针,并且为str指针分配了内存空间。根据变量的作用域规则,char str = (char) malloc (100) 这行代码定义的局部变量str,有效范围是在if(!str){}语句块中。代码最后部分printf("%cn",str[0]) ,在if(!str){}语句块范围之外,此处使用的str不是在if(!str){}语句块中经过malloc分配过内存的指针str,而是程序首行定义的char *str = NULL;此时str为NULL,所以访问str[0]出现coredump

正确代码

char *str = NULL;
    if(!str) {
        str = (char*) malloc (100);
        if(!str) {
            return -1;
        }
        str[0] = 'a';
    }
printf("%c\n", str[0]);

本文仅用于学习和交流目的,不代表异步社区观点。非商业转载请注明作译者、出处,并保留本文的原始链接。

上一篇:$utils使用全指南----持续更新


下一篇:封装多线程处理大量数据操作