JS线程机制与事件机制
JS线程机制与事件机制
1.进程与线程
(1).定义:
进程:程序的一次执行,它占有一片独有的内存空间
CPU的基本调度单位,是程序执行的一个完整的流程
(2).进程与线程的关联
一个进程一般至少有一个运行的线程:主线程
一个进程可以运行多个线程
一个进程内的数据可以供其中的多个线程共享
多个线程之间的数据是不能直接共享的
(3).浏览器基本上是多进程的
2.浏览器内核
(1).定义:支持浏览器运行的最核心的程序
(2).不同的浏览器运行的内核不同
Chrome,Safari:webkit
firefox:Gecko
IE:Trident
国内浏览器360等:Trident + webkit
(3).内核组成的模块:
html,css文档解析模块:负责页面文本的解析
dom/css模块: 负责dom/css在内存中的相关处理
布局和渲染模块:负责页面的布局和效果的绘制
定时器模块:负责定时器的管理
网络请求模块:负责服务器请求(Ajax)
事件响应模块:负责事件的管理
3.定时器
(1)分类:
循环定时器:不关闭一直执行
延时定时器:一定时间后才执行,只执行一次
(2)循环定时器:setInterval
var i = 0;
//获得定时器句柄
var intervalId = setInterval(function(){
if (i >= 5) {
//清除定时器
clearInterval(intervalId);
}
console.log(Date.now());
i++;
},1000);
(3)延时定时器:
setTimeout(function(){
console.log("----");
},2000);
4.JS是单进程的
(1)证明:
使用setTimeout()回调函数在主线程运行
定时器回调函数只有在运行栈中的代码全部执行完毕后才可能执行
(2)为什么js要使用单线程模式:
作为浏览器的脚本语言主要目的是和用户交互,以及操作DOM,单线程会避免复杂的同步问题
(3)代码分类:
初始化代码
回调代码
(4)JS引擎执行代码的基本流程
先执行初始化代码:包括一些特别的代码:
设定定时器
绑定监听
发送Ajax请求
在某一时刻执行回调代码
5.事件循环模型
执行流程:
1.同步任务加载执行
初始化代码:绑定监听,设置定时器,发送ajax请求
2.异步任务交给时间管理模块
3.管理模块监听异步任务是否满足条件,如果满足条件就会将对应的任务放入callback queue中
4.主线程同步任务执行完成后通过event loop(事件轮询机制)询问callback queue
有可执行的回调函数,就将回调函数放入主线程中执行
如果没有待会再来询问
6.Web Workers:(需要开启服务器)
(1)提供了js分线程实现
(2)相关API:
Worker:构造函数,加载分线程执行的js文件
Worker.prototype.onmessage:用于接收另一个线程的回调函数
Worker.prototype.postMessage:向另一个线程发送信息
(3)不足:
不能操作DOM(不能更新UI)
不能跨域加载JS
不是每一个浏览器都支持这个新特性
(4)代码:
在主线程html中编写
<input type="text" id="number" value="30">
<button id="btn">计算斐波那契数</button>
<script type="text/javascript"> document.getElementById("btn").onclick = function(){
var value = document.getElementById("number").value; //获得分线程
var worker = new Worker("./work.js"); //发送给分线程数据
worker.postMessage(value);
//接收分线程数据
worker.onmessage = function(event){
console.log(event.data);
} }
</script>
在同一级目录下work.js
function fibonacci(num){
return num > 2 ? fibonacci(num - 1) + fibonacci(num - 2) : 1;
} var onmessage = function(event){
console.log("分线程监视...."); //获取主线程发送过来的数据
var data = event.data; //分线程处理数据
data = fibonacci(data); //返回数据给主线程
postMessage(data);
};
执行结果:
不会卡住主进程界面,大批量计算在分线程中执行。
JS线程机制与事件机制的更多相关文章
- QT源码之Qt信号槽机制与事件机制的联系
QT源码之Qt信号槽机制与事件机制的联系是本文要介绍的内容,通过解决一个问题,从中分析出的理论,先来看内容. 本文就是来解决一个问题,就是当signal和slot的连接为Qt::QueuedConne ...
- [JS]笔记12之事件机制--事件冒泡和捕获--事件监听--阻止事件传播
-->事件冒泡和捕获-->事件监听-->阻止事件传播 一.事件冒泡和捕获 1.概念:当给子元素和父元素定义了相同的事件,比如都定义了onclick事件,点击子元素时,父元素的oncl ...
- 锁机制(Lock) 信号量机制(Semaphore) 事件机制(Event)
IPC 进程间通信(inter-Process Communicate) 锁机制(Lock) l = Lock() 开启一个锁机制(实例化) 一把锁配一个钥匙 l.acquire() 获得钥匙 ...
- 剖析Qt的事件机制原理
版权声明 请尊重原创作品.转载请保持文章完整性,并以超链接形式注明原始作者“tingsking18”和主站点地址,方便其他朋友提问和指正. QT源码解析(一) QT创建窗口程序.消息循环和WinMai ...
- Atitit 数据库的事件机制--触发器与定时任务attilax总结
Atitit 数据库的事件机制--触发器与定时任务attilax总结 1.1. 事件机制的图谱1 2. 触发器的类型2 3. 实现原理 After触发器 Vs Instead Of触发器2 3.1. ...
- ALSA声卡驱动中的DAPM详解之七:dapm事件机制(dapm event)
前面的六篇文章,我们已经讨论了dapm关于动态电源管理的有关知识,包括widget的创建和初始化,widget之间的连接以及widget的上下电顺序等等.本章我们准备讨论dapm框架中的另一个机制:事 ...
- Node js 安装+回调函数+事件
/* 从网站 https://nodejs.org/zh-cn/ 下载 这里用的 9.4.0 版本 下载完安装 安装目录是 D:\ApacheServer\node 一路默认安装 安装后打开cmd命令 ...
- Node.js实战(九)之事件循环
Node.js 是单进程单线程应用程序,但是因为 V8 引擎提供的异步执行回调接口,通过这些接口可以处理大量的并发,所以性能非常高. Node.js 几乎每一个 API 都是支持回调函数的. Node ...
- Node.js入门:事件机制
Evented I/O for V8 JavaScript 基于V8引擎实现的事件驱动IO. 事件机制的实现 Node.js中大部分的模块,都继承自Event模块(http://n ...
随机推荐
- 如何解决Requests的SSLError(转)
add by zhj: 我使用方法2“更新系统的certificate”解决了问题 原文:https://www.jianshu.com/p/8deb13738d2c 这两天在Linux上爬Googl ...
- Linux中最大进程数和最大文件数
前言 Linux系统中可以设置关于资源的使用限制,比如:进程数量,文件句柄数,连接数等等. 在日常的工作中应该遇到过: -bash: fork: retry: Resource temporarily ...
- 系统压测结果对比:tomcat/thinkphp/swoole/php-fpm/apache
[测试所用服务器8核,16G内存]压测接口:很简单,从一张表里根据主键随机查询出一条数据[数据库服务器和WEB服务器分开的].表数据量大概:910000+条. 这个测试结果很有趣:tp5.0和3.2性 ...
- eclipse从svn检出maven项目
使用Eclipse从svn检出项目. 打开Eclipse,在project explorer空白区域右键鼠标移至import选择import. 2 之后选择svn-->从svn检出项目,然后输入 ...
- (7)ASP.NET Core 中的错误处理
1.前言 ASP.NET Core处理错误环境区分为两种:开发环境和非开发环境.●开发环境:开发人员异常页.●非开发环境:异常处理程序页.状态代码页.在Startup.Configure方法里面我们会 ...
- C# 使用SuperSocket
一.需求场景 (1)使用SuperSocket进行网络通信 二.所需软件 (1)SocketTool 三.实现步骤 (1)使用Nuget管理器安装SuperSocket.Engine 该插件已经包 ...
- Mycat分布式数据库架构解决方案--Mycat实现数据库分表
echo编辑整理,欢迎转载,转载请声明文章来源.欢迎添加echo微信(微信号:t2421499075)交流学习. 百战不败,依不自称常胜,百败不颓,依能奋力前行.--这才是真正的堪称强大!!! 准备工 ...
- 玩转zynq7020之风速风向测量实战项目
本文是用米尔zynq7020开发板(Z-turn broad)风速风向测量实战项目. 这次项目是以测量风速风向为目标的产品,由于传统的风杯有很大的缺陷,在零下20度,结冰后不能使用,还有启动风速等等, ...
- JavaScript 之 事件(详解)
一.注册事件的三种方式 1.直接事件方式 语法格式: 变量名.on事件名 = function() {} 注意:这种方式无法给同一对象的同一事件注册多个事件处理函数 2.addEventListene ...
- eclipse 小提示
1.模糊提示插件 Code Recommenders alt+/ 模糊提示插件 Code Recommenders