在实现一个简单的字符对应函数的过程中发现了这个不算是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把内存重新整理过才进行的分配,所以指针会乱。深层一点的代码我暂时没时间阅读……
做完毕业设计先……