线程安全:多个线程访问同一个区域的时候其最终结果是可预期的,并不会因为产生冲突或者异常中断再次恢复而使结果不可预期


1.重入:函数被不同的控制流程调用,有可能在第一次调用还没有返回的时候就再次进入该函数这称之为 重入;

2.不可重入函数:当访问一个全局的变量或者参数的时候,有可能因为重入造成错乱,像这样的函数称之为不可重入函数

如果一个函数符合以下条件之一则是不可重入的

(1)调用了malloc/free,因为malloc是用全局链表来管理堆的

(2)调用了标准I/O卡函数,biaozhun I/O库函数很多实现都以不可重入的方式使用全局数据结构


3.可重入函数:如果一个函数只访问自己的局部变量或参数,则称之为可重入函数

可重入函数可以被一个以上的任务调用,而不必担心数据会破坏,可重入函数任何时候都可以被中断,一段时间以后又可以运行,而相应的数据不会丢失;可重入函数或者只使用局部变量,即保存在寄存器或堆栈中,或者使用全局变量,则要对全局变量给予保护

4.可重入函数与线程安全的区别与联系


(1)线程安全是在多个线程情况下引发的,而可重入函数可以在只有一个线程的情况下来说;

(2)线程安全一定是不可重入的,可重入函数一定是线程安全的

(3)如果一个函数中有全局变量,那么这个函数既不是线程安全的也不是可重入的

(4)如果将对临界 资源的访问加上锁,则这个函数是线程安全的

(5)如果一个函数当中的数据全是自身栈空间的,那么这个函数即是线程安全的又是可重入的

(6)线程安全函数能够使不同的线程访问同一块地址空间,而可重入函数要求不同的执行流对数据的操作互不影响使结果是相同的