今天上班遇到这么一个意料之外的异常:
出问题的代码是这样的(已去除上下文信息):
Log.i(LOG_TAG, new SimpleDateFormat("YYYY-MM-dd HH:mm:ss", Locale.CHINA) .format(System.currentTimeMillis()));
反复检查,感觉没有问题,于是新建一个Java Project,直接输出同样的代码:
public class Main{ public static void main(String[] args){ System.out.println(new SimpleDateFormat("YYYY-MM-dd HH:mm:ss", Locale.CHINA) .format(System.currentTimeMillis())); }}
得到的结果是这样的:
感觉蹊跷,遂查阅Android API,在Java.text.SimpleDateFormat的描述表中,与Java SE 不同,对“年”的描述中,仅有"y",没有"Y"。当把代码中的"Y"替换为小写后,问题就解决了。
这便是API的不同的坑。以前也遇到过一些,但今天这个有些意外,以前没有注意过。总结:以后如果使用Java标准代码出现奇怪的问题,最好先查看Android API,以确保自己的调用方式是否正确和有效。
Android 和Java API的一个坑:SimpleDateFormat,布布扣,bubuko.com
时间: 2024-12-10 10:59:26