此代码一直工作到几天前。现在它不再适用于Android 6.0版。它适用于7.0及更高版本。
public void setToDate(String quickDate) {
DateTime toDate = new DateTime();
if (quickDate.equals(context.getString(R.string.quickDate_today))) {
fromDate = fromDate.withTimeAtStartOfDay();
toDate = DateUtils.endOfDay(toDate);
}
....
}
/**
* @return a copy of dateTime with the time set to 11:59:59.999 pm.
*/
public static DateTime endOfDay(DateTime dateTime) {
return dateTime.withTime(23, 59, 59, 999);
}
这是奇怪的事情,如果我将withTime()调用直接调用而不是像这样的实用程序方法:
public void setToDate(String quickDate) {
DateTime toDate = new DateTime();
if (quickDate.equals(context.getString(R.string.quickDate_today))) {
fromDate = fromDate.withTimeAtStartOfDay();
toDate = toDate.withTime(23, 59, 59, 999);
}
....
}
然后代码工作,没有异常抛出。为什么?如何让它再次在实用程序方法中工作?
堆栈追踪:
Process: com.salesrabbit.android.sales.universal, PID: 29358
java.lang.ExceptionInInitializerError
at com.salesrabbit.android.sales.universal.canvass.filter.filters.Filter.setQuickFromAndToDates(Filter.java:273)
at com.salesrabbit.android.widget.FilterView.lambda$loadQuickDateMenu$3$FilterView(FilterView.java:203)
at com.salesrabbit.android.widget.FilterView$$Lambda$3.onMenuItemClick(Unknown Source)
at android.support.v7.widget.PopupMenu$1.onMenuItemSelected(PopupMenu.java:108)
at android.support.v7.view.menu.MenuBuilder.dispatchMenuItemSelected(MenuBuilder.java:822)
at android.support.v7.view.menu.MenuItemImpl.invoke(MenuItemImpl.java:171)
at android.support.v7.view.menu.MenuBuilder.performItemAction(MenuBuilder.java:973)
at android.support.v7.view.menu.MenuPopup.onItemClick(MenuPopup.java:127)
at android.widget.AdapterView.performItemClick(AdapterView.java:310)
at android.widget.AbsListView.performItemClick(AbsListView.java:1145)
at android.widget.AbsListView$PerformClick.run(AbsListView.java:3066)
at android.widget.AbsListView$3.run(AbsListView.java:3903)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:148)
at android.app.ActivityThread.main(ActivityThread.java:5417)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
Caused by: java.lang.IllegalArgumentException: Unknown pattern character 'X'
at java.text.SimpleDateFormat.validatePatternCharacter(SimpleDateFormat.java:323)
at java.text.SimpleDateFormat.validatePattern(SimpleDateFormat.java:312)
at java.text.SimpleDateFormat.<init>(SimpleDateFormat.java:365)
at java.text.SimpleDateFormat.<init>(SimpleDateFormat.java:258)
at com.salesrabbit.android.util.DateUtils.<clinit>(DateUtils.java:31)
答案 0 :(得分:2)
您可能知道 - 当Java无法创建类的实例时抛出ExceptionInInitializerError - 它通常表示构造函数中的错误,但也可以来自类中的静态块。
示例(由于静态块,无法创建此类,您会看到错误):
class MyClass {
private static boolean canDivideByZero;
private Object unassignedValue;
static {
//Of course this code is ridiculous, it's just an example
canDivideByZero = (10/0 == 10);
}
public MyClass() {
//The stupid NPE here would also manifest as an ExceptionInInitializerError
if ( unassignedValue.equals("") ) {
...
}
}
}
虽然您没有包含所需的堆栈跟踪,但您的评论为我们提供了线索
这是奇怪的事情,如果我移动withTime()...然后代码工作,没有异常抛出
因此,问题可能是您的实用程序类不可实例化,或者您调用的方法中的某些内容已被破坏 - 您正在从构造函数中调用它。请记住,实用程序类应该是最终的私有构造函数,它什么都不做。
注意:在OP的特定示例中,尝试使用来自另一个SDK的值的静态变量是原因。这是我在上面的示例中未涉及的内容 - 静态块和静态变量都在加载类时被初始化,并且可以抛出此异常。