Подтвердить что ты не робот

Android java ошибки реализации.. они документированы?

Я играю с простым андроидным приложением, используя emmulator, работающий с android-7 (2.1) и moto-defy, работающий с android-8 (2.2).

У меня возникла интересная проблема, из-за которой приложение синтаксического анализа CSV потерпело неудачу на эмуляторе, но преуспело в defy и в обычных Java-приложениях (используя sun java).

Я проследил проблему, и причина в том, что реализация StringReader для Android-версии не поддерживает отрицательную операцию пропуска:

Android-7:

/**
 * Skips {@code amount} characters in the source string. Subsequent calls of
 * {@code read} methods will not return these characters unless {@code
 * reset()} is used.
 *
 * @param ns
 *            the maximum number of characters to skip.
 * @return the number of characters actually skipped or 0 if {@code ns < 0}.
 * @throws IOException
 *             if this reader is closed.
 * @see #mark(int)
 * @see #markSupported()
 * @see #reset()
 */
@Override
public long skip(long ns) throws IOException {
    synchronized (lock) {
        if (isClosed()) {
            throw new IOException(Msg.getString("K0083")); //$NON-NLS-1$
        }
        if (ns <= 0) {
            return 0;
        }
        long skipped = 0;
        if (ns < this.count - pos) {
            pos = pos + (int) ns;
            skipped = ns;
        } else {
            skipped = this.count - pos;
            pos = this.count;
        }
        return skipped;
    }
}

J2SE 1.6:

/**
 * Skips the specified number of characters in the stream. Returns
 * the number of characters that were skipped.
 *
 * <p>The <code>ns</code> parameter may be negative, even though the
 * <code>skip</code> method of the {@link Reader} superclass throws
 * an exception in this case. Negative values of <code>ns</code> cause the
 * stream to skip backwards. Negative return values indicate a skip
 * backwards. It is not possible to skip backwards past the beginning of
 * the string.
 *
 * <p>If the entire string has been read or skipped, then this method has
 * no effect and always returns 0.
 *
 * @exception  IOException  If an I/O error occurs
 */
public long skip(long ns) throws IOException {
    synchronized (lock) {
        ensureOpen();
        if (next >= length)
            return 0;
        // Bound skip by beginning and end of the source
        long n = Math.min(length - next, ns);
        n = Math.max(-next, n);
        next += n;
        return n;
    }
}

Поэтому вместо пропусков назад (синтаксический анализатор использует это для предварительного чтения символа в определенных случаях) версия для Android остается одним символом вперед.

Мой вопрос в том, являются ли различные несовместимости и вариации от спецификации J2SE в любом месте? Если нет, то какие другие проблемы вы столкнетесь с ребятами.

Спасибо, стр.

4b9b3361

Ответ 1

Одно место для поиска - трекер для Android.

Еще одно место для поиска - это трекер для Apache Harmony.

По общему признанию, использование трекеров ошибок будет включать поиск, а не просмотр веб-страниц с осторожными категоризацией. Вы могли бы подумать об этом как о возможности...


FWIW - поиск трекера Tracker Harmony показывает, что было несколько проблем с поведением skip в различных классах потоков. Один из вопросов жаловался, что поведение какого-либо класса не соответствует javadoc... и это было закрыто, говоря, что оно DID соответствует поведению RI, и что ошибка была поэтому в javadoc.

Я считаю, что Sun/Oracle несут в себе много вины за подобные вещи из-за их отказа от лицензии TCK на проект Apache Harmony на разумных условиях.