Странное поведение при использовании Apache Commons lib в Android - PullRequest
2 голосов
/ 02 ноября 2011

Я использую commons-lang3-3.0.1.jar, чтобы использовать класс StrSubstitutor.Проверьте это ...

Следующий код вызывается из моего SyncAdapter, происходит сбой при создании StrSubstitutor:

public static String makeGetPlansQueryString(Bundle params)
{
    Map<String, String> valuesMap = new HashMap<String, String>();

    valuesMap.put(REQUEST_PARAM_APIUSERNAME, API_USERNAME);
    valuesMap.put(REQUEST_PARAM_APIPASSWORD, API_PASSWORD);
    //... etc. etc.

    String xmlTemplate = VendApplication.getContext().getString(R.string.XMLREQUEST_GET_PLANS);
    StrSubstitutor subst = new StrSubstitutor(valuesMap); // <-- Crashes in here.
    return subst.replace(xmlTemplate);
}

Вывод ошибки:

    11-02 14:36:08.439: ERROR/AndroidRuntime(9244): FATAL EXCEPTION: SyncAdapterThread-1
    11-02 14:36:08.439: ERROR/AndroidRuntime(9244): java.lang.ExceptionInInitializerError
    11-02 14:36:08.439: ERROR/AndroidRuntime(9244):     at com.conducthq.android.vend.webapi.WebAPIRequestHelper.makeGetPlansQueryString(WebAPIRequestHelper.java:68)
    11-02 14:36:08.439: ERROR/AndroidRuntime(9244):     at com.conducthq.android.vend.webapi.WebAPIClient.createHTTPRequest(WebAPIClient.java:121)
    11-02 14:36:08.439: ERROR/AndroidRuntime(9244):     at com.conducthq.android.vend.webapi.WebAPIClient.processRequest(WebAPIClient.java:55)
    11-02 14:36:08.439: ERROR/AndroidRuntime(9244):     at com.conducthq.android.vend.webapi.SyncAdapter.onPerformSync(SyncAdapter.java:39)
    11-02 14:36:08.439: ERROR/AndroidRuntime(9244):     at android.content.AbstractThreadedSyncAdapter$SyncThread.run(AbstractThreadedSyncAdapter.java:163)
    11-02 14:36:08.439: ERROR/AndroidRuntime(9244): Caused by: java.lang.ExceptionInInitializerError
    11-02 14:36:08.439: ERROR/AndroidRuntime(9244):     at org.apache.commons.lang3.text.StrMatcher.stringMatcher(StrMatcher.java:206)
    11-02 14:36:08.439: ERROR/AndroidRuntime(9244):     at org.apache.commons.lang3.text.StrSubstitutor.<clinit>(StrSubstitutor.java:112)
    11-02 14:36:08.439: ERROR/AndroidRuntime(9244):     ... 5 more
    11-02 14:36:08.439: ERROR/AndroidRuntime(9244): Caused by: java.lang.NullPointerException
    11-02 14:36:08.439: ERROR/AndroidRuntime(9244):     at org.apache.commons.lang3.StringUtils.<clinit>(StringUtils.java:717)
    11-02 14:36:08.439: ERROR/AndroidRuntime(9244):     ... 7 more

ЕслиЯ добавляю эту одну строку к моей HomeActivity (запускается при запуске приложения), приведенный выше код отлично работает:

StrSubstitutor sub = new StrSubstitutor(new HashMap<String, String>());

Странно, верно?Как эта строка влияет на другой код, выполняющийся в другом потоке в другой момент времени?Какие-нибудь гуру Android могут пролить свет на это?Есть какая-то странная ошибка загрузки JAR Android, о которой я не знаю?@ _ @

Я использую Android 2.1 SDK на LG-P350.Я воспроизвел это поведение с помощью очень простого примера кода из документа API Apache Commons на StrSubstitutor: http://commons.apache.org/lang/api-3.0.1/org/apache/commons/lang3/text/StrSubstitutor.html

1 Ответ

1 голос
/ 02 ноября 2011

Ваш сбой происходит в статическом инициализаторе StringUtils, где он пытается получить загрузчик класса контекста из текущего потока - в явной попытке получить класс $ java.text.Normalizer.Так что да, это странная проблема с getContextClassLoader (), возвращающей null.

Обновление

Ошибка, очевидно, упоминается в эта ошибка ,так что, я думаю, вы могли бы просто принудительно установить загрузчик класса контекста, и все будет в порядке.

Thread.currentThread().setContextClassLoader(this.getClassLoader());
...