Ошибка в автоматически сгенерированных файлах, созданных при сборке RecyclerView - PullRequest
0 голосов
/ 16 мая 2019

Я новый пользователь Android Studio, также новичок в Java. Я создаю новый проект и следовал этому руководству, чтобы добавить RecyclerView в мой проект: https://www.youtube.com/watch?v=Vyqz_-sJGFk. Приложение выглядит правильно, но теперь сразу открывается при открытии на моем устройстве. До этого все работало нормально. Сообщения об ошибках приводят меня к автоматически сгенерированным файлам, которые были созданы во время этого процесса.

Я попытался проследить за сообщениями об ошибках в файлах и не могу понять, как их исправить, если это действительно проблема. В поисках решения с поисковыми терминами 'recyclerview', 'android studio' 'не удается разрешить символы' и т. Д. Я нашел несколько рекомендаций по обновлению до Android Studio 3.3. Я был уже на 3.4.0, но я попытался обновить до 3.4.1. Без изменений. Я попытался изменить зависимости в моем файле build.gradle, который, похоже, тоже ничего не изменил. Большинство других ответов, которые я нашел, было связано с cannot resolve symbol 'RecyclerView', что не является проблемой, с которой я сталкиваюсь в настоящее время. Я также пытался Файл> Неправильные кэши / перезапуск ...> Неправильные кэши и перезапуск несколько раз, как я рекомендовал в нескольких местах.

В следующих файлах я обнаружил несколько мест, где import androidx.recyclerview.R; приводит к ошибке cannot resolve symbol 'R', и несколько мест, где lst.elementData отлично работает в одной части файла, но не в другой, что приводит к cannot resolve symbol 'elementData'. Мои текущие зависимости build.gradle выглядят так:

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation 'androidx.appcompat:appcompat:1.0.2'
    implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
    implementation 'com.google.android.material:material:1.0.0'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'androidx.test:runner:1.1.1'
    androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.1'
    implementation 'androidx.recyclerview:recyclerview-selection:1.0.0'
}

Последняя функция, которую я могу быть уверен, вызывается:

@Override
    public void onBindViewHolder(@NonNull ViewHolder holder, final int position) {
        Log.d(TAG, "onBindViewHolder: called");

        holder.itemName.setText(mItemName.get(position));
        holder.itemDue.setText(mItemDue.get(position));

        holder.listItem.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Log.d(TAG, "onClick: clicked on: " + mItemName.get(position));

                // Insert navigation here
            }
        });
    }

как видно из журнала ошибок ниже.
Единственный код, который я добавил в последний раз, когда работал мой проект, - это учебник, которому я следовал, с небольшими изменениями имен некоторых переменных и заменой изображения в каждом элементе списка вторым TextView.

Сообщения об ошибках в журнале:

