我的理解如下:

同步: 实时的在等待返回结果;

异步:可以不是同步执行的,放入到执行队列中。

所以建议:如果需要根绝请求的结构做些判断应当用 同步,异步可能由于时间先后出现问题。

/*post异步请求: postDataWithParame*/
private int ispower() { power = 0;
OkHttpClient client = new OkHttpClient();//创建OkHttpClient对象。
FormBody.Builder formBody = new FormBody.Builder();//创建表单请求体
formBody.add("username","ansen");//传递键值对参数
formBody.add("password","123"); //传递键值对参数
Request request = new Request.Builder()//创建Request 对象。
.url("http://172.25.1.234:8080/DormitoryHelper/user/login")
.post(formBody.build())//传递请求体
.build();
client.newCall(request).enqueue(new Callback() { //回调方法的使用与get异步请求相同。
@Override
public void onFailure(Call call, IOException e) {
rtdate = "请求失败";
} @Override
public void onResponse(Call call, Response response) throws IOException {
if(response.isSuccessful()){//回调的方法执行在子线程。
Log.d("kwwl","获取数据成功了");
Log.d("kwwl","response.code()=="+response.code());
String rt = response.body().string();
rtdate = rt;
Log.d("kwwl","response.body().string()==" + rt);
if(rt.equals("1")){
power = 1; //有权限
}
else{
power = Integer.valueOf(rt); //无权限
}
}
}
});
return power;
} /*post同步请求: postDataWithParame */
public void ispower_tongbu(){
new Thread(new Runnable() {
@Override
public void run() {
try {
OkHttpClient client = new OkHttpClient();//创建OkHttpClient对象
FormBody.Builder formBody = new FormBody.Builder();//创建表单请求体
formBody.add("username","ansen");//传递键值对参数
formBody.add("password","123"); //传递键值对参数 Request request = new Request.Builder()
.url("http://172.25.1.234:8080/DormitoryHelper/user/login")
.post(formBody.build())//传递请求体
.build();
Response response = null;
response = client.newCall(request).execute();//得到Response 对象
if (response.isSuccessful()) {
Log.d("kwwl","获取数据成功了");
Log.d("kwwl","response.code()=="+response.code());
String rt = response.body().string();
rtdate = rt;
Log.d("kwwl","response.body().string()==" + rt);
if(rt.equals("1")){
power = 1; //有权限
}
else{
power = 0; //无权限
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}).start();
} /*************提示框*******************/
private void showExitDialog1(String num){
// String rt = String.valueOf(num);
new AlertDialog.Builder(this)
.setTitle("提示")
.setMessage("您没有修改权限" + num)
.setPositiveButton("确定", null)
.show();
}
private void showExitDialog(){
new AlertDialog.Builder(this)
.setTitle("提示")
.setMessage("您没有修改权限")
.setPositiveButton("确定", null)
.show();
} @Override
public void onStopTrackingTouch(SeekBar seekBar) {
int x = 0;
switch (seekBar.getId()) {
case R.id.sb_data_uptime_h: ispower_tongbu();
if(power == 1){
sendCommand(KEY_UPTIME_H, (seekBar.getProgress() + UPTIME_H_OFFSET ) * UPTIME_H_RATIO + UPTIME_H_ADDITION);
}
else{
//没有权限
// showExitDialog1(String.valueOf(pr_data_uptime_h));
showExitDialog1(power+ "------power");
showExitDialog1(x + "-----x");
showExitDialog1(rtdate + "-----data");
showExitDialog();
tv_data_uptime_h.setText(String.valueOf(pr_data_uptime_h));
sb_data_uptime_h.setProgress(pr_data_uptime_h);
}
break;
case R.id.sb_data_uptime_m:
ispower_tongbu();
if(power == 1) {
sendCommand(KEY_UPTIME_M, (seekBar.getProgress() + UPTIME_M_OFFSET) * UPTIME_M_RATIO + UPTIME_M_ADDITION);
}
else{
//没有权限
// showExitDialog1(String.valueOf(pr_data_uptime_m));
showExitDialog();
tv_data_uptime_m.setText(String.valueOf(pr_data_uptime_m));
sb_data_uptime_m.setProgress(pr_data_uptime_m);
}
break;
default:
break;
}
}

  

10-okHttp的同步与异步的更多相关文章

  1. .NET Core采用的全新配置系统[10]: 配置的同步机制是如何实现的?

    配置的同步涉及到两个方面:第一,对原始的配置文件实施监控并在其发生变化之后从新加载配置:第二,配置重新加载之后及时通知应用程序进而使后者能够使用最新的配置.要了解配置同步机制的实现原理,先得从认识一个 ...

  2. ASP.NET WebAPi(selfhost)之文件同步或异步上传

    前言 前面我们讲过利用AngularJs上传到WebAPi中进行处理,同时我们在MVC系列中讲过文件上传,本文结合MVC+WebAPi来进行文件的同步或者异步上传,顺便回顾下css和js,MVC作为客 ...

  3. socket阻塞与非阻塞,同步与异步、I/O模型,select与poll、epoll比较

    1. 概念理解 在进行网络编程时,我们常常见到同步(Sync)/异步(Async),阻塞(Block)/非阻塞(Unblock)四种调用方式: 同步/异步主要针对C端: 同步:      所谓同步,就 ...

  4. WCF的同步和异步(以WPF连接为例)

    2016-06-0711:05:44 在学习WCF时,学到WCF服务的同步和异步. 我理解的同步是: 当WCF服务是同步执行时,程序只有一条线程,代码只能按顺序一步一步来执行,当执行客户端/服务端某方 ...

  5. socket阻塞与非阻塞,同步与异步

    socket阻塞与非阻塞,同步与异步 作者:huangguisu 转自:http://blog.csdn.net/hguisu/article/details/7453390 1. 概念理解 在进行网 ...

  6. Python番外之 阻塞非阻塞,同步与异步,i/o模型

    1. 概念理解 在进行网络编程时,我们常常见到同步(Sync)/异步(Async),阻塞(Block)/非阻塞(Unblock)四种调用方式: 同步/异步主要针对C端: 同步:      所谓同步,就 ...

  7. 阻塞与非阻塞、同步与异步 I/O模型

    I/O模型 Linux 下的五种I/O模型 阻塞I/O(blocking I/O) 非阻塞I/O (nonblocking I/O) I/O复用(select 和poll) (I/O multiple ...

  8. js的事件循环机制:同步与异步任务(setTimeout,setInterval)宏任务,微任务(Promise,process.nextTick)

    javascript是单线程,一切javascript版的"多线程"都是用单线程模拟出来的,通过事件循环(event loop)实现的异步. javascript事件循环 事件循环 ...

  9. js回调函数以及同步与异步

    1. 背景介绍javascript的单线程特性由于javascript语言是一门“单线程”的语言,所以,javascript就像一条流水线,仅仅是一条流水线而已,要么加工,要么包装,不能同时进行多个任 ...

  10. C#中委托的同步和异步有什么区别

    通过定义委托,来实现同步和异步,委托通过Action和Func来实现,记录学习委托的同步和异步的过程 委托的同步方法 委托的Invoke方法用来进行同步调用. static void Main(str ...

随机推荐

  1. 减少mysql主从数据同步延迟

    网上给出的解决办法: 基于局域网的master/slave机制在通常情况下已经可以满足'实时'备份的要求了.如果延迟比较大,就先确认以下几个因素:1. 网络延迟2. master负载3. slave负 ...

  2. C++ new 和malloc 区别

    1.分配地方不同,malloc是堆上面,new是自由存储区域 2.malloc/delete是函数,new/delete是操作符,可以重载 3.malloc 要指定大小,返回的是void*指针,开辟的 ...

  3. 自行编译mwan加入openwrt里

    参考源文:http://www.right.com.cn/forum/thread-124449-1-1.html 本例以 opoenwrt 12.09正式版为例,原软件来自openwrt 英文论坛: ...

  4. 创建一个Maven Web应用程序

    1 在Eclipes创建maven,首先File new ,在other 中找到Maven,Maven Project,下一步选择WebApp,创建Maven工程名字,完成 2 在新建的Maven工程 ...

  5. 434. Number of Segments in a String

    原题: 434. Number of Segments in a String 解题: 刚看到题目时,觉得可以通过统计空格个数,但想想有可能会有多个空格的情况 思路: 一:遍历字符,if条件碰到非空格 ...

  6. 21 week4 submit buidAndRun() node-rest-client

    . 我们想实现一个提交代码的功能 这个功能有nodeserver 传到后边的server 验证 在返回给nodeserver 我们稍微修改一下ui ATOM修改文件权限不够 用下面命令 我们 Cont ...

  7. 通过日志恢复SQL Server的历史数据

    通过日志恢复SQL Server的历史数据 Posted on 2008-11-14 21:47 代码乱了 阅读(4658) 评论(10)  编辑 收藏 园子里前段时间发过一篇通过日志恢复MSSQL数 ...

  8. shiro 认证思路

  9. 微信小程序----搜索框input回车搜索事件

    在微信小程序里的搜索框,按软键盘回车键触发搜索事件. <input type="text"  placeholder="搜索" value="{ ...

  10. hibernate 性能问题

    hibernate的目标是快速开发,数据库数据转换为java对象,业务逻辑中只使用对象进行处理. 性能开销有: 数据-对象转换时间,状态记录(是否为脏数据),sql优化(默认是对表字段全部更新,增加网 ...