-
localtime
localtime返回一个指向静态变量的指针,这样是线程不安全的,使用localtime_r代替
-
STL中的容器类
STL容器只保证线程读安全,不保证线程写安全
-
strtok
应用函数初次调用strtok时传递一个字串的地址,比如”aaa.bbb.dddd”,并将字串的地址保存在自己的静态变量中,当你将来再次调用strtok并传递NULL时(strtok的特殊用法,第二次调用时字串传NULL表示对第一次传进去的字串继续分隔,所以要先保存字串地址,这是有点怪异的实现),该函数就会引用保存好的字串地址。在多线程环境下,另一个线程也可能调用strtok,在这种环境下,另一个线程会在第一个线程不知道的情况下替换静态变量中的字串地址,这就会导致各种难以排除的错误出现。
-
asctime()
-
basename()
-
catgets()
-
crypt()
-
ctermid()//if passed a non-NULL argument
-
ctime()
-
dbm_clearerr()
-
dbm_close()
-
dbm_delete()
-
dbm_error()
-
dbm_fetch()
-
dbm_firstkey()
-
dbm_nextkey()
-
dbm_open()
-
dbm_store()
-
dirname()
-
dlerror()
-
drand48()
-
ecvt()//[POSIX.1-2001 only (function removed in POSIX.1-2008)]
-
encrypt()
-
endgrent()
-
endpwent()
-
endutxent()
-
fcvt()//[POSIX.1-2001 only (function removed in POSIX.1-2008)]
-
ftw()
-
gcvt()//[POSIX.1-2001 only (function removed in POSIX.1-2008)]
-
getc_unlocked()
-
getchar_unlocked()
-
getdate()
-
getenv()
genevn的实现原理为:
进程应当维护着一个全局变量 char **environ,用来指向每一条环境变量的字符串,同时在原本的getenv的实现里,还应当维护着一个全局的字符串的缓冲区(暂且命名为envbuf),当线程调用getenv()时,系统找到对应的环境变量的字符串,拷贝到全局缓冲区envbuf中,再通过getenv()函数返回给调用者。
如果多个线程同时调用getenv()的话,可能就会出现对envbuf的异步访问,造成返回错误结果
-
getgrent()
-
getgrgid()
-
getgrnam()
-
gethostbyaddr()//[POSIX.1-2001 only (function removed in POSIX.1-2008)]
-
gethostbyname()//[POSIX.1-2001 only (function removed in POSIX.1-2008)]
-
gethostent()
-
getlogin()
-
getnetbyaddr()
-
getnetbyname()
-
getnetent()
-
getopt()
-
getprotobyname()
-
getprotobynumber()
-
getprotoent()
-
getpwent()
-
getpwnam()
-
getpwuid()
-
getservbyname()
-
getservbyport()
-
getservent()
-
getutxent()
-
getutxid()
-
getutxline()
-
gmtime()
-
hcreate()
-
hdestroy()
-
hsearch()
-
inet_ntoa()
-
l64a()
-
lgamma()
-
lgammaf()
-
lgammal()
-
localeconv()
-
localtime()
-
lrand48()
-
mrand48()
-
nftw()
-
nl_langinfo()
-
ptsname()
-
putc_unlocked()
-
putchar_unlocked()
-
putenv()
-
pututxline()
-
rand()
-
readdir()
-
setenv()
-
setgrent()
-
setkey()
-
setpwent()
-
setutxent()
-
strerror()
-
strsignal()//[Added in POSIX.1-2008]
-
system()//[Added in POSIX.1-2008]
system()中会调用fork()产生一个子进程,注意是进程;程序中所有的线程好像都被复制。。
这样,貌似不能在多线程环境中使用system()
-
tmpnam()//if passed a non-NULL argument
-
ttyname()
-
unsetenv()
-
wcrtomb()//if its final argument is NULL
-
wcsrtombs()//if its final argument is NULL
-
wcstombs()
-
wctomb()
-
参考文档:http://www.ccvita.com/506.html
-
结论:没什么事别用多线程,一不留神,死都不知道怎么死的..