JavaScript调用栈

1:基本概念

栈(stack):用来保存简单的数据字段。

堆(heap):用来保存栈中简单的数据字段对指针的引用。

队列:是一种先进先出的线性数据结构。

函数的调用的进栈和出栈的顺序,遵循 先进后出 的原则。

空间分配: 堆:一般由程序员释放,如果程序员不释放就会在结束时由OS回收; 栈:一般由操作系统自动分配释放。

缓存方式: 堆:存放在二级缓存中,生命周期一般是由虚拟机的垃圾回收算法决定的; 栈:存放在一级缓存中,被调用时处于存储空间,调用完立即释放。

操作数据:堆栈(先进后出),队列(先进先出)。

调用栈是一种栈结构,它用来存储计算机程序执行时候其活跃子程序的信息。它是一种LIFO的数据结构,将记录代码运行时的执行上下文。当遇到某个函数的调用语句时,它将会记录当前的执行上下文,将函数入栈,并为其创建一个新的执行上下文。(比如什么函数正在执行,什么函数正在被这个函数调用等等信息)。

调用栈是解析器的一种机制。

javascript是一门单线程语言,主线程在同一时间只能处理一件事。那javascript是如何处理处理函数的调用关系的?

答案是——调用栈。

2:Event Loop(事件循环)

JavaScript是一个单线程,它执行的所有代码都放在下面这个Call Stack里面,当Call Stack执行完毕之后,就会再右侧的队列里面找任务,如果有微任务,就会先执行微任务,再去执行宏任务。

事件循环:就是同步任务进入主线程,异步任务加入到任务队列中。等主线程的任务执行完就去执行任务队列中的任务,这个过程会不断重复。所有同步任务都在主线程上执行,形成一个执行栈。主线程之外, 存在一个任务队列(task queue), 异步任务有了运行结果会在任务队列之中放置一个任务。执行栈中的所有同步任务执行完毕后读取任务队列(先读取微任务、宏任务)不断重复上面的第三步。

js既然是单线程那么肯定是排队执行代码,怎么去排这个队就是Event Loop,虽然js是单线程但是浏览器不是单线程。

    console.log('script start');
    
    setTimeout(function() {
        console.log('timeout1');
    }, 10);
    
    new Promise(resolve => {
        console.log('promise1');
        resolve();
        setTimeout(() => console.log('timeout2'), 10);
    }).then(function() {
        console.log('then1')
    })
    
    console.log('script end');
    
    //
    * script start
    * promise1
    * script end
    * then1
    * timeout1
    * timeout2

3:宏任务(Mask-task)

  • setTimeout
  • setInterval
  • I/O

特点:由JavaScript线程外的宿主线程执行,比如,定时器触发线程setTimeout、setInterval,异步http请求线程。JavaScript线程不空闲宏任务永远没有执行机会。

    for(let i=0; i<100000000; i++) {}
    
    setTimeout(function() {
        console.log('setTimeout1');
    }, 1000);
    
    setTimeout(function() {
        console.log('setTimeout2');
    }, 2000);

4:微任务(Mask-task)

  • promise

特点:由JavaScript线程维护,它的执行时机是在主线程所有可执行代码执行完成后执行,浏览器渲染DOM前会全部执行。

转载于:https://my.oschina.net/u/4144971/blog/3078160

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用JavaScript调用C#的方法,可以使用以下几种方法: 1. 使用Ajax请求:在JavaScript中使用Ajax技术向服务器发送请求,然后服务器端使用C#处理请求并返回结果。这种方法适用于在客户端通过异步请求调用服务器端的C#方法。 ```javascript $.ajax({ type: "POST", url: "MyPage.aspx/MyMethod", data: JSON.stringify({ parameter: "Hello" }), contentType: "application/json; charset=utf-8", dataType: "json", success: function(result) { console.log(result.d); // 输出返回结果 }, error: function(xhr, status, error) { console.log(error); // 输出错误信息 } }); ``` 在C#中,创建一个可供JavaScript调用的静态方法: ```csharp using System.Web.Services; public class MyPage : System.Web.UI.Page { [WebMethod] public static string MyMethod(string parameter) { // 执行一些逻辑 return "Hello, " + parameter; } } ``` 2. 使用SignalR:SignalR是一个实时应用程序框架,可以在客户端和服务器之间建立双向通信。你可以在服务器端使用C#编写代码,并在客户端使用JavaScript通过SignalR调用服务器端的方法。 首先,安装SignalR NuGet包。然后,在服务器端创建一个Hub类: ```csharp using Microsoft.AspNet.SignalR; public class MyHub : Hub { public string MyMethod(string parameter) { // 执行一些逻辑 return "Hello, " + parameter; } } ``` 在客户端使用JavaScript连接到SignalR Hub,并调用服务器端的方法: ```javascript // 引用SignalR库 <script src="~/Scripts/jquery.signalR-2.4.1.min.js"></script> <script src="/signalr/hubs"></script> // 连接到SignalR Hub var hub = $.connection.myHub; // 定义客户端方法 hub.client.myMethodResponse = function(result) { console.log(result); // 输出返回结果 }; // 开始连接 $.connection.hub.start().done(function() { // 调用服务器端方法 hub.server.myMethod("Hello"); }); ``` 这些是通过JavaScript调用C#方法的两种常见方法。具体使用哪种方法取决于你的应用程序需求和技术

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值