经典的4道笔试题

————经典的笔试题
————1请问运行Test 函数会有什么样的结果?
//#include<stdio.h>
//#include<stdlib.h>
//void GetMemory(char* p)//1.改为char**p,也可以不传参,将对应代码块的p改为char**p//2.void改为char*
// //p为形参(形式参数)只可作用于所属函数内部,出了函数外,就被收回。但是malloc开辟的空间并没有被释放,导致内存泄漏
//{
//    p = (char*)malloc(100);//1.改为*p
 return p;//2
//}
//void Test(void)
//{
//    char* str = NULL;
//    GetMemory(str);//改为&str//2.改为str=GetMemory(str)
//    strcpy(str, "hello world");//此时str仍为NULL,因此不可以对其进行解引用,会导致系统崩溃。
//    printf(str);
//    //还要添加释放//1.2
// // free(str);
// // str=NULL;
//}
//int main()
//{
//    Test();
//    return 0;
//}

//——改法1(不传参)
//#include<stdio.h>
//#include<stdlib.h>
//char* GetMemory()
//{
//    char* p = (char*)malloc(100);
//    return p;//2
//}
//void Test(void)
//{
//    char* str = NULL;
//    str = GetMemory();
//    strcpy(str, "hello world");
//    printf(str);
//    free(str);
//    str = NULL;
//}
//int main()
//{
//    Test();
//    return 0;
//}

//——改法2(传参采取返回p地址,并定义变量接收地址)
//#include<stdio.h>
//#include<stdlib.h>
//char* GetMemory(char*p)
//{
//    p = (char*)malloc(100);
//    return p;
//}
//void Test(void)
//{
//    char* str = NULL;
//    str = GetMemory(str);
//    strcpy(str, "hello world");
//    printf(str);
//    free(str);
//    str = NULL;
//}
//int main()
//{
//    Test();
//    return 0;
//}

//——改法3(传参,采取二级指针)
//#include<stdio.h>
//#include<stdlib.h>
//char* GetMemory(char** p)
//{
//    *p = (char*)malloc(100);
//    return p;
//}
//void Test(void)
//{
//    char* str = NULL;
//    GetMemory(&str);
//    strcpy(str, "hello world");
//    printf(str);
//    free(str);
//    str = NULL;
//}
//int main()
//{
//    Test();
//    return 0;
//}
解决办法:把开辟的空间放到str中,之后拷贝就没问题了。而开辟的地址想放到外面的str里去,
             /* 就要把str的地址传给GetMeory函数中。而char*类型的地址就应该放到char**的二级指针里面去,
              p里放的是str的地址,*p就指的是str,即函数GetMeory函数调用完之后,
              str里存放的就是动态开辟的100字节的地址*/

//————2请问运行Test 函数会有什么样的结果?
//#include<stdio.h>
//char* GetMemory()
//{
//    char* p[] = { "hello world" };//p为局部数组,当return p时,表示返回p的首元素地址,
//    //而不是p所指向的内容,即打印时并没有可打印的元素,因为结束结束GetMemory()函数时,
//    // p就不存在了,即p已经将自己的内容归还给系统。从而str中只剩下p的首元素地址,而指向那块内容就不清楚了。
//    return p;//返回栈空间地址的问题
//}
//void Test(void)
//{
//    char* str = NULL;
//    str = GetMemory();//此处的str为野指针,因为str指向的空已经不属于我们了
//    printf(str);
//}
//int main()
//{
//    Test();
//    return 0;
//}
//#include<stdio.h>
//int test()
//{
//    int a = 10;//局部变量放在栈区
//    return &a;//返回栈区空间上的地址,均为临时的,进行返回时的操作是很危险的//返回栈空间地址的问题
//}
//int main()
//{
//    int *p= Test();
//    printf("hehe");//在没有此句调用printf函数时,打印*p还有可能是10.但是此处调用printf时,
//    //就开辟了新的空间,而原始的空间就被覆盖了
//    printf("%d\n", *p);
//    return 0;
//}

//————3请问运行Test 函数会有什么样的结果?
//#include<stdio.h>
//#include<stdlib.h>
//void GetMemory(char** p, int num)
//{
//    *p = (char*)malloc(num);
//}
//void Test(void)
//{
//    char* str = NULL;
//    GetMemory(&str, 100);
//    strcpy(str, "hello");
//    printf(str);
//  //free(str);//未释放
//  //str=NULL;
//}
//int main()
//{
//    Test();
//    return 0;
//}
//————4请问运行Test 函数会有什么样的结果?
#include<stdio.h>
#include<stdlib.h>
void Test(void)
{
    char* str = (char*)malloc(100);
    strcpy(str, "hello");
    free(str);//此时只是把str申请的空间释放,但是str的内容并未改变。
    if (str != NULL)//因此此处可进入循环
    {
        strcpy(str, "world");//但是此处的str只含有内容,并没有地址(或空间),即str为野指针
        printf(str);//野指针不可以进行任何操作。
    }
    str = NULL;
}
int main()
{
    Test();
    return 0;
}
 

  • 15
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值