/**
* 缓存一个 Notify
*/
public static void cacheNotify(Notify n) {
synchronized (notifyCacheList) {
notifyCacheList.add(n);
}
FsSdkLog.i(LOG_TAG, "cache notify " + n.toString());
}
/**
* 上传缓存的通知
*/
private static void uploadCachedNotifies(SQLiteDatabase db) {
Notify[] notifies;
FsSdkLog.i(LOG_TAG, "1cached notify count=" + notifyCacheList.size());
synchronized (notifyCacheList) {
notifies = notifyCacheList.toArray(new Notify[0]);
notifyCacheList.clear();
}
if(notifies != null && notifies.length > 0)
Notify.send(db, notifies);
FsSdkLog.i(LOG_TAG, "2cached notify count=" + notifyCacheList.size());
}
注意:
notifies = notifyCacheList.toArray(new Notify[0]);
刚开始写的是
notifies = (Notify[])notifyCacheList.toArray();
然后诡异问题就出现了。只打印了 1 处日志,2处日志没打印,没抛异常,诡异了!
其实是一个很低级的问题,数组不能强转,而刚好又在同步快内,异常出现了,下面的逻辑直接没执行,但是程序没崩溃我就不理解了!