-2

这段代码直到几天前才有效。现在它不再适用于 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)
4

1 回答 1

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

于 2017-12-04T10:21:35.223 回答