1.2.2 GoLLVM 编译探索GO CN GoLLVM编译探索 马春辉 字节跳动程序语言团队工程师 目录 团队与个人 01 GoLLVM 背景 02 GoLLVM现状 03 GoLLVM问题解决 04 阶段性的成果 05 未来与展望 06 第一部分 团队与个人 ’ alt=‘OCR图片’/> 团队与个人 字节跳动程序语言团队 go 编译器/Runtime/GC 优化 基础库、性能分析工具、java、python 基础库、性能分析工具、java、python 马春辉 十多年的编译器领域相关工作经验 先后就职于HP编译器组,IBM jvm组,华为虚拟机实验室,字节跳动程序语言团队 ’ alt=‘OCR图片’/> 第二部分 GoLLVM背景 ’ alt=‘OCR图片’/> GoLLVM背景 · 字节内有大量的go微服务 性能要求 在原生Go SDK上的一些传统编译优化收益超过几十万核 PSM CPU Latency GoLLVM背景 传统编译优化在go compiler上的实现 Inline 策略调整 栈大小调整 Fast path inline Aggressive BCE ’ alt=‘OCR图片’/> GoLLVM背景 ·两条路 继续在原生Go SDK上开发 优化pass少 SSA比较简陋,缺少一些优化的基础设施 探索利用LLVM的优化能力:语言团队与STE-编译器组联合探索0 码力 | 25 页 | 3.99 MB | 1 月前3
Greenplum 编译安装和调试## Greenplum 编译安装和调试 本文先介绍如何从源代码编译安装Greenplum、初始化Greenplum集群。然后介绍SQL在Greenplum中的典型执行路径,最后介绍一些调试技巧。 源代码使用 Greenplum 开源社区最新源代码 6X_STABLE 分支: https://github.com/greenplum-db/gpdb,内核代码基于PostgreSQL 9. com/greenplum-db/gpdb-postgres-merge。 ### 1. 从源代码编译 Greenplum Greenplum 目前官方支持 Redhat/Centos/SuSE/Ubuntu 等 Linux 系统。大量开发人员包括我自己使用 Mac 系统,但是不在官方支持列表中。 ### 1.1 在 Mac 系统上编译 首先需要关闭苹果操作系统的 SIP 特性,否则无法初始化集群。 1. 重启操作系统 python get-pip.py $ sudo pip install psutil lockfile paramiko setuptools epydoc // 需要安装 openssl,否则无法编译 $ brew install openssl && brew link openssl --force $ CPPFLAGS="-I/usr/local/include/0 码力 | 15 页 | 2.07 MB | 2 年前3
Rust并行编译的挑战与突破Rust并行编译的挑战与突破 李原 2022年5月28日 ## 目录 - 相关浅谈 - Rust并行编译的挑战与突破 - 从并行编译到并行程序设计 - Rust社区与并行编译  ## 相关浅谈 ## Rust编译速度之殇 ## ## 编译器设计造成编译速度缓慢  · 单态化 · 借用检查 · 宏展开 · MIR优化 Rust规模编译速度慢于C++  ## Rust编译速度之殇 ## 提升编译效率成为近年社区重点工作  2017-2021,Rust编译速度已提升一倍以上 编译器的方案 AST = Abstract Syntax Tree抽象语法树 SSA = Single Static Assignment单静态赋值 IR = Intermediate Representation中间表示0 码力 | 36 页 | 1.63 MB | 1 月前3
KCL: Rust 在编译器领域的实践与探索## RUST CHINA CONF 2023 第三届中国Rust开发者大会 6.17-6.18 @Shanghai ## KCL: Rust 在编译器领域的实践与探索 张正 蚂蚁集团 ## 😍 01 KusionStack 与 KCL 02 用 Rust 重写 KCL 03 Rust 重写后的收益 04 更多的探索 ## 01 KusionStack 与 KCL ## KusionStack是什么 badd1b5abffd9fb8525138fc88bca0/p9_2.jpg) ## 2 KCL 编译器架构升级 Python 代码翻译 Source Code Python code 栈式虚拟机 Source Code AST Bit code VM Rust 编译器 Source Code AST LLVM IR Native/WASM ## R ## 我们遇到了哪些问题? ## 01 稳定性提升 源于 Rust 强大的编译检查和错误处理方式,更少的 Bug 03 20 & 40 前端解析器性能提升 20倍 中端语义分析器性能提升40倍 ## 02 66% 端到端编译执行性能提升了66% ## 04 50% 语言编译器编译过程平均内存使用量变为原来 Python 版本的一半 ## Case1: 单文件编译 > https://github.0 码力 | 25 页 | 3.50 MB | 2 年前3
Python 2.7.18 正则表达式 HOWTO# 正则表达式 HOWTO 发布 2.7.18 Guido van Rossum and the Python development team 五月 20, 2020 Python Software Foundation Email: docs@python.org ## Contents 1 概述 2 简单模式 2.1 匹配字符 2.2 重复 3 使用正则表达式 使用正则表达式 3.1 编译正则表达式 3.2 反斜杠灾难 3.3 应用匹配 3.4 模块级别函数 3.5 编译标志 4 更多模式能力 4.1 更多元字符 4.2 分组 4.3 非捕获和命名组 4.4 前向断言 5 修改字符串 5.1 分割字符串 5.2 搜索和替换 6 常见问题 6.1 使用字符串方法 6.2 match() 和 search() search() 6.3 贪婪与非贪婪 6.4 使用 re.VERBOSE 7 反馈 |摘要| |---| |本文档是在 Python 中使用 re 模块使用正则表达式的入门教程。它提供了比 “标准库参考” 中相应部分更平和的介绍。| ## 1 概述 The re module was added in Python 1.5, and provides Perl-style regular expression0 码力 | 18 页 | 369.95 KB | 1 年前3
Python 2.7.18 正则表达式 HOWTO# 正则表达式 HOWTO 发布 2.7.18 Guido van Rossum and the Python development team 五月 20, 2020 Python Software Foundation Email: docs@python.org ## Contents 1 概述 2 简单模式 2.1 匹配字符 2.2 重复 3 使用正则表达式 使用正则表达式 3.1 编译正则表达式 3.2 反斜杠灾难 3.3 应用匹配 3.4 模块级别函数 3.5 编译标志 4 更多模式能力 4.1 更多元字符 4.2 分组 4.3 非捕获和命名组 4.4 前向断言 5 修改字符串 5.1 分割字符串 5.2 搜索和替换 6 常见问题 6.1 使用字符串方法 6.2 match() 和 search() search() 6.3 贪婪与非贪婪 6.4 使用 re.VERBOSE 7 反馈 |摘要| |---| |本文档是在 Python 中使用 re 模块使用正则表达式的入门教程。它提供了比 “标准库参考” 中相应部分更平和的介绍。| ## 1 概述 The re module was added in Python 1.5, and provides Perl-style regular expression0 码力 | 18 页 | 369.95 KB | 1 年前3
Python 3.11.10 正则表达式 HOWTO# 正则表达式指南 发行版本 3.11.10 ## Guido van Rossum and the Python development team 九月 09, 2024 Python Software Foundation Email: docs@python.org ## Contents 1 概述 2 简单正则 2.1 匹配字符 2.2 重复匹配 3 使用正则表达式 使用正则表达式 3.1 编译正则表达式 3.2 反斜杠灾难 3.3 应用匹配 3.4 模块级函数 3.5 编译标志 4 更多模式能力 4.1 更多元字符 4.2 分组 4.3 非捕获和命名组 4.4 前视断言 5 修改字符串 5.1 分割字符串 5.2 搜索和替换 6 常见问题 6.1 使用字符串方法 6.2 match() 和 search() Kuchling摘要 本文档是一个关于如何在 Python 中使用 re 模块进行正则表达式操作的入门教程。相较于 Python 标准库参考文档中的相关章节,本教程采用了更为浅显易懂的讲解方式。 ## 1 概述 正则表达式(Regular expression,也称为 RE、regex 或 regex pattern),本质上是一种微型的、高度专业化的编程语言。在 0 码力 | 18 页 | 403.35 KB | 1 年前3
Python 3.6.15 正则表达式 HOWTO# 正则表达式 HOWTO 发布 3.6.15 Guido van Rossum and the Python development team 九月 05, 2021 Python Software Foundation Email: docs@python.org ## Contents 1 概述 2 简单模式 2.1 匹配字符 2.2 重复 3 使用正则表达式 3.1 编译正则表达式 3.2 反斜杠灾难 3.3 应用匹配 3.4 模块级别函数 3.5 编译标志 4 更多模式能力 4.1 更多元字符 4.2 分组 4.3 非捕获和命名组 4.4 前向断言 5 修改字符串 5.1 分割字符串 5.2 搜索和替换 6 常见问题 6.1 使用字符串方法 6.2 match() 和 search()
## 1 概述 正则表达式(称为 RE,或正则,或正则表达式模式)本质上是嵌入在 Python 中的一种微小的、高度专业化的编程语言,可通过 re 模块获得。使用这摘要 本文档是在 Python 中使用 re 模块使用正则表达式的入门教程。它提供了比 “标准库参考” 中相应部分更平和的介绍。 0 码力 | 18 页 | 391.58 KB | 1 年前3
Python 3.7.13 正则表达式 HOWTO# 正则表达式 HOWTO 发布 3.7.13 Guido van Rossum and the Python development team 三月 16, 2022 Python Software Foundation Email: docs@python.org ## Contents 1 概述 2 简单模式 2.1 匹配字符 2.2 重复 3 使用正则表达式 使用正则表达式 3.1 编译正则表达式 3.2 反斜杠灾难 3.3 应用匹配 3.4 模块级别函数 3.5 编译标志 4 更多模式能力 4.1 更多元字符 4.2 分组 4.3 非捕获和命名组 4.4 前向断言 5 修改字符串 5.1 分割字符串 5.2 搜索和替换 6 常见问题 6.1 使用字符串方法 6.2 match() 和 search() M. Kuchling摘要 本文档是在 Python 中使用 re 模块使用正则表达式的入门教程。它提供了比 “标准库参考” 中相应部分更平和的介绍。 ## 1 概述 正则表达式(称为 RE,或正则,或正则表达式模式)本质上是嵌入在 Python 中的一种微小的、高度专业化的编程语言,可通过 re 模块获得。使用这种小语言,你可以为要匹配的 0 码力 | 17 页 | 392.75 KB | 1 年前3
共 818 条
- 1
- 2
- 3
- 4
- 5
- 6
- 82













