WSSetYieldFunction (C 函数)
int WSSetYieldFunction(WSLINK link,WSYieldFunctionObject yf)
安装由 link 引用的链接的屈服函数 yf.
更多信息
- 某些 WSTP API 调用会被阻塞直到数据可被读取或空间可被写入. 如果在阻塞期间,应用程序需要执行其他有用的处理,应用程序可以安装链接的屈服函数(yield function),当被阻塞时,WSTP 会自动调用屈服函数.
- 备份被封锁的读或写,屈服函数应返回一个非零值.
- 若发生错误,则 WSSetYieldFunction() 返回0;若函数成功,则返回非零值.
- 在 Windows 上, WSYieldFunctionObject 使用 WINAPI 调用规范.
- 若 WSSetYieldFunction() 失败,则使用 WSError() 检索错误代码.
- WSTP 的标头文件 wstp.h 已对 WSSetYieldFunction() 作出声明.
范例
基本范例 (1)
#include "wstp.h"
#if UNIX_MATHLINK
# define CALLING_CONVENTION
#elif WINDOWS_MATHLINK
# define CALLING_CONVENTION WINAPI
#endif
int CALLING_CONVENTION AppYieldFunction(WSLINK lp, WSYieldParameters yp)
{
/* ... */
return 0;
}
int main(int argc, char **argv)
{
WSENV env;
WSLINK link;
int error;
env = WSInitialize((WSEnvironmentParameter)0);
if(env == (WSENV)0)
{ /* unable to initialize WSTP environment */ }
link = WSOpenArgcArgv(env, argv, argv + argc, &error);
if(link == (WSLINK)0 || error != WSEOK)
{ /* unable to create the link */ }
if(! WSSetYieldFunction(link, AppYieldFunction))
{ /* unable to set the yield function for link */ }
/* ... */
WSClose(link);
WSDeinitialize(env);
return 0;
}