ChakraCore 开源项目安装与使用指南

ChakraCore 开源项目安装与使用指南

ChakraCoreChakraCore is an open source Javascript engine with a C API.项目地址:https://gitcode.com/gh_mirrors/ch/ChakraCore


1. 项目目录结构及介绍

ChakraCore 是一个开放源代码的 JavaScript 引擎,它带有 C API,允许开发者在其应用程序中嵌入JavaScript运行环境。以下是其主要的目录结构和重要组成部分:

.
├── azure-pipelines.yml             # Azure Pipelines 的持续集成配置文件
├── Build                            # 包含Visual Studio解决方案和其他构建脚本
│   └── ChakraCore.sln               # 主解决方案文件,用于在Windows上构建ChakraCore
├── contrib                          # 贡献者相关文档和协议文件
│   ├── CONTRIBUTING.md              # 贡献指南
│   └── ContributionAgreement.md
├── deps/ChakraICU                   # ICU库依赖,用于国际化支持
├── lib                              # 库文件,编译后的输出可能会存放于此
├── manifests                        # 相关清单或配置文件
├── pal                              # 平台抽象层代码
├── test                             # 测试套件
├── tools                            # 构建和测试工具
├── cirrus.yml                       # 可能是用于CI/CD的特定配置
├──.editorconfig                     # 编辑器配置文件
├──.gitattributes                    # Git属性文件
├──.gitignore                        # 忽略文件列表
├──CMakeLists.txt                    # CMake构建系统的配置文件,用于非Windows平台
├──LICENSE.txt                       # 许可证文件,说明软件使用的MIT许可证
├──README.md                         # 项目的简介和快速入门指导
└──THIRD-PARTY-NOTICES.txt           # 第三方组件及版权声明

注意:具体文件夹的功能可能随项目更新有所变化,请参考最新版本的官方文档。

2. 项目的启动文件介绍

  • 在完成编译之后,ChakraCore的核心测试和执行环境主要通过命令行工具来启动。对于开发人员来说,最重要的“启动文件”实际上是编译后的ch.exe(Windows)或同名的Linux和macOS等效程序。这个轻量级的应用程序作为一个基本的宿主,用来运行JavaScript代码并验证引擎是否正确运行。

  • 对于开发和调试过程,启动涉及打开Visual Studio中的solution文件(ChakraCore.sln),然后进行构建以生成必要的可执行文件和库。

3. 项目的配置文件介绍

  • Visual Studio解决方案文件: (ChakraCore.sln) 是项目的主要入口点,用于Windows上的开发和构建。不直接作为配置文件,但它管理着项目之间的依赖关系,决定了哪些项目将在构建时被编译。

  • CMakeLists.txt: 当在非Windows平台上构建ChakraCore时,此文件是关键的配置文件,指定了如何构建项目以及相关的构建设置。

  • 其他配置文件.editorconfig.gitattributes主要用于编辑器和Git的行为配置,而非项目构建或运行的直接配置。

  • 特定于构建配置的细节通常分散在各个构建脚本和环境变量中,特别是当你在不同的操作系统下使用CMake或直接在Windows上使用Visual Studio构建系统时。

结论

ChakraCore项目提供了灵活且详细的结构来适应不同平台的构建需求。理解这些基础结构和核心文件是成功集成和使用ChakraCore的关键。确保查阅最新的官方文档,因为项目详情和最佳实践可能会随着时间而更新。

ChakraCoreChakraCore is an open source Javascript engine with a C API.项目地址:https://gitcode.com/gh_mirrors/ch/ChakraCore

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

一、什么是 ChakraCore ChakraCore 是微软开源的 Microsoft Edge 浏览器 Chakra JavaScript 引擎的核心部分,主要用于 Microsoft Edge 和 Windows 中 HTML/CSS/JavaScript 编写的应用 ChakraCore 支持 x86/x64/ARM 架构 JavaScript 的 Just-in-time (JIT) 编译,垃圾收集和大量的最新 JavaScript 特性。ChakraCore 还支持 JavaScript Runtime (JSRT) APIs ,允许用户简单嵌入 ChakraCore 到应用中。 ChakraCore 是一个功能完整的、独立的 JavaScript 虚拟机,可嵌入到衍生产品中,驱动需要脚本功能的产品如 NoSQL 数据库、生产力工具和游戏引擎。 ChakraCore 现在已经跨平台支持:Windows、MacOS、 Ubuntu 详细参考微软开源地址: https://github.com/Microsoft/ChakraCore 二、ChakraCore架构 三、JS脚本支持有哪些优势? 在流行的脚本语言中,Lua的小巧高性能(性能指LuaJit的性能),Python的功能性一直受开发者青睐。有什么理由使用JS脚本呢? JS脚本有众多的库支持 JS脚本被用于HTML网页开发,开发者众多 JS有众多大公司的支持 JS有优秀的即时编译(JIT)性能 JS有无敌的开发工具Visual Studio的支持 JS语言特性更类似C/C++,相比Lua要舒服很多 Chakra的嵌入优势:相比Lua的堆栈式API,Chakra的API更容易写胶水代码。 很多游戏使用Lua的原因是比Python性能好,没有其他可选方案了。Chakra的开源,应该带动开发者去使用JS脚本。Chakra对于大型Windows游戏开发者更大的好处在于系统支持,Lua需要去下载编译,而Chakra只需要包含头文件,链接lib。 四、QA 可以列出全局对象或函数吗? 可以,除了Intl,这是个特例 JS可以使用引用(c++的,c#的ref)参数吗? 不可以,即使你为传入Native的函数参数修改值也是没用的。 如果一定要用,那只能传一个引用类型的对象,在函数内部修改此对象的成员。var arr=[];(function (v){v[1]=1;})(arr);//arr[1] == 1 Chakra的API支持多线程吗? 支持,据我当前的研究,不同线程必须有各自的runtime对象,每个runtime可以有多个环境(context),同一个runtime下的多个环境可以自由交换数据,但环境之间不共享数据。也就是说api级别可以把环境1的数据带到环境2,但是脚本里,环境2是看不到环境1的数据的。 Chakra支持ES6的Symbol吗? 完全支持。 Chakra如何在原生函数里支持JS的闭包? 函数(function)也是对象(object),可以有自定义属性,所以,在原生API级别操作Chakra时,可以把需要闭包的变量放在函数的属性里。如果希望在脚本中是只读的,那么可以设置属性描述。如果希望在脚本中是隐藏的,那么可以用符号属性。 五、关于世界4大js引擎的简介 google v8 ,目前为止,只能编译出静态链接库版本。静态库将近3G,运行链接一次需要2分钟,太庞大了 mozilla spider monkey,老牌的js引擎,编译后大小合适,很适合使用 ms chakra core,最新的js引擎,支持es6标准,编译后最小,速度很快,我个人蛮喜欢的 苹果的webkit中的javascript core引擎,没编译过,但是感觉不会太小 代码及相关例程截图 目前该组件已经在自身业务上稳定运用近一年,特以此机会开源给大家使用。 选择这个引擎是因为谷歌的V8太大了,而且API对易语言 也不友好,微软这个性能和V8差不太大,API封装友好。也一直在更新。而且体积也只有5M多一点。非常适合做嵌入开发。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

花化贵Ferdinand

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值