原创 函数的可重入性

2009-10-12 21:34 3026 8 8 分类: 软件与OS

若一个程序子程序可以安全地被并行执行,则称其为可重入(reentrantre-entrant)的;即当该子程序正在运行时,可以再次进入并执行它。若一个函数是可重入的,则该函数:


(1) 不能含有静态(全局)非常量数据。


(2) 不能返回静态(全局)非常量数据的地址。


(3) 只能处理由调用者提供的数据。


(4) 不能依赖于单实例模式资源的锁。


(5) 不能调用不可重入的函数。


多用户/对象/进程优先级一般会使得对可重入代码的控制变得复杂。同时,IO代码通常不是可重入的,因为它们依赖于像磁盘这样共享的、单独的资源。


在以下的C语言代码中,函数f和函数g都不是可重入的。


int g_var = 1;


      


int f()


{


             g_var = g_var + 2;


             return g_var;


}


      


int g()


{


      return f() + 2;


}


以上代码中,f使用了全局变量 g_var,所以,如果两个线程同时执行它并访问g_var,则返回的结果取决于执行的时间,因此,f不可重入。而g调用了f,所以它也不可重入。


稍作修改后,两个函数都是可重入的:


int f(int i)


{


             return i + 2;


}


      


int g(int i)


{


             return f(i) + 2;


}

文章评论0条评论)

登录后参与讨论
我要评论
0
8
关闭 站长推荐上一条 /2 下一条