前端开发面试题—JavaScript执行机制(同步与异步,补充:线程与进程)

简介: 今天分享一下我遇到的一个面试题,是关于JavaScript执行机制——同步与异步的问题,解释一下什么是同步和异步呢?

 今天分享一下我遇到的一个面试题,是关于JavaScript执行机制——同步与异步的问题,解释一下什么是同步和异步呢?


🎯JavaScript单线程

    • JavaScript语言的一大特点就是单线程(Java多线程),也就是说,同一个时间只能做一件事。这是因为JavaScript这门脚本语言诞生的使命所致,即JavaScript是为处理页面中用户的交互,以及操作DOM而诞生的。比如,对某个DOM元素进行添加和删除操作,不能同时进行,那么这个DOM元素究竟是要添加还是删除呢?这会带来很复杂的同步问题,所以应该先进行添加,然后才删除,因此,JavaScript是单线程的。
    • 单线程就意味着,所有任务需要排队进行,前一个任务结束,才会执行后一个任务,这样所导致的问题是,如果JavaScript执行的时间过长,就会导致页面的渲染不连贯,导致页面渲染加载有阻塞的感觉,对于用户而言,阻塞就意味着"卡死",这样就导致了很差的用户体验。

    为了更好理解,他过下面这段代码来演示

    console.log('1')
    setTimeout(function(){
    console.log('2')
    },1000)
    console.log('3')
    image.gif

    上述代码输出为“1,3,2”,在控制台会看到程序先输出1、3,然后等待1秒后才会输出2。当调用setTimeout()方法后,该方法会立即执行完成,然后执行后面的代码,输出3。 但是为setTimeout()传入的函数,会在一秒后才执行(定时器)。像这样的操作称为异步操作,这个异步执行的函数称为回调函数,它的调用时机是由定时器来决定的。

    setTimeout()语法格式:setTimeout(调用的函数,[延迟的毫秒数])

    🎯JavaScript同步(Synchronous, sync)与异步(Asynchronous, async)

    为了更好的利用多核CPU的计算能力,HTML5提出Web Worker标准,运行JavaScript脚本创建多个线程,于是JavaScript出现了同步和异步的概念。

      • 所谓同步和异步:同步就是前一个任务执行完毕,才能继续执行下一个任务,程序的执行顺序与任务的排列顺序一致、同步的。异步是与同步相对的概念,就是在做一件事的同时,可以去处理其他事情。
      • 在我们学习的传统单线程编程中,程序的运行是同步的(同步不意味着所有步骤同时运行,而是指步骤在一个控制流序列中按顺序执行)。而异步的概念则是不保证同步的概念,也就是说,一个异步过程的执行将不再与原有的序列有顺序关系
        简单来理解就是:同步按你的代码顺序执行,异步不按照代码顺序执行,异步的执行效率更高
      • 同步任务都是在主线程上排队执行的任务,会形成一个执行栈,只有前一个任务执行完毕,才能继续执行下一个任务,而异步任务是通过回调函数实现的异步就是从主线程发射一个子线程来完成任务)。


      🎯补充:线程与进程

      ⏬二者联系

        • 线程是操作系统能够进行运算调度的最小单位(不能独立运动,必须依赖于进程)。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,(进程包含线程,每条线程并行执行不同的任务)一个进程中可以并发一个或多个线程,每条线程并行执行不同的任务。(计算机科学中的线程是同时运行多个任务或程序的执行。每个能够执行代码的单元称为线程)
        • 同一个进程中的线程是共享内存资源的,比如全局变量,每一个线程都可以改变其共同进程中的全局变量的数据

        ⏬二者区别

          • 线程是操作系统能够进行运算调度的最小单位(线程是独立调度和分派的基本单位)。进程是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。
          • 地址空间和其它资源(如打开文件):进程间相互独立,同一进程的各线程间共享。某进程内的线程在其它进程不可见。
          • 通信:进程间通信IPC,线程间可以直接读写进程数据段(如全局变量)来进行通信——需要进程同步和互斥手段的辅助,以保证数据的一致性。
          • 调度和切换:线程上下文切换比进程上下文切换要快得多。
          • 在多线程OS中,进程不是一个可执行的实体。
          • 进程下管理的最底层单位是线程,在等级上,进程明显大于线程。
          • 线程基本不拥有系统资源,它与其他线程共享同一进程所拥有的共同资源。由于线程比进程小,且基本不拥有系统资源,因此对其调度的开销会很小,从而极大的提高了对系统资源的利用率。
          • 当服务器需要响应多个用户请求时,如果创建多个进程,由于进程与进程之间是相互独立的,会过多的占用内存空间,降低服务器的响应速度,但线程是共享同一进程中的资源的,使用线程会提高系统的并发型。

          参考来自

          百度百科线程

          百度百科进程

          JavaScript异步编程

          博客园呆呆菇凉——进程和线程的区别和联系

          目录
          相关文章
          |
          2天前
          |
          监控 Java 应用服务中间件
          高级java面试---spring.factories文件的解析源码API机制
          【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
          14 2
          |
          26天前
          |
          消息中间件 并行计算 安全
          进程、线程、协程
          【10月更文挑战第16天】进程、线程和协程是计算机程序执行的三种基本形式。进程是操作系统资源分配和调度的基本单位,具有独立的内存空间,稳定性高但资源消耗大。线程是进程内的执行单元,共享内存,轻量级且并发性好,但同步复杂。协程是用户态的轻量级调度单位,适用于高并发和IO密集型任务,资源消耗最小,但不支持多核并行。
          40 1
          |
          5天前
          |
          并行计算 数据处理 调度
          Python中的并发编程:探索多线程与多进程的奥秘####
          本文深入探讨了Python中并发编程的两种主要方式——多线程与多进程,通过对比分析它们的工作原理、适用场景及性能差异,揭示了在不同应用需求下如何合理选择并发模型。文章首先简述了并发编程的基本概念,随后详细阐述了Python中多线程与多进程的实现机制,包括GIL(全局解释器锁)对多线程的影响以及多进程的独立内存空间特性。最后,通过实例演示了如何在Python项目中有效利用多线程和多进程提升程序性能。 ####
          |
          9天前
          |
          Linux 调度 C语言
          深入理解操作系统:进程和线程的管理
          【10月更文挑战第32天】本文旨在通过浅显易懂的语言和实际代码示例,带领读者探索操作系统中进程与线程的奥秘。我们将从基础知识出发,逐步深入到它们在操作系统中的实现和管理机制,最终通过实践加深对这一核心概念的理解。无论你是编程新手还是希望复习相关知识的资深开发者,这篇文章都将为你提供有价值的见解。
          |
          7天前
          |
          Java
          java小知识—进程和线程
          进程 进程是程序的一次执行过程,是系统运行的基本单位,因此进程是动态的。系统运行一个程序即是一个进程从创建,运行到消亡的过程。简单来说,一个进程就是一个执行中的程序,它在计算机中一个指令接着一个指令地执行着,同时,每个进程还占有某些系统资源如CPU时间,内存空间,文件,文件,输入输出设备的使用权等等。换句话说,当程序在执行时,将会被操作系统载入内存中。 线程 线程,与进程相似,但线程是一个比进程更小的执行单位。一个进程在其执行的过程中产生多个线程。与进程不同的是同类的多个线程共享同一块内存空间和一组系统资源,所以系统在产生一个线程,或是在各个线程之间做切换工作时,负担要比
          17 1
          |
          12天前
          深入理解操作系统:进程与线程的管理
          【10月更文挑战第30天】操作系统是计算机系统的核心,它负责管理计算机硬件资源,为应用程序提供基础服务。本文将深入探讨操作系统中进程和线程的概念、区别以及它们在资源管理中的作用。通过本文的学习,读者将能够更好地理解操作系统的工作原理,并掌握进程和线程的管理技巧。
          27 2
          |
          13天前
          |
          调度 Python
          深入浅出操作系统:进程与线程的奥秘
          【10月更文挑战第28天】在数字世界的幕后,操作系统悄无声息地扮演着关键角色。本文将拨开迷雾,深入探讨操作系统中的两个基本概念——进程和线程。我们将通过生动的比喻和直观的解释,揭示它们之间的差异与联系,并展示如何在实际应用中灵活运用这些知识。准备好了吗?让我们开始这段揭秘之旅!
          |
          18天前
          |
          Java
          线程池内部机制:线程的保活与回收策略
          【10月更文挑战第24天】 线程池是现代并发编程中管理线程资源的一种高效机制。它不仅能够复用线程,减少创建和销毁线程的开销,还能有效控制并发线程的数量,提高系统资源的利用率。本文将深入探讨线程池中线程的保活和回收机制,帮助你更好地理解和使用线程池。
          43 2
          |
          22天前
          |
          消息中间件 存储 Java
          Android面试高频知识点(2) 详解Android消息处理机制(Handler)
          Android面试高频知识点(2) 详解Android消息处理机制(Handler)
          |
          22天前
          |
          Java
          在Java多线程编程中,`wait()` 和 `notify()/notifyAll()` 方法是线程间通信的核心机制。
          在Java多线程编程中,`wait()` 和 `notify()/notifyAll()` 方法是线程间通信的核心机制。它们通过基于锁的方式,使线程在条件不满足时进入休眠状态,并在条件成立时被唤醒,从而有效解决数据一致性和同步问题。本文通过对比其他通信机制,展示了 `wait()` 和 `notify()` 的优势,并通过生产者-消费者模型的示例代码,详细说明了其使用方法和重要性。
          24 1