質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.91%

androidのWorkManagerで、ClassCastExceptionが時折発生する

受付中

回答 0

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 174

tamago83

score 45

前提・実現したいこと

androidxのWorkerManagerを使用し、バックグラウンドで通信を行うアプリを作成しています。
公開したアプリで、androidのバージョンに関係なく、常に発生しておらず、時折発生しております。
※自端末では発生しておらず、firebase Crashlyticsなどでは大量に発生が見えます。

発生している問題・エラーメッセージ

Fatal Exception: java.lang.ClassCastException
class jp.example.DataCollectWorker cannot be cast to androidx.work.ListenableWorker
java.lang.Class.asSubclass
java.lang.Class.asSubclass (Class.java:2477)
androidx.work.WorkerFactory.createWorkerWithDefaultFallback (WorkerFactory.java:88)
androidx.work.impl.WorkerWrapper.runWorker (WorkerWrapper.java:242)
androidx.work.impl.WorkerWrapper.run (WorkerWrapper.java:136)
androidx.work.impl.utils.SerialExecutor$Task.run (SerialExecutor.java:91)
java.util.concurrent.ThreadPoolExecutor.runWorker (ThreadPoolExecutor.java:1167)
java.util.concurrent.ThreadPoolExecutor$Worker.run (ThreadPoolExecutor.java:641)
java.lang.Thread.run (Thread.java:764)

該当のソースコード

実際にどこで発生しているか不明ですので、WorkerManagerを呼び出している部分のみ抜粋しています。

実行

class Activity : :AppCompatActivity(){
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)

        WorkManager.getInstance(application)
                  .getWorkInfoByIdLiveData(DataCollectWorker.allRequest())
    }
}
                    .getWorkInfoByIdLiveData(DataCollectWorker.allRequest())


呼び出し用

object DataCollectWorker{
    fun allRequest(): UUID {
        Util.log.d("allRequest")
        val request: OneTimeWorkRequest = OneTimeWorkRequestBuilder<DataAllRequestUseCase>()
                .build()

        WorkManager
                .getInstance(applicationContext)
                .beginUniqueWork(
                        "ALL"
                        , ExistingWorkPolicy.REPLACE
                        , request
                ).enqueue()

        return request.id
    }

    fun singleRequest(url: String): UUID {
        Util.log.d("newRequest")
        val request: OneTimeWorkRequest = OneTimeWorkRequestBuilder<DataSingleRequestUseCase>()
                .addTag(TAG_ONETIME)
                .setInputData(
                    workDataOf(
                            DATA_URL to url
                    )
                ).build()

        WorkManager
                .getInstance(applicationContext)
                .beginUniqueWork(
                        "ONE_TIME"
                        , ExistingWorkPolicy.REPLACE
                        , request
                ).enqueue()

        return request.id
    }
}

動作しているところ

class DataAllRequestUseCase(appContext: Context, params: WorkerParameters) : CoroutineWorker(appContext, params) {
    override suspend fun doWork(): Result = withContext(Dispatchers.IO)  {
        // いろいろな処理

        return@withContext Result.success()
    }

}

class DataSingleRequestUseCase(appContext: Context, params: WorkerParameters) : CoroutineWorker(appContext, params) {
    override suspend fun doWork(): Result = withContext(Dispatchers.IO) {
        // いろいろな処理

        return@withContext Result.success()
    }
}

試したこと

ライブラリのバージョンの変更しましたが、変わりませんでした。

補足情報(FW/ツールのバージョンなど)

端末:Huawei P10 lite
androidバージョン: 8.0.0
ライブラリ: androidx.work:work-runtime-ktx:2.3.4
IDE : android studio 4.0
targetSdkVersion : 29

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正の依頼

  • hoshi-takanori

    2020/07/10 17:33

    DataCollectWorker を ListenableWorker にキャストしようとして失敗しているようですが、DataCollectWorker はどこでどう使われてますか?

    キャンセル

  • tamago83

    2020/07/15 05:55

    activityのonCreateで以下のように実行しております。
    WorkManager.getInstance(application)
    .getWorkInfoByIdLiveData(DataCollectWorker.allRequest())

    キャンセル

まだ回答がついていません

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.91%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る