今天使用strncpy遇到了一个奇怪的现象。
在先后调用两次strncpy复制不同的内容时,第一次打印的内容的末尾同时打印出了第二次的内容。伪代码如下:
strncpy(structA.stringA, structB.stringA, sizeof(structA.stringA)-1);
strncpy(structA.stringB, structB.stringB, sizeof(structA.stringB)-1);
cout << structA.stringA << endl;
cout << structA.stringB << endl;
打印出的内容为
structB.stringAstructA.stringB
structA.stringB
进入gdb调试后发现,第一次strncpy语句执行完之后,structA.stringA中的内容还是初始化的0,而等到第二次strncpy执行完之后,structA.stringA和structA.stringB中同时有了内容。此时猜测是第一次strncpy时没有遇到structB.stringA中的结束符,所以复制的长度为structA.stringA的长度,接着复制遇到了structB.stringB的结束符,所以复制了两个string中的内容。检查后发现,确实是structB.stringA发送的string长度超出了其本身的定义,结束符没有传递过来,造成了这样的结果。
最后修改structB.stringA的长度定义即可正常输出。
语言描述或理解方面若有不当之处,欢迎指正和讨论。
`/*
strncpy底层源码
*/
char *strncpy(char *dest, const char *src, size_t count)
{