您现在的位置是:主页 > news > 房地产家居网络平台/关键词排名优化如何
房地产家居网络平台/关键词排名优化如何
admin2025/5/11 14:30:17【news】
简介房地产家居网络平台,关键词排名优化如何,WordPress评论博主,微信公众号内嵌网站开发可重入函数可以做这样的基本定义:重入意味着这个函数可以重复进入,可以被并行调用,可以被中断,它只使用自身栈上的数据变量,它不依赖于任务环境,在多任务调度过程中,它是安全的,不必…
房地产家居网络平台,关键词排名优化如何,WordPress评论博主,微信公众号内嵌网站开发可重入函数可以做这样的基本定义:重入意味着这个函数可以重复进入,可以被并行调用,可以被中断,它只使用自身栈上的数据变量,它不依赖于任务环境,在多任务调度过程中,它是安全的,不必…
可重入函数可以做这样的基本定义:重入意味着这个函数可以重复进入,可以被并行调用,可以被中断,它只使用自身栈上的数据变量,它不依赖于任务环境,在多任务调度过程中,它是安全的,不必担心数据出错。
不可重入函数基本上与可重入函数有相反的定义了:不可重入,意味着不可被并行调度,否则会产生不可预料的结果,这些函数提内一般使用了静态(static)的数据结构,使用了malloc()或者free()函数,使用了标准I/O函数等等。
在多任务环境中或者实时系统设计中,应该尽可能的使用可重入函数,例如下面的函数:
int count_apple(int *package,int n)
{
int temp = 0;
int i;
if(package == NULL)
exit(1);
for(i = 0;i
该函数功能是计算不同篮子里的苹果数,函数体内没有访问全局变量,不使用静态局部变量,只使用局部变量,所以这个函数具有可重入的,如果必须使用全局变量,那么为了保证函数的安全,必须利用互斥信号量或者中断机制来保护全局变量。例如下面函数:
int *package;
int count_apple(int n)
{
int temp = 0;
int i;
P操作(申请信号量);
if(package == NULL)
{
V操作(释放信号量);
exit(1)
}
for(i = 0; i
temp += *(package++);
V操作(释放信号量);
return temp;
}
象上面的PV操作机制就可以让可重入函数安全的使用全局变量了,而且保证了可并行性。
不可重入函数,例如:
static int sum = 0;
int cout_pear(int *package,int n)
{
int i;
for(i = 0; i
sum += *(package ++); //(1)
return sum;
}
这个函数由于使用了静态全局变量,对sum的并行性操作结果是未知的,是不安全的操做。若此函数被多个进程调用的话,结果是未知的。因为,但语句(1)执行完一次或者几次后,另外使用这个sum的函数可能正好被调度,并得到运行机会,那么这个新运行的函数将使sum变成了另外的值,所以当(1)重新获得运行机会时,sum的值已经变成了另外的值,这是不可预料的结果。
也可以这样总结,在任务系统中要进行并行操作,应该保证函数的可重入性,或者使用信号量、中断等机制来保证数据的安全性操作。
不可重入函数基本上与可重入函数有相反的定义了:不可重入,意味着不可被并行调度,否则会产生不可预料的结果,这些函数提内一般使用了静态(static)的数据结构,使用了malloc()或者free()函数,使用了标准I/O函数等等。
在多任务环境中或者实时系统设计中,应该尽可能的使用可重入函数,例如下面的函数:
int count_apple(int *package,int n)
{
int temp = 0;
int i;
if(package == NULL)
exit(1);
for(i = 0;i
该函数功能是计算不同篮子里的苹果数,函数体内没有访问全局变量,不使用静态局部变量,只使用局部变量,所以这个函数具有可重入的,如果必须使用全局变量,那么为了保证函数的安全,必须利用互斥信号量或者中断机制来保护全局变量。例如下面函数:
int *package;
int count_apple(int n)
{
int temp = 0;
int i;
P操作(申请信号量);
if(package == NULL)
{
V操作(释放信号量);
exit(1)
}
for(i = 0; i
temp += *(package++);
V操作(释放信号量);
return temp;
}
象上面的PV操作机制就可以让可重入函数安全的使用全局变量了,而且保证了可并行性。
不可重入函数,例如:
static int sum = 0;
int cout_pear(int *package,int n)
{
int i;
for(i = 0; i
sum += *(package ++); //(1)
return sum;
}
这个函数由于使用了静态全局变量,对sum的并行性操作结果是未知的,是不安全的操做。若此函数被多个进程调用的话,结果是未知的。因为,但语句(1)执行完一次或者几次后,另外使用这个sum的函数可能正好被调度,并得到运行机会,那么这个新运行的函数将使sum变成了另外的值,所以当(1)重新获得运行机会时,sum的值已经变成了另外的值,这是不可预料的结果。
也可以这样总结,在任务系统中要进行并行操作,应该保证函数的可重入性,或者使用信号量、中断等机制来保证数据的安全性操作。