从类的文档中
java.util.Timer:
与每个Timer对象相对应的是一个后台线程。
而偷看到的内码
java.util.Timer类,我们可以看到,它基本上是通过调用实例的线程
newThread()。
同时,从App
Engine的文档中了解有关在其Java沙箱中使用线程的信息:
您必须使用ThreadManager上的方法之一来创建线程。
您不能自己调用新的Thread() 或使用默认的线程工厂。
因此,这里发生的是
Timer对象实例化了自己的线程,然后该线程执行Objectify查询,但是由于在ThreadManager外部实例化的线程没有为它们设置适当的App
Engine API环境,因此它将引发异常。
您需要重构代码以避免使用Timer和TimerTask类,而应使用基本线程。例如,代替使用:
import java.util.Timer;import java.util.TimerTask;...Timer timer = new Timer();timer.schedule( new TimerTask(){ @Override public void run() { // Objectify query here. }}, 5000 );您可以改用:
import com.google.appengine.api.ThreadManager;...final long tScheduleDelay = 5000;ThreadManager.createThreadForCurrentRequest( new Runnable(){ @Override public void run() { try { Thread.sleep( tScheduleDelay ); } catch ( InterruptedException ex ) { // log possible exception } // Objectify query here. }} ).start();


