为什么从另一个方法调用DateTime.withTime()会导致exceptionInInitializerError

时间:2017-11-20 18:12:34

标签: android jodatime android-jodatime

此代码一直工作到几天前。现在它不再适用于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)

1 个答案:

答案 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的值的静态变量是原因。这是我在上面的示例中未涉及的内容 - 静态块和静态变量都在加载类时被初始化,并且可以抛出此异常。