Workmanager:FutureCallback总是返回成功,无论结果如何

发布于 2025-01-26 04:51:03 字数 767 浏览 3 评论 0原文

我正在这样做:

val fileUploadRequest = OneTimeWorkRequestBuilder<FileUploadWorker>().build()

Futures.addCallback(workManager.enqueueUniqueWork(this::class.simpleName!!, ExistingWorkPolicy.KEEP, fileUploadRequest).result,
    object : FutureCallback<Operation.State.SUCCESS> {
        override fun onSuccess(result: Operation.State.SUCCESS?) {
            Log.d(TAG, "onSuccess: ")
        }

        override fun onFailure(t: Throwable) {
            Log.d(TAG, "onFailure: ")
        }
    },
    executor
)

使用此RXWorker代码:

override fun createWork(): Single<Result> {
        return Single.just(Result.failure())
}

我总是最终进入OnSuccess()。怎么会?

另外:期货回调是否被删除了?还是永远活着?在某些情况下,我需要手动删除它吗?

I am doing this:

val fileUploadRequest = OneTimeWorkRequestBuilder<FileUploadWorker>().build()

Futures.addCallback(workManager.enqueueUniqueWork(this::class.simpleName!!, ExistingWorkPolicy.KEEP, fileUploadRequest).result,
    object : FutureCallback<Operation.State.SUCCESS> {
        override fun onSuccess(result: Operation.State.SUCCESS?) {
            Log.d(TAG, "onSuccess: ")
        }

        override fun onFailure(t: Throwable) {
            Log.d(TAG, "onFailure: ")
        }
    },
    executor
)

with this RxWorker code:

override fun createWork(): Single<Result> {
        return Single.just(Result.failure())
}

I always end up in onSuccess(). How come?

Also: Is the Futures callback ever removed? Or does it live forever? Do I need to remove it manually during some circumstances?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文