今天,在开启定时任务线程时,任务在执行1遍之后不再执行。一直卡主,但无任务异常报出(不知是否是日志屏蔽了这类错误)。
错误类似如下:
private Long a;
pirvate int timeout =50000;
private ChannelSftp sftp = new ChannelSftp ();
if (null !=sftp && System.currentTimeMillis() - a < timeout ) {
//XXXX业务代码
}
其中 使用到了System.currentTimeMillis() 减去一个Long 型 < int 类型。
在加减运算之中,一般会自动的类型转换,而且初始long 应该被赋予了初值0.
但是注意到了。。其实是 long - Long < int.
正常情况下不会有什么问题,但是Long类型初始化并不像int 与 long 一样被系统赋予初值0.导致Long类型为空,线程僵死,后续定时线程上来后依然卡死在这样,从外来看像是程序假死了。
在使用Integer 与Long 等基础类型对应object,如果需默认值,需要初始化赋值,避免运算时假死。