可重入函数
如果一个函数被多个执行流调用,有可能在第一次调用还没有返回时,再次进入这个函数,这称为重入。如果这个函数访问了全局变量或静态变量,造成结果错乱,这个函数叫不可重入函数,反之,则称为可重入变量。
可重入函数书写遵循如下原则:
1、不在函数内部使用静态或全局数据
2、不返回静态或全局数据,所有数据都由函数的调用者提供。
3、使用本地数据,或者通过制作全局数据的本地拷贝来保护全局数据。
4、如果必须访问全局变量,利用互斥机制来保护全局变量。
5、不调用不可重入函数
线程安全:
是指一个函数被多个线程同时运行,运行出的结果和一个线程运行时的结果一样且是正确的。若每个线程中对全局变量、静态变量只有读操作,而无写操作,一般来说,这个全局变量是线程安全的;若有多个线程同时执行写操作,一般都需要考虑线程同步,否则就可能影响线程安全。 线程安全就是多线程访问时,采用了加锁机制,当一个线程访问该类的某个数据时,进行保护,其他线程不能进行访问直到该线程读取完,其他线程才可使用。不会出现数据不一致或者数据污染。 线程不安全就是不提供数据访问保护,有可能出现多个线程先后更改数据造成所得到的数据是脏数据。
两者区别与联系:
1、可重入函数是线程安全函数的一种,其特点在于它们被多个线程调用时,不会引用任何共享数据。
2、线程安全是在多个线程情况下引发的,而可重入函数可以在只有一个线程的情况下来说。
3、线程安全不一定是可重入的,而可重入函数则一定是线程安全的。
4、如果一个函数中有全局变量,那么这个函数既不是线程安全也不是可重入的。
5.如果将对临界资源的访问加上锁,则这个函数是线程安全的,但如果这个重入函数若锁还未释放则会产生死锁,因此是不可重入的。
6、线程安全函数能够使不同的线程访问同一块地址空间,而可重入函数要求不同的执行流对数据的操作互不影响使结果是相同的。
转载于:https://blog.51cto.com/10810512/1830742