2019-05-16 00:46:04.247 12824-12824/? D/RecyclerViewAdapter: onBindViewHolder: called
2019-05-16 00:46:04.248 12824-12824/? D/AndroidRuntime: Shutting down VM
2019-05-15 23:44:28.830 4480-4480/com.example.divideanddestress E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.example.divideanddestress, PID: 4480
    java.lang.IndexOutOfBoundsException: Index: 0, Size: 0
        at java.util.ArrayList.get(ArrayList.java:411)
        at com.example.divideanddestress.RecyclerViewAdapter.onBindViewHolder(RecyclerViewAdapter.java:42)
        at com.example.divideanddestress.RecyclerViewAdapter.onBindViewHolder(RecyclerViewAdapter.java:16)
        at androidx.recyclerview.widget.RecyclerView$Adapter.onBindViewHolder(RecyclerView.java:6781)
        at androidx.recyclerview.widget.RecyclerView$Adapter.bindViewHolder(RecyclerView.java:6823)
        at androidx.recyclerview.widget.RecyclerView$Recycler.tryBindViewHolderByDeadline(RecyclerView.java:5752)
        at androidx.recyclerview.widget.RecyclerView$Recycler.tryGetViewHolderForPositionByDeadline(RecyclerView.java:6019)
        at androidx.recyclerview.widget.RecyclerView$Recycler.getViewForPosition(RecyclerView.java:5858)
        at androidx.recyclerview.widget.RecyclerView$Recycler.getViewForPosition(RecyclerView.java:5854)
        at androidx.recyclerview.widget.LinearLayoutManager$LayoutState.next(LinearLayoutManager.java:2230)
        at androidx.recyclerview.widget.LinearLayoutManager.layoutChunk(LinearLayoutManager.java:1557)
        at androidx.recyclerview.widget.LinearLayoutManager.fill(LinearLayoutManager.java:1517)
        at androidx.recyclerview.widget.LinearLayoutManager.onLayoutChildren(LinearLayoutManager.java:612)
        at androidx.recyclerview.widget.RecyclerView.dispatchLayoutStep2(RecyclerView.java:3924)
        at androidx.recyclerview.widget.RecyclerView.dispatchLayout(RecyclerView.java:3641)
        at androidx.recyclerview.widget.RecyclerView.onLayout(RecyclerView.java:4194)
        at android.view.View.layout(View.java:19039)
        at android.view.ViewGroup.layout(ViewGroup.java:5935)
        at androidx.constraintlayout.widget.ConstraintLayout.onLayout(ConstraintLayout.java:1915)
        at android.view.View.layout(View.java:19039)
        at android.view.ViewGroup.layout(ViewGroup.java:5935)
        at com.google.android.material.appbar.HeaderScrollingViewBehavior.layoutChild(HeaderScrollingViewBehavior.java:142)
        at com.google.android.material.appbar.ViewOffsetBehavior.onLayoutChild(ViewOffsetBehavior.java:41)
        at com.google.android.material.appbar.AppBarLayout$ScrollingViewBehavior.onLayoutChild(AppBarLayout.java:1556)
        at androidx.coordinatorlayout.widget.CoordinatorLayout.onLayout(CoordinatorLayout.java:888)
        at android.view.View.layout(View.java:19039)
        at android.view.ViewGroup.layout(ViewGroup.java:5935)
        at android.widget.FrameLayout.layoutChildren(FrameLayout.java:323)
        at android.widget.FrameLayout.onLayout(FrameLayout.java:261)
        at android.view.View.layout(View.java:19039)
        at android.view.ViewGroup.layout(ViewGroup.java:5935)
        at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1741)
        at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1585)
        at android.widget.LinearLayout.onLayout(LinearLayout.java:1494)
        at android.view.View.layout(View.java:19039)
        at android.view.ViewGroup.layout(ViewGroup.java:5935)
        at android.widget.FrameLayout.layoutChildren(FrameLayout.java:323)
        at android.widget.FrameLayout.onLayout(FrameLayout.java:261)
        at android.view.View.layout(View.java:19039)
        at android.view.ViewGroup.layout(ViewGroup.java:5935)
        at android.widget.LinearLayout.setChildFrame(LinearLayout.java:1741)
        at android.widget.LinearLayout.layoutVertical(LinearLayout.java:1585)
        at android.widget.LinearLayout.onLayout(LinearLayout.java:1494)
        at android.view.View.layout(View.java:19039)
        at android.view.ViewGroup.layout(ViewGroup.java:5935)
        at android.widget.FrameLayout.layoutChildren(FrameLayout.java:323)
        at android.widget.FrameLayout.onLayout(FrameLayout.java:261)
        at com.android.internal.policy.DecorView.onLayout(DecorView.java:954)
        at android.view.View.layout(View.java:19039)
        at android.view.ViewGroup.layout(ViewGroup.java:5935)
        at android.view.ViewRootImpl.performLayout(ViewRootImpl.java:2711)
        at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:2426)
2019-05-15 23:44:28.831 4480-4480/com.example.divideanddestress E/AndroidRuntime:     at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1569)
        at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:7296)
        at android.view.Choreographer$CallbackRecord.run(Choreographer.java:930)
        at android.view.Choreographer.doCallbacks(Choreographer.java:705)
        at android.view.Choreographer.doFrame(Choreographer.java:640)
        at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:916)
        at android.os.Handler.handleCallback(Handler.java:751)
        at android.os.Handler.dispatchMessage(Handler.java:95)
        at android.os.Looper.loop(Looper.java:154)
        at android.app.ActivityThread.main(ActivityThread.java:6816)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1563)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1451)

Ответы [ 2 ]

0 голосов
/ 16 мая 2019

Спасибо обоим людям, которые ответили / прокомментировали.Посмотрев на то, на чем вы фокусировались, я обнаружил, что ArrayList mItemDue не заполняется.После исправления приложение работает нормально.

0 голосов
/ 16 мая 2019

Объявите mItemName = new ArrayList () перед использованием arrarylist и проверьте значение itemCount.

...