分析四道内存题

关于内存的4个经典题目GetMomery
void GetMemory(char *p)
{
    p = (char *)malloc(100);
}

void Test(void) 
{
    char *str = NULL;
    GetMemory(str); 
    strcpy(str, "hello world");
    printf(str);
}
请问运行Test函数会有什么样的结果?
答:程序崩溃。
因为GetMemory并不能传递动态内存,
Test
函数中的 str一直都是 NULL
strcpy(str, "hello world");
将使程序崩溃。
说的简单一些,就是传入的就是一个空指针,p确实分配空间了,
但是生成的空间首地址没有返回给str

2:
char *GetMemory(void)

    char p[] = "hello world";
    return p;
}
void Test(void)
{
    char *str = NULL;
    str = GetMemory(); 
    printf(str);
}
请问运行Test函数会有什么样的结果?

答:可能是乱码。
因为GetMemory返回的是指向"栈内存"的指针,该指针的地址不是 NULL,但其原现的内容已经被清除,新内容不可知。
说的简单一些,就是函数的局部变量释放了。
3:
void GetMemory2(char **p, int num)
{
    *p = (char *)malloc(num);
}
void Test(void)
{
    char *str = NULL;
    GetMemory(&str, 100);
    strcpy(str, "hello"); 
    printf(str); 
}
请问运行Test函数会有什么样的结果?
答:
1)能够输出hello
2)内存泄漏

说的简单一些,就是没有释放malloc的空间

4:
void Test(void)
{
    char *str = (char *) malloc(100);
    strcpy(str, "hello");
    free(str); 
    if(str != NULL)
{
            strcpy(str, "world"); 
            printf(str);
}
}
请问运行Test函数会有什么样的结果?
答:篡改动态内存区的内容,后果难以预料,非常危险。
因为free(str);之后,str成为野指针,
if(str != NULL)
语句不起作用。
说的简单一些,就是只收回内存,没有用str=NULL收回指针

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
嵌入式开发中,内存泄露是一个常见的面试内存泄露指的是在程序中动态分配的内存未能被正确释放,导致这部分内存无法再次使用,最终造成内存的浪费和程序性能问。 在面试中,你可能会被问及如何检测和解决内存泄露问。以下是一些常见的方法和技巧: 1. 使用静态代码分析工具:静态代码分析工具可以扫描代码并检查潜在的内存泄露问。例如,Cppcheck、Coverity等工具可以帮助你找出潜在的内存泄露缺陷。 2. 注意动态内存分配和释放:在使用动态内存分配函数(如malloc)时,务必记得在不再使用内存时进行释放(如free)。确保每次分配都有相应的释放操作,防止内存泄露。 3. 使用编译器/工具提供的内存管理功能:一些编译器和开发环境提供了内存管理功能,例如GCC的-Malloc、FreeRTOS中的Heap4等。这些功能可以帮助你跟踪和管理动态内存分配和释放操作。 4. 尽量避免使用动态内存分配:在嵌入式开发中,动态内存分配可能会增加复杂性和风险。尽量使用静态分配或者使用固定大小的内存池来避免动态内存分配。 5. 编写测试用例:编写针对内存管理的测试用例,覆盖各种分配和释放场景。通过测试用例可以帮助你发现潜在的内存泄露问。 以上是一些常见的方法和技巧,希望对你在面试中回答该问有所帮助。在实际开发中,密切关注内存的分配和释放,以及合理使用内存管理工具是避免内存泄露问的关键。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值