博客
关于我
读《深入浅出Nodejs-朴灵》笔记
阅读量:85 次
发布时间:2019-02-26

本文共 1293 字,大约阅读时间需要 4 分钟。

起源

2020年8月,我在微信读书上阅读了一本关于Node.js的书籍。当时我刚开始接触前端开发,了解到了“大前端”的概念。这个概念让我兴奋,因为它试图将JavaScript从前端扩展到后端,让前端开发人员也能学习后端开发,从而降低后端开发的学习门槛。 在那段时间里,我学习了Node.js的基础语法,包括模块的编写和引入、服务的创建以及端口号的配置。虽然当时我已经遗弃了Node.js,存放在Baidu网盘上,但今年的一次机会让我重新接触这门技术。公司的项目需要用Node.js来写后端接口,我也有机会与写后端的同事一起负责项目。作为主干前端开发人员,我在项目进入1.0阶段后,等待1.5版本迭代的空窗期,公司另一个项目需要同事回去写Java,我临时被派驻负责后台接口的开发。尽管我对MySQL感到忐忑,但老板鼓励我慢慢来,我最终接受了挑战。

发展

回到书本后,我重新开始系统地学习Node.js。与入门教程不同,这本书不仅详细介绍了Node.js的作者和创作历程,还探讨了未来的发展方向。目前我已经阅读了前三章,虽然有些知识点需要反复理解和消化,但通过查阅百度资料和反复思考,我逐渐掌握了这些概念,并将一些关键点整理后分享到CSDN。

笔记

  • 模块

    模块在Node.js中是组织代码的基本单元。通过exportsmodule.exports,我们可以将函数或变量向外暴露供其他模块使用。例如:

    exports.FN = function () {    // todo  };

    或者:

    module.exports = {    func () {      // todo    }  };
  • 路径索引缓存

    Node.js会对文件路径进行缓存,这意味着即使文件结构发生变化,路径查询的性能也不会显著下降。这种机制使得文件操作更加高效。

  • async/await

    async/await是Node.js处理异步操作的优雅方式。通过await,可以将 promise 响应的数据逐步解构,实现更直观的异步流程。例如:

    async function fun () {    const A = await p_fun();    const B = await p_func(A);    const C = await p_func1(B);  }

    fun()函数会等待p_fun()返回一个Promise,A是resolve后的数据,依此类推。

  • IO类型

    • 阻塞IO:当Node.js执行一次IO操作时,它会等待数据返回后再继续下一次IO调用。
    • 非阻塞IO:Node.js会立即返回IO操作的状态码,并在状态码返回后继续执行下一次IO操作以获取完整数据。
  • 单线程与线程池

    Node.js采用单线程模型,但线程池可以帮助分配和调度工作线程(n)来处理I/O任务。主线程负责工作线程的调度,而各工作线程则专注于特定的任务。

  • 通过这本书的学习,我对Node.js的理解更加深入,尤其是模块化、异步操作和性能优化方面的知识。这段学习经历让我对后端开发有了全新的认识,也让我意识到持续学习的重要性。

    转载地址:http://zgdk.baihongyu.com/

    你可能感兴趣的文章
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>
    NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
    查看>>
    NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
    查看>>
    NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
    查看>>
    NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>
    NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
    查看>>
    NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
    查看>>
    NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
    查看>>
    NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
    查看>>
    NIH发布包含10600张CT图像数据库 为AI算法测试铺路
    查看>>
    Nim教程【十二】
    查看>>