今天我参加一个面试,面试中有下面的一道题.
#include <stdio.h>
#include <stdlib.h>
#include<string.h>
void get_memory(char *p){
p = (char *)malloc(100);
}
int main(void) {
char *str = NULL;
get_memory(str);
strcpy(str,"hello,world");
printf("%s\n",str);
return EXIT_SUCCESS;
}
面试时,面试官让我做3道题其中这一题我做错了.
我答了输出"hello,world"了.
当时我没有想通.现在我回到实验室,自己调试了一下.
调试过程如下:
在get_memory(str);中.str传递的是0x00过去.
.然后.p的值也是0x00.
这个肯定不成功,我以为是因为str初始化为NULL才这样的.
但是.当我给str初始化有东西时.如下:
int get_memory(char *p){
p = (char *)malloc(100);
return 0;
}
int main(void) {
char *str = "a";
get_memory(str);
strcpy(str,"hello,world");
printf("%s\n",str);
return EXIT_SUCCESS;
}
/*** 在eclipse中调试时一些变量 的值:
语句:char *str = "a";
执行前:
Name : str
Details:0x28bff4 "|\\315\\025"
Default:0x28bff4 "|\315\025"
Decimal:2670580
Hex:0x28bff4
Binary:1010001011111111110100
Octal:012137764
执行后:
Name : str
Details:0x8048c0f "a"
Default:0x8048c0f "a"
Decimal:134515727
Hex:0x8048c0f
Binary:1000000001001000110000001111
Octal:01001106017
语句 :p = (char *)malloc(100);
执行前:
Name : p
Details:0x8048c0f "a"
Default:0x8048c0f "a"
Decimal:134515727
Hex:0x8048c0f
Binary:1000000001001000110000001111
Octal:01001106017
执行后:
Name : p
Details:0x8048c0f "a"
Default:0x8048c0f "a"
Decimal:134515727
Hex:0x8048c0f
Binary:1000000001001000110000001111
Octal:01001106017
分析 char *p = (char *)malloc(100);语句时发现,malloc的调用对于p好像没有什么直接的影响.
我们换成在main函数中对str直接调用malloc试下,如下:
/**
str = (char *)malloc(100);
调用前:
Name : str
Details:0x8048c0f "a"
Default:0x8048c0f "a"
Decimal:134515727
Hex:0x8048c0f
Binary:1000000001001000110000001111
Octal:01001106017
调用之后:
Name : str
Details:0x804b008 ""
Default:0x804b008 ""
Decimal:134524936
Hex:0x804b008
Binary:1000000001001011000000001000
Octal:01001130010
**/
这是一个问题.为什么在参数中声明的char *p.在调用了malloc函数之后却没有反应呢?
面试的过程中,我还被问到一个问题,就是堆和栈的区别.
分享到:
相关推荐
6. 已经至少答对一题,意味着第一题答对的概率是1,第二题答对的概率是3/4(因为不能两题都错)。两题都对的概率是1×3/4=3/4。答案:A. 1/3。 7. 题目描述的是层次遍历二叉树,从根节点开始,按照FIFO(先进先出)...
少儿编程scratch项目源代码文件案例素材-直升机飞行.zip
wanjunshe_Python-Tensorflow_12888_1745868924470
健康监测_Android开发_BLE蓝牙通信_心率数据采集与存储_基于小米手环2的实时心率监测应用_支持后台长时间运行的心率记录工具_可导出SQLite数据库的心率数据分析系统_适
少儿编程scratch项目源代码文件案例素材-种花模拟器.zip
嵌入式系统开发_FreeRTOS实时操作系统_STM32F103C8T6微控制器_OLED显示屏_DHT11温湿度传感器_多任务调度_多级菜单设计_万年历算法_电子闹钟功能_参数配
基于python实现的粒子群的VRP(车辆配送路径规划)问题建模求解+源码+项目文档+算法解析,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用,详情见md文档 算法设计的关键在于如何向表现较好的个体学习,标准粒子群算法引入惯性因子w、自我认知因子c1、社会认知因子c2分别作为自身、当代最优解和历史最优解的权重,指导粒子速度和位置的更新,这在求解函数极值问题时比较容易实现,而在VRP问题上,速度位置的更新则难以直接采用加权的方式进行,一个常见的方法是采用基于遗传算法交叉算子的混合型粒子群算法进行求解,这里采用顺序交叉算子,对惯性因子w、自我认知因子c1、社会认知因子c2则以w/(w+c1+c2),c1/(w+c1+c2),c2/(w+c1+c2)的概率接受粒子本身、当前最优解、全局最优解交叉的父代之一(即按概率选择其中一个作为父代,不加权)。 算法设计的关键在于如何向表现较好的个体学习,标准粒子群算法引入惯性因子w、自我认知因子c1、社会认知因子c2分别作为自身、当代最优解和历史最优解的权重,指导粒子速度和位置的更新,这在求解函数极值问题时比较容易实现,而在VRP问题上,速度位置的更新则难以直接采用加权的方式进行,一个常见的方法是采用基于遗传算法交叉算子的混合型粒子群算法进行求解,这里采用顺序交叉算子,对惯性因子w、自我认知因子c1、社会认知因子c2则以w/(w+c1+c2),c1/(w+c1+c2),c2/(w+c1+c2)的概率接受粒子本身、当前最优解、全局最优解交叉的父代之一(即按概率选择其中一个作为父代,不加权)。
scratch少儿编程逻辑思维游戏源码-猫猫粉碎.zip
scratch少儿编程逻辑思维游戏源码-蓝胡子.zip
scratch少儿编程逻辑思维游戏源码-美食大亨.zip
scratch少儿编程逻辑思维游戏源码-洛克人.zip
scratch少儿编程逻辑思维游戏源码-龙冲刺.zip
思幻个人引导页V2.2版本11月29日更新.zip
scratch少儿编程逻辑思维游戏源码-骑士风斩法.zip
移动应用开发_H5CSS3ionicng-cordovaMVVM模式_基于HTML5和CSS3技术实现多页面布局ionic指令数据绑定ui-route单页跳转调用手机
少儿编程scratch项目源代码文件案例素材-植物大战僵尸创造版 Ver. 1.0.3.zip
scratch少儿编程逻辑思维游戏源码-日落(2).zip
动态星空背景个人主页(带后台).zip
scratch少儿编程逻辑思维游戏源码-迷雾森林:诞生 3.2 起源觉醒.zip