我们常常使用一些库函数,很好用,Very nice. 通常这个时候我们就会懈怠,以为是标准了就不会有问题了。
对此,要说不。我的同事给了我一个example – asctime:
我们要深入源码去追查。在asctime.c这个文件中存在着这个函数的实现。
static _TSCHAR buf[_ASCBUFSIZE]; 这就是那个静态存储区,也就是说返回值是在这个里面的,多线程访问?Game over!
所以需要总结一个经验教训。对于返回值为指针的函数,我们要尤为小心。因为我们要先知道,这个指针指向的是什么地方?如果这个地方是Caller提供的私有空间,OK,这是可控的。如果是库函数提供的Space,那就要注意了,因为很可能是共享的空间,那么多线程程序,您自己保证吧。