静态变量的线程问题。

其中askedCount 是静态变量,多线程访问导致askedCount 结果不对,因为静态变量再被多个线程修改时其实是修改的同一个变量

导致 在返回前值被修改。

改正方式是 把askedCount 声明成静态变量。

public static Long getAskedCount() {



String beginTime;
Date beginDate = new Date();
askedCount = -1L;


if (GameDynamicElement.getAskTime() != null) {
SimpleDateFormat df = null;
df = new SimpleDateFormat("yyyy-MM-dd");
beginTime = df.format(new Date());
beginTime = beginTime + " " + GameDynamicElement.getAskTime();
} else {
beginTime = null;
}


if (StringUtils.isNotEmpty(beginTime)) {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
try {
beginDate = sdf.parse(beginTime);
} catch (ParseException e) {
e.printStackTrace();
}
// 时差
askedCount = System.currentTimeMillis() - beginDate.getTime();


if (askedCount > 0) {


askedCount = (askedCount / (GameDynamicElement.getSpaceTime() * 1000)) + 1;
}
}
return askedCount;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值