六狼论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博账号登陆

只需一步,快速开始

搜索
查看: 26|回复: 0

malloc函数引起的意外错误

[复制链接]

升级  85.33%

50

主题

50

主题

50

主题

秀才

Rank: 2

积分
178
 楼主| 发表于 2013-1-26 12:29:39 | 显示全部楼层 |阅读模式
在实现一个简单的字符对应函数的过程中发现了这个不算是BUG的错误:
这个错误出现的前提是这样的:
 
Main函数如下:
 
int main(int argc, char **argv){int num = 4;char *nodeName=NULL;nodeName = getNodeName(num);printf("\n\nnodeName is:\n%s\n\n",nodeName);char *aliasVal = (char *)malloc(10);getAliasVal(aliasVal, num);printf("\n\nnodeName is:\n%s\n\n",nodeName); //不能在这里输出nodeName,exit(0);}  
getNodeName函数:
 
char *getNodeName(int num){printf("\n\ntest num:%d\n\n",num);/*char *nodeName=NULL;*/char *nodeName = (char *)malloc(10);// 生成节点名switch (num){case 1:nodeName = "port1";printf("\n\nin the switch:%s\n\n",nodeName);break;case 2:nodeName = "port2";break;case 3:nodeName = "port3";break;case 4:nodeName = "port4";printf("\n\nin the switch:%s\n\n",nodeName);break;case 5:nodeName = "port5";break;case 6:nodeName = "port6";break;case 7:nodeName = "port7";break;case 8:nodeName = "port8";break;}printf("\n\nOUT OF the switch:%s\n\n",nodeName);return nodeName;} 
getAliasVal函数
 
char *getAliasVal(char *aliasVal, int num){char b[1];int tmp = num - 1;if (tmp == 0){strcpy(aliasVal, "ttyM0");}else{// 整数转字符串,方便拼接itoa(tmp, b);// 生成alias属性的值/*char *aliasVal = (char *)malloc(10);*/strcpy(aliasVal, "ttyM");strcat(aliasVal, b);}printf("\n\nresult:\n%s\n\n",aliasVal);return aliasVal;} 
 
错误产生在main函数的第9行那段,
该段代码不能正确产生输出,而前一句(第6行)是可以正确输出的,具有可重复性。
在getNodeName中nodeName也都能正确输出。
 
起初是怀疑nodeName指针出的问题,
但是用GDB进行简单的调试之后,发现nodeName指针并没有错误。
 
于是定位到malloc()函数这里,
因为malloc()函数之前可以正确输出,而malloc()之后就乱了,而且每次执行的结果都不一样。(指针的地址每次不一样。)
 
解决办法目前我只想到取消使用malloc()函数,我推测的原因是malloc把内存重新整理过才进行的分配,所以指针会乱。深层一点的代码我暂时没时间阅读……
做完毕业设计先……
您需要登录后才可以回帖 登录 | 立即注册 新浪微博账号登陆

本版积分规则

快速回复 返回顶部 返回列表