软中断和多线程均可能导致函数重入,有必要讨论一下不可重入函数。
不可重入(non-reentrant)函数不能由超过一个任务所共享,除非能确保函数的互斥(或者使用信号量,或者在代码的关键部分禁用中断)。
比如:
函数中调用了不可重入函数;
函数体内使用了静态的数据结构;
函数体内调用了malloc()或者free()函数;
函数体内调用了其他标准I/O函数;
函数是singleton中的成员函数而且使用了不使用线程独立存储的成员变量 。
总的来说,如果一个函数在重入条件下使用了未受保护的共享的资源,那么它是不可重入的。
举几个例子如下:
/*****example 1*****/
static int tmp;
//函数func1不具有可重入性
void func1(int* x, int* y) {
tmp=*x;
*x=*y;
*y=tmp;
}
//函数func2具有可重入性
void func2(int* x, int* y) {
int tmp;
tmp=*x;
*x=*y;
*y=tmp;
}
/*****example 2*****/
int Exam;
//函数func3不具有可重入性
unsigned int func3( int para )
{
unsigned int temp;
Exam = para;
temp = Square_Exam( );
return temp;
}
//函数func4具有可重入性
unsigned int func4( int para )
{
unsigned int temp;
[申请信号量操作] // 若申请不到“信号量”,说明另外的进程正处于
Exam = para; // 给Exam赋值并计算其平方过程中(即正在使用此
temp = Square_Exam( ); // 信号),本进程必须等待其释放信号后,才可继
[释放信号量操作] // 续执行。若申请到信号,则可继续执行,但其
// 它进程必须等待本进程释放信号量后,才能再使
// 用本信号。
return temp;
}
近来很多提供商已经开始提供标准 C 程序库的可重入版本,这是一个好消息。
文章评论(0条评论)
登录后参与讨论