请教一个关于python的全局锁的问题

在把python的程序嵌入到c中,使用多线程的时候发现这么一个现象,python中如果把循环到一定长度后,在c线程退出的时候就会出现
Fatal Python error: This thread state must be current when releasing

这个错误,大概就是线程在释放的时候的状态应该是处于主线程状态,而python中循环写得短的话,就不会出问题,只启动一个线程的话也不会有问题,启动两个以上线程并且有一个线程循环很长的话就会有这个问题,希望大家能帮帮我看看要怎么做,最近全局锁把头都整大了,如果直接使用全局锁的话,单独启动一个线程的话就没有问题,如果启动两个的话就会出现 Fatal Python error: ceval: tstate mix-up 错误,所以使用的是PyGILState_STATE系列.

python的程序样本如下:

def strtest():
a=0

while a<1000000:
a=a+1

print 'ok'

return 0



c的线程样本如下:

void ThreadProc1(void*p){



PyObject * pFunc =NULL;
PyObject * pValue = NULL;





PyGILState_STATE gstate;

gstate = PyGILState_Ensure();




pFunc = PyDict_GetItemString(pDict,"strtest");
if (PyCallable_Check(pFunc)){
pValue = PyObject_CallObject(pFunc, NULL);
}else{
PyErr_Print();
}

Py_CLEAR(pValue);



PyGILState_Release(gstate);


pthread_exit(NULL);


}