1.使用依赖库
compile 'com.birbit:android-priority-jobqueue:2.0.1'
2.应用功能部署
- 自定义Application
public class MyApp extends Application {
private static MyApp myApp;
public MyApp() {
myApp = this;
}
@Override
public void onCreate() {
super.onCreate();
}
private JobManager jobManager;
private void configureJobManager() {
Configuration.Builder builder = new Configuration.Builder(this).customLogger(new CustomLogger() {
private static final String TAG = "JOBS";
@Override
public boolean isDebugEnabled() {
return true;
}
@Override
public void d(String text, Object... args) {
Log.d(TAG, String.format(text, args));
}
@Override
public void e(Throwable t, String text, Object... args) {
Log.e(TAG, String.format(text, args), t);
}
@Override
public void e(String text, Object... args) {
Log.e(TAG, String.format(text, args));
}
@Override
public void v(String text, Object... args) {
}
}).minConsumerCount(1)//always keep at least one consumer alive
.maxConsumerCount(3)//up to 3 consumers at a time
.loadFactor(3)//3 jobs per consumer
.consumerKeepAlive(120);//wait 2 minute
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
builder.scheduler(FrameworkJobSchedulerService.createSchedulerFor(this, MyJobService.class), true);
}
jobManager = new JobManager(builder.build());
}
public synchronized JobManager getJobManager() {
if (jobManager == null) {
configureJobManager();
}
return jobManager;
}
public static MyApp getInstance() {
return myApp;
}
}
复制代码
- 自定义JobService
public class MyJobService extends FrameworkJobSchedulerService {
@NonNull
@Override
protected JobManager getJobManager() {
return MyApp.getInstance().getJobManager();
}
}
复制代码
- 自定义Job
public class MyJob extends Job {
private Handler mHandler;
private String city;
protected MyJob(Params params, Handler handler,String city) {
super(params);
this.mHandler = handler;
this.city = city;
}
@Override
public void onAdded() {
Log.w("日志", "onAdded: 添加了");
}
@Override
public void onRun() throws Throwable {
Log.w("日志", "onRun: 执行");
OkHttpClient client = new OkHttpClient();
client.setConnectTimeout(30 * 1000, TimeUnit.MILLISECONDS);
client.setWriteTimeout(30*1000,TimeUnit.MILLISECONDS);
Request request = new Request.Builder()
.url(city.equals("北京")?"http://www.sojson.com/open/api/weather/json.shtml?city=北京":"http://www.weather.com.cn/data/sk/101110101.html")
.build();
Response response = client.newCall(request).execute();
ResponseBody body = response.body();
byte[] bytes = body.bytes();
String get = new String(bytes,"UTF-8");
Log.w("日志", "onRun: "+get);
}
@Override
protected void onCancel(int cancelReason, @Nullable Throwable throwable) {
}
@Override
protected RetryConstraint shouldReRunOnThrowable(@NonNull Throwable throwable, int runCount, int maxRunCount) {
Log.w("日志", "shouldReRunOnThrowable: 异常情况再次运行");
return null;
}
}
复制代码
- 自定义响应结果
public class Result implements Serializable{
private String data;
private int status;
private String message;
private String date;
private String city;
private int count;
}
复制代码
- 创建Job 并加入队列执行
private void query() {
// 开启网络线程执行该Job
// Params参数越大优先级越高
MyJob job = new MyJob(new Params(7).requireNetwork(), handler, "北京");
jobManager.addJobInBackground(job);
MyJob job1 = new MyJob(new Params(7).requireNetwork(), handler, "上海");
jobManager.addJobInBackground(job1);
}
复制代码
3.共同使用的其他依赖库
implementation 'com.squareup.okhttp:okhttp:2.0.0'
implementation 'com.google.code.gson:gson:2.2.4'