নির্দিষ্ট পরিস্থিতিতে, আপনাকে একটি কাস্টম থ্রেডিং কৌশল প্রদান করতে হতে পারে। উদাহরণস্বরূপ, আপনাকে একটি কলব্যাক-ভিত্তিক অ্যাসিঙ্ক্রোনাস অপারেশন পরিচালনা করতে হতে পারে। WorkManager ListenableWorker এর সাথে এই ব্যবহারের ক্ষেত্রে সমর্থন করে। ListenableWorker হল সবচেয়ে মৌলিক কর্মী API; Worker , CoroutineWorker , এবং RxWorker সবাই এই শ্রেণী থেকে উদ্ভূত। একজন ListenableWorker শুধুমাত্র তখনই সংকেত দেয় যখন কাজটি শুরু করা উচিত এবং বন্ধ করা উচিত এবং থ্রেডিং সম্পূর্ণভাবে আপনার উপর ছেড়ে দেয়। মূল থ্রেডে কাজ শুরু করার সংকেত দেওয়া হয়, তাই আপনার পছন্দের ব্যাকগ্রাউন্ড থ্রেডে ম্যানুয়ালি যাওয়া খুবই গুরুত্বপূর্ণ।
বিমূর্ত পদ্ধতি ListenableWorker.startWork() Result একটি ListenableFuture প্রদান করে। একটি ListenableFuture হল একটি হালকা ইন্টারফেস: এটি একটি Future যা শ্রোতাদের সংযুক্ত করার এবং ব্যতিক্রমগুলি প্রচার করার জন্য কার্যকারিতা প্রদান করে৷ startWork পদ্ধতিতে, আপনি একটি ListenableFuture ফেরত দেবেন বলে আশা করা হচ্ছে, যেটি আপনি সম্পূর্ণ হয়ে গেলে অপারেশনের Result সাথে সেট করবেন। আপনি দুটি উপায়ের একটিতে ListenableFuture দৃষ্টান্ত তৈরি করতে পারেন:
- আপনি যদি পেয়ারা ব্যবহার করেন তবে
ListeningExecutorServiceব্যবহার করুন। - অন্যথায়, আপনার gradle ফাইলে
councurrent-futuresঅন্তর্ভুক্ত করুন এবংCallbackToFutureAdapterব্যবহার করুন।
আপনি যদি একটি অ্যাসিঙ্ক্রোনাস কলব্যাকের উপর ভিত্তি করে কিছু কাজ সম্পাদন করতে চান তবে আপনি এইরকম কিছু করবেন:
কোটলিন
class CallbackWorker( context: Context, params: WorkerParameters ) : ListenableWorker(context, params) { override fun startWork(): ListenableFuture<Result> { return CallbackToFutureAdapter.getFuture { completer -> val callback = object : Callback { var successes = 0 override fun onFailure(call: Call, e: IOException) { completer.setException(e) } override fun onResponse(call: Call, response: Response) { successes++ if (successes == 100) { completer.set(Result.success()) } } } repeat(100) { downloadAsynchronously("https://example.com", callback) } callback } } }
জাভা
public class CallbackWorker extends ListenableWorker { public CallbackWorker(Context context, WorkerParameters params) { super(context, params); } @NonNull @Override public ListenableFuture<Result> startWork() { return CallbackToFutureAdapter.getFuture(completer -> { Callback callback = new Callback() { int successes = 0; @Override public void onFailure(Call call, IOException e) { completer.setException(e); } @Override public void onResponse(Call call, Response response) { successes++; if (successes == 100) { completer.set(Result.success()); } } }; for (int i = 0; i < 100; i++) { downloadAsynchronously("https://www.example.com", callback); } return callback; }); } }
আপনার কাজ বন্ধ হলে কি হবে? একটি ListenableWorker 's ListenableFuture সর্বদা বাতিল করা হয় যখন কাজ বন্ধ হওয়ার আশা করা হয়। একটি CallbackToFutureAdapter ব্যবহার করে, আপনাকে কেবল একটি বাতিল শ্রোতা যোগ করতে হবে, নিম্নরূপ:
কোটলিন
class CallbackWorker( context: Context, params: WorkerParameters ) : ListenableWorker(context, params) { override fun startWork(): ListenableFuture<Result> { return CallbackToFutureAdapter.getFuture { completer -> val callback = object : Callback { var successes = 0 override fun onFailure(call: Call, e: IOException) { completer.setException(e) } override fun onResponse(call: Call, response: Response) { ++successes if (successes == 100) { completer.set(Result.success()) } } } completer.addCancellationListener(cancelDownloadsRunnable, executor) repeat(100) { downloadAsynchronously("https://example.com", callback) } callback } } }
জাভা
public class CallbackWorker extends ListenableWorker { public CallbackWorker(Context context, WorkerParameters params) { super(context, params); } @NonNull @Override public ListenableFuture<Result> startWork() { return CallbackToFutureAdapter.getFuture(completer -> { Callback callback = new Callback() { int successes = 0; @Override public void onFailure(Call call, IOException e) { completer.setException(e); } @Override public void onResponse(Call call, Response response) { ++successes; if (successes == 100) { completer.set(Result.success()); } } }; completer.addCancellationListener(cancelDownloadsRunnable, executor); for (int i = 0; i < 100; ++i) { downloadAsynchronously("https://www.example.com", callback); } return callback; }); } }
একটি ভিন্ন প্রক্রিয়ায় একটি ListenableWorker চালানো
আপনি RemoteListenableWorker ব্যবহার করে একজন কর্মীকে একটি নির্দিষ্ট প্রক্রিয়ার সাথে আবদ্ধ করতে পারেন, ListenableWorker এর একটি বাস্তবায়ন।
RemoteListenableWorker দুটি অতিরিক্ত আর্গুমেন্ট সহ একটি নির্দিষ্ট প্রক্রিয়ার সাথে আবদ্ধ হয় যা আপনি কাজের অনুরোধ তৈরি করার সময় ইনপুট ডেটার অংশ হিসাবে প্রদান করেন: ARGUMENT_CLASS_NAME এবং ARGUMENT_PACKAGE_NAME ।
নিম্নলিখিত উদাহরণটি একটি কাজের অনুরোধ তৈরি করে যা একটি নির্দিষ্ট প্রক্রিয়ার সাথে আবদ্ধ:
কোটলিন
val PACKAGE_NAME = "com.example.background.multiprocess" val serviceName = RemoteWorkerService::class.java.name val componentName = ComponentName(PACKAGE_NAME, serviceName) val data: Data = Data.Builder() .putString(ARGUMENT_PACKAGE_NAME, componentName.packageName) .putString(ARGUMENT_CLASS_NAME, componentName.className) .build() return OneTimeWorkRequest.Builder(ExampleRemoteListenableWorker::class.java) .setInputData(data) .build()
জাভা
String PACKAGE_NAME = "com.example.background.multiprocess"; String serviceName = RemoteWorkerService.class.getName(); ComponentName componentName = new ComponentName(PACKAGE_NAME, serviceName); Data data = new Data.Builder() .putString(ARGUMENT_PACKAGE_NAME, componentName.getPackageName()) .putString(ARGUMENT_CLASS_NAME, componentName.getClassName()) .build(); return new OneTimeWorkRequest.Builder(ExampleRemoteListenableWorker.class) .setInputData(data) .build();
প্রতিটি RemoteWorkerService এর জন্য, আপনাকে আপনার AndroidManifest.xml ফাইলে একটি পরিষেবা সংজ্ঞা যোগ করতে হবে:
<manifest ... > <service android:name="androidx.work.multiprocess.RemoteWorkerService" android:exported="false" android:process=":worker1" /> <service android:name=".RemoteWorkerService2" android:exported="false" android:process=":worker2" /> ... </manifest>