java中同步和异步有什么区别? Ajax请求中的async:false/true的作用?
概念:
Java中交互方式分为同步和异步两种:
同步交互:指发送一个请求,需要等待返回,然后才能够发送下一个请求,有个等待过程;
异步交互:指发送一个请求,不需要等待返回,随时可以再发送下一个请求,即不需要等待。
相同的地方:都属于交互方式,都是发送请求。
不同的地方:一个需要等待,一个不需要等待。
作用:
同步可以避免读脏数据的发生,一般共享某一资源的时候用,如果每个人都有修改权限,同时修改一个文件,有可能使一个人读取另一个人已经删除的内容,就会出错,同步就会按顺序来修改。但是同步会造成死锁。
死锁是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程。
异步则是可以提高效率了,现在cpu都是双核,四核,异步处理的话可以同时做多项工作,当然必须保证是可以并发处理的。
举例:
广播,就是一个异步例子。发起者不关心接收者的状态。不需要等待接收者的返回信息; 在部分情况下,我们的项目开发中都会优先选择不需要等待的异步交互方式。 |
电话,就是一个同步例子。发起者需要等待接收者,接通电话后,通信才开始。需要等待接收者的返回信息 比如银行的转账系统,对数据库的保存操作等等,都会使用同步交互操作。 |
阅读更多test.html
<a href="javascript:void(0)" onmouseover="testAsync()">
asy.js
function testAsync(){
var temp;
$.ajax({
async: false,
type : "GET",
url : 'tet.php',
complete: function(msg){
alert('complete');
},
success : function(data) {
alert('success');
temp=data;
}
});
alert(temp+' end');
}
tet.php
<?php
echo "here is html code";
sleep(5);
?>
async: false,(默认是true);
如上:false为同步,这个 testAsync()方法中的Ajax请求将整个浏览器锁死,
只有tet.php执行结束后,才可以执行其它操作。
当async: true 时,ajax请求是异步的。但是其中有个问题:testAsync()中的ajax请求和其后面的操作是异步执行的,那么当tet.php还未执行完,就可能已经执行了 ajax请求后面的操作,
如: alert(temp+' end');
然而,temp这个数据是在ajax请求success后才赋值的,结果,输出时会为空。
- ajax 异步请求 async:true;// true为异步,默认异步,false为同步
- Jquery(javascript)Ajax同步请求与异步区别(aysnc:true,false)
- Ajax请求中的async:false/true的作用(ajax返回值在外部调用问题)
- ajax同步异步 async默认为true 异步 async:false, //同步
- Ajax请求中的async:false/true的作用
- Ajax请求中的async:false/true的作用
- Ajax请求中的async:false/true的作用
- Ajax请求中的async:false/true的作用
- Ajax请求中的async:false/true的作用
- 火狐浏览器滚动条下拉到底部触发ajax出现闪屏的问题(Ajax请求中的async:false/true的作用)
- Ajax请求中的async:false/true的作用
- Ajax请求中的async:false/true的作用
- Ajax请求中的async:false/true的作用
- Ajax请求中的async:false/true的作用
- Ajax请求中的async:false/true的作用
- 详谈Ajax请求中的async:false/true的作用(ajax 在外部调用问题)
- Ajax请求中的async:false/true的作用
- Ajax请求中的async:false/true的作用
- Ajax请求中的async:false/true的区别
- Ajax请求中的async:false/true的作用