codecamp

Atom 如何使用Chromium快照

为了提高启动时间,在构建Atom时,会创建一个V8快照在该快照中预加载核心服务和包。然后,在运行时,我们通过提供编译阶段中没有的所有信息来完成加载(例如加载第三方包、定制样式表、配置等)。


电子链接是为快照提供动力的工具,因为它使我们能够遍历整个需求图(从入口点开始)并替换所有禁止的require调用(例如,要求调用本地模块,节点核心模块或其他模块,在快照V8上下文中访问)与一个将在运行时调用的函数。向Atom添加新代码时,我们总是尝试将其放入快照中,例如,在这些工具可用时,推迟使用DOM API或本地节点模块。如果无法做到这一点我们将向从快照中排除的文件列表中添加不受支持的代码路径, 以确保我们只排除那些不支持的、而不是跳过整个节点模块的程序。


电子链路的输出是一个单一的脚本,包含从入口点可到达的所有模块的代码, 然后供应 mksnapshot 以生成一个快照 blob。


生成的blob最终被复制到应用程序包中并在运行Atom时由Electron自动加载。

Atom 维护你的包
Atom 小结
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }