JavaScript学习-5——异步同步、回调函数
----------异步同步函数
----------回调函数
一、异步同步函数
同步:发送一个请求,等待返回,然后再发送下一个请求
异步:发送一个请求,不等待返回,随时可以再发送下一个请求
同步可以避免出现死锁,读脏数据的发生,一般共享某一资源的时候用,如果每个人都有修改权限,同时修改一个文件,有可能使一个人读取另一个人已经删除的内 容就会出错,同步就会按顺序来修改。
异步则是可以提高效率了,现在cpu都是双核,四核,异步处理的话可以同时做多项工作,当然必须保证是可以并发处理的。
这些都是对的。
同步和异步最大的区别就在于。一个需要等待,一个不需要等待。
比如广播,就是一个异步例子。发起者不关心接收者的状态。不需要等待接收者的返回信息
电话,就是一个同步例子。发起者需要等待接收者,接通电话后,通信才开始。需要等待接收者的返回信息
异步代码:
function a(){
console.log("执行a函数");
setTimeout(function(){
console.log("执行a函数的间隔")
},2000)
}
function b(){
console.log("执行b函数");
}
a();
b();
运行代码时优先执行a函数,并且a的延迟调用前执行b函数,最后执行a的 延迟函数,所以即使,时间设置为0,也是会照样先执行函数b
=> 
并且:
调用 setTimeout 函数会在一个时间段过去后在队列中添加一个消息。这个时间段作为函数的第二个参数被传入。如果队列中没有其它消息,消息会被马上处理。但是,如果有其它消息,setTimeout 消息必须等待其它消息处理完。因此第二个参数仅仅表示最少的时间 而非确切的时间,所以即使,时间设置为0,也是会照样先执行函数b.
同步代码
var a = 0;
function one(){
a=1;
console.log(a);
}
function two(){
console.log(a);
}
one();
two();
two函数会等one函数完成之后去执行,所以结构输出为1,因为one函数修改了全局变量a的值,one执行之后才执行的two函数;
二、回调函数
回来调用,把函数作为参数使用
回调函数是作为参数传递给另一个函数并在其父函数完成后执行的函数。
所以回调与同步、异步并没有直接的联系,回调只是一种实现方式,既可以有同步回调,也可以有异步回调,还可以有事件处理回调和延迟函数回调,这些在我们工作中有很多的使用场景
始终记着callback,只是一个形参名字而已.
观察下面几个例子
举例普通函数及调用:
function plus(){
console.log("函数plus被执行");
}
plus();
输出结果为:

另一种方法:
var num = plus;
num();
function plus(){
console.log("函数plus被执行");
}
同样输出结果为:

复杂点的例子: operation即为回调,传进来的函数就是回调函数
var num = mathc(10,5,minus);//运算过程就是operation=minus=function(a,b){return a+b;}
console.log(num);
function mathc(a,b,operation){ //operation意思是运算,作为形参
//把10,5,minus传递给mathc函数,其中minus作为一个函数方法
var number = operation(a,b);
//然后把a,b传递给minus函数,以上语句的本质就是 minus(a,b);
return number;
}
//以下为运算方式的函数
function plus(a,b){
return a+b;
}
function minus(a,b){
return a-b;
}
输出结果为:

看上去很乱,我们来解析一下过程:
①首先10,5,minus作为参数传递给函数mathc,而此时minus则是minus函数的整体内容
输出一下minus为:

②然后var number = operation(a,b)的语句,就是operation=minus,即为var number = minus(a,b); minus是函数而括号内则代表了形参如果写代码就如下:
var number = function minus(a,b){
return 10-5;
}
③最后调用函数mathc
mathc(10,5,minus)即为:传递了三个参数a,b以及minus函数,而函数的形参就是operation
JavaScript学习-5——异步同步、回调函数的更多相关文章
- 6.26学习 异步委托回调函数 VS 多线程 VS 并行处理
描述: 我现在是轮询着构建实例,然后这个实例去执行一个方法,但是执行方法需要大约10s时间,全部轮询下来需要很长时间.所以我现在要更改,头给了我两个方法,1多线程 2异步委托回调函数. 异步委托回调函 ...
- python 并发编程 同步调用和异步调用 回调函数
提交任务的两张方式: 1.同步调用 2.异步调用 同步调用:提交完任务后,就在原地等待任务执行完后,拿到结果,再执行下一行代码 同步调用,导致程序串行执行 from concurrent.future ...
- javascript es6 Promise 异步同步的写法(史上最简单的教程了)
1 来个简单的例子 var p = new Promise(function(resolve, reject){ //做一些异步操作 setTimeout(function(){ console.lo ...
- JavaScript学习笔记(十二) 回调模式(Callback Pattern)
函数就是对象,所以他们可以作为一个参数传递给其它函数: 当你将introduceBugs()作为一个参数传递给writeCode(),然后在某个时间点,writeCode()有可能执行(调用)intr ...
- JavaScript学习总结-技巧、有用函数、简洁方法、编程细节
整理JavaScript方面的一些技巧.比較有用的函数,常见功能实现方法,仅作參考 变量转换 //edit http://www.lai18.com var myVar = "3.14159 ...
- JavaScript学习总结-技巧、实用函数、简洁方法、编程细节
整理JavaScript方面的一些技巧,比较实用的函数,常见功能实现方法,仅作参考 变量转换 var myVar = "3.14159", str = ""+ ...
- javascript总结29 :递归与回调函数
1 递归函数 -递归的实质就是函数自己调用自己. -递归注意点:递归必须有跳出条件,否则是死循环. var i = 1; fn(); function fn(){alert("从前有座山,山 ...
- C# 异步委托回调函数使用
using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threa ...
- 异步编程(回调函数,promise)
一.回调函数 ①概念:一般情况下,程序会时常通过API调用库里所预先备好的函数.但是有些库函数却要求应用先传给它一个函数,好在合适的时候调用,以完成目标任务.这个被传入的.后又被调用的函数就称为回调函 ...
随机推荐
- 使用Postfix与Dovecot部署邮件系统
- 明令禁止下,哪些APP在违规获取用户信息?
2019年4月28日消息 移动互联网时代各大APP大行其道,用户为了更便捷地享受互联网服务,常常需要让渡部分个人信息.在信息获取不透明的情况下,不少APP运营企业出现过度获取乃至违规获取用户信息的情 ...
- 20165308『网络对抗技术』Exp5 MSF基础应用
20165308『网络对抗技术』Exp5 MSF基础应用 一.原理与实践说明 实践内容 本实践目标是掌握metasploit的基本应用方式,重点常用的三种攻击方式的思路.具体需要完成: 一个主动攻击实 ...
- docker mysql8 注意
1. mysql8 出了有段时间了,但公司项目的django还不支持mysql8的默认加密方式. 连接时报错 Error : The server requested authentication m ...
- 在虚拟机上配置安装hadoop集群
原本以为有大神已经总结的很清楚了,就不自己在写了, 但是在自己安装的过程中还是出现了一些问题, 所以打算以自己的方式重新总结一下. 参考https://blog.csdn.net/hliq539 ...
- Stripes视图框架实现纯Java代码控制表现层参考文档
https://blog.csdn.net/boonya/article/details/14101477 Stripes是一个开放源码的Web应用程序框架的基础上的模型 - 视图 - 控制器(MVC ...
- delphi 各版本的特性
delphi 各新版本特性收集 Delphi XE6新增了一些特性并增强了原有的功能,主要有以下几个方面: IDE(整合开发环境) Internet XML(扩展标记语言) Compiler( ...
- Nginx配置CI框架问题(Linux平台下Centos系统)
CI框架:官方文档 http://codeigniter.org.cn/user_guide/index.html CI框架的数据流程图如下: 其中:index.php作为入口文件,在安装好CI框架后 ...
- 后台文本编辑器KindEditor介绍
后台文本编辑器KindEditor介绍 我们在自己的个人主页添加文章内容的时候,需要对文章内容进行修饰,此时就需要文本编辑器助阵了! 功能预览 KindEditor文本编辑器 KindEditor文本 ...
- [UE4]线性插值Lerp