java Arraylist 同步问题,引发的问题

        /**
	 * 缓存一个 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处日志没打印,没抛异常,诡异了!

其实是一个很低级的问题,数组不能强转,而刚好又在同步快内,异常出现了,下面的逻辑直接没执行,但是程序没崩溃我就不理解了!



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值