可重入函数与不可重入函数

可重入函数与不可重入函数不可重入函数:(a)已知它们使用静态数据结构(b)它们调用malloc或free(c)它们是标准I/O函数。标准I/O库的很多实现都以不可重入方式使用全局数据结构。因为每个线程只有一个errno变量,所以我们可能修改了其原先的值。考虑一个信号处理程序,它恰好在main刚设置errno之后被调用。如果该信号处理程序调用rea

不可重入函数:
( a )已知它们使用静态数据结构
( b )它们调用m a l l o c或f r e e
( c )它们是标准I / O函数。标准I / O库的很多实现都以不可重入方式使用全局数据结构。

因为每个线程只有一个e r r n o变量,所以我们可能修改了其原先的值。考虑一个信号处理程序,它恰好在 m a i n刚设置e r r n o之后被调用。如果该信号处理程序调用r e a d,则它可能更改e r r n o的值,从而取代了刚由m a i n设置的值。
因此,作为一个通用的规则,当在信号处理程序中调用不可重入函数时,应当在其前保存,在其后恢复e r r n o。 (要了解经常被捕捉到的信号是 S I G C H L D,其信号处理程序通常要调用一种w a i t函数,而各种w a i t函数都能改变e r r n o)

今天的文章可重入函数与不可重入函数分享到此就结束了,感谢您的阅读。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/9981.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注