问题描述
我正在尝试使用 androidx.work:work-multiprocess:2.5.0 在使用 Configuration.setDefaultProcessName() 指定的进程中运行工作,但是无论我使用哪个进程入队工作,在主应用进程中调用 doWork() 方法。
如 documentation 中所述 RemoteWorkManager 始终与指定的进程联系。进程内调度器也在指定进程中运行。
我的完整测试项目在这里:https://github.com/padreMateo88/multiprocessWorkManagerTest
我使用以下依赖项:
implementation 'androidx.work:work-runtime-ktx:2.5.0'
implementation 'androidx.work:work-multiprocess:2.5.0'
我删除了清单中的默认 WorkManagerInitialiser:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
package="com.example.workmanagertest">
<application
android:name=".MyApplication"
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/AppTheme">
<activity android:name=".MainActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<receiver
android:name="com.example.workmanagertest.SecondProcessBroadcastReceiver"
android:process=":second_process" />
<provider
android:name="androidx.work.impl.WorkManagerInitializer"
android:authorities="${applicationId}.workmanager-init"
tools:node="remove" />
</application>
</manifest>
在 Application 类中实现的 Configuration.Provider:
class MyApplication : Application(),Configuration.Provider {
override fun getWorkManagerConfiguration(): Configuration = WorkConfigurationProvider().get()
}
class WorkConfigurationProvider {
fun get() = Configuration.Builder().setDefaultProcessName(processName).build()
companion object {
private const val processName = "com.example.workmanagertest:second_process"
}
}
并使用 RemoteWorkManager.getInstance() 将我的工作加入队列:
class SampleWorker(context: Context,workerParams: WorkerParameters) : Worker(context,workerParams) {
override fun doWork(): Result {
Util.d(applicationContext,"SampleWorker.doWork()")
return Result.success()
}
companion object {
@JvmStatic
fun enqueueWork(context: Context) {
Util.d(context,"SampleWorker.enqueueWork()")
try {
val rwm = RemoteWorkManager.getInstance(context)
Util.d(context,"RemoteWorkManager hash ${rwm.hashCode()}")
rwm.enqueueUniqueWork(
"SampleWorker",ExistingWorkPolicy.REPLACE,OneTimeWorkRequest.from(SampleWorker::class.java)
)
} catch (ex: Throwable) {
Util.d(context,"SampleWorker,WorkManager is not initialized properly,reason: " + ex.message)
}
}
}
}
我做错了什么?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)