可重入函数与线程安全关系
来源:互联网 发布:四川麻将血战定缺算法 编辑:程序博客网 时间:2024/06/08 19:27
什么是可重入函数和不可重入函数
可重入函数
在 实时系统的设计中,经常会出现多个任务调用同一个函数的情况。如果这个函数不幸被设计成为不可重入的函数的话,那么不同任务调用这个函数时可能修改其他任 务调用这个函数的数据,从而导致不可预料的后果。那么什么是可重入函数呢?所谓可重入是指一个可以被多个任务调用的过程,任务在调用时不必担心数据是否会 出错。不可重入函数在实时系统设计中被视为不安全函数。
满足下列条件的函数多数是不可重入的:
(1)函数体内使用了静态的数据结构;
(2)函数体内调用了malloc()或者free()函数;
(3)函数体内调用了标准I/O函数。
线程安全:概念比较直观。一般说来,一个函数被称为线程安全的,当且仅当被多个并发线程反复调用时,它 会一直产生正确的结果。
可重入:概念基本没有比较正式的完整解释,但是它比线程安全要求更严格。根据经验,所谓“重入”,常见的情况是,程序执行到某个函数foo()时,收到信号,于是暂停目前正在执行的函数,转到信号处理函数,而这个信号处理函数的执行过程中,又恰恰也会进入到刚刚执行的函数foo(),这样便发生了所谓的重入。此时如果foo()能够正确的运行,而且处理完成后,之前暂停的foo()也能够正确运行,则说明它是可重入的。
线程安全的条件:
要确保函数线程安全,主要需要考虑的是线程之间的共享变量。属于同一进程的不同线程会共享进程内存空间中的全局区和堆,而私有的线程空间则主要包括栈和寄存器。因此,对于同一进程的不同线程来说,每个线程的局部变量都是私有的,而全局变量、局部静态变量、分配于堆的变量都是共享的。在对这些共享变量进行访问时,如果要保证线程安全,则必须通过加锁的方式。
可重入的判断条件:
要确保函数可重入,需满足一下几个条件:
1、不在函数内部使用静态或全局数据
2、不返回静态或全局数据,所有数据都由函数的调用者提供。
3、使用本地数据,或者通过制作全局数据的本地拷贝来保护全局数据。
4、不调用不可重入函数。
可重入与线程安全并不等同,一般说来,可重入的函数一定是线程安全的,但反过来不一定成立。
如果我们的线程函数不是线程安全的,那在多线程调用的情况下,可能导致的后果是显而易见的——共享变量的值由于不同线程的访问,可能发生不可预料的变化,进而导致程序的错误,甚至崩溃。
- 线程安全与可重入函数的关系
- 可重入函数与线程安全关系
- 线程安全与可重入的关系
- 线程安全与可重入的关系
- 线程安全与可重入函数
- 线程安全与可重入函数
- 可重入函数与线程安全
- 可重入函数与线程安全
- 线程安全与可重入函数
- 可重入函数与线程安全
- 可重入函数与线程安全
- 可重入函数与线程安全
- 可重入函数与线程安全
- 线程安全与可重入函数
- 线程安全与可重入函数
- 线程安全与可重入函数
- 线程安全与可重入函数
- 可重入函数与线程安全
- VMware Workstation虚拟机中安装CentOS7
- 性能优化之Java(Android)代码优化
- okular的设计和后端
- 8255做流水灯实验
- ECharts
- 可重入函数与线程安全关系
- ubuntu 下用anaconda 安装tensorflow,并配置vscode用来写代码
- 利用manifest文件或资源文件让程序以管理员身份运行
- DAO
- tomcat发布项目绑定域名总结
- IntelliJ IDEA平台里面的修改----字体修改
- 数据持久化
- DAO模式
- Linux命令指南之一