代码优化- 前端优化

这篇具有很好参考价值的文章主要介绍了代码优化- 前端优化。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

代码优化- 前端优化

常量折叠

基本思想:在编译期间计算表达式的值(编译时静态计算)

例如:a = 3 + 5 ==> a = 8,if (true && false) ... ==> if (false)

好处是:语法树的节点数量减少了,意味着编译器要维护的中间表示所要耗费的计算资源(比如内存)减少了;将来生成机器码的话,指令也减少了。

代码优化- 前端优化

常量折叠把进行更深层次的优化的机会暴露出来了,例如上面的if (false),就可以进行死代码消除优化。

可以整型、布尔型、浮点型等数据类型上进行(依赖于我们编译的元语言的情况) 

语法制导的常量折叠算法

const_foid(Exp_t e)
{
    while (e is stiil shrinking)
        switch (e->kind)
            case EXP_ADD:
                Exp_t l = e->left;
                Exp_t r = e->right;
                if (l->kind == EXP_NUM && r->kind == EXP_NUM)
                    e = Exp_Num _new(l->value + r->value);
                break;
            case EXP_TIMES:
                ...
            default:
                break;
}

常量折叠小结

容易实现、可以在语法树或者中间表示上进行

通常被实现成公共子函数被其他优化调用

必须要很小心遵守语言的定义,例如:考虑溢出或者异常,0xffffffff+1 ==> 0 (要考虑整型数的溢出是否要抛异常?不能直接优化掉!)

代数化简

基本思想:利用代数系统的性质对程序进行化简

示例:

a = 0 + b    ==>    a = b        (0是加法的左零元)
a = 1 * b    ==>    a = b         (1是乘法的左单位元)
2 * a          ==>    a + a         (强度削弱)
2 * a          ==>    a << 1       (强度削弱)

同样必须非常仔细的处理语义

例如:(i - j) + (i - j)    ==>    i + i - j - j,其中i = j = 0xffffffff,优化前为0,优化后i + i溢出,抛出异常

语法制导的代数化简算法

alg_simp(Exp_t e)
{
    whiie(e is sti11 shrinking) 
        switch (e->kind)
            caseEXP_ADD : 
                Exp_t l = e->left;
                Exp_t r = e->right;
                if (l->kind == EXP_NUM && l->value == 0)
                    e = r;
                break;
            case...:
                ...;  // 类似
}

死代码(不可达代码)删除

基本思想:静态移除程序中不可执行的代码

示例:if (false)  s1;  else  s2;   ==>   s2;

在控制流图上也可以进行这些优化,但在早期做这些优化可以简化中后端文章来源地址https://www.toymoban.com/news/detail-422324.html

不可达代码删除算法

deadcode(Stm_t s)
{
    while (s is still shrinking)
        switch (s->kind)
            case STM_IF:
                Exp_t e = s->condition;
                if (e->kind == EXP_FALSE)
                    s = s->elsee;
                break;
            case ...:
                ...; // 类似
}

到了这里,关于代码优化- 前端优化的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • SE、CBAM、ECA注意力机制(网络结构详解+详细注释代码+核心思想讲解+注意力机制优化神经网络方法)——pytorch实现

           这期博客我们来学习一下神秘已久的注意力机制,刚开始接触注意力机制的时候,感觉很有意思,事实上学会之后会发现比想象中的要简单,复杂的注意力机制后续会讲解,这期博客先讲解最常见的三种SE、CBAM、ECA注意力机制。        注意力机制更详细的可以被称

    2024年02月07日
    浏览(49)
  • 使用 Swift 代码优化项目编译速度

    软件的性能是评价一个软件质量的重要指标,尤其在今天这个时代,性能已成为大型项目不可或缺的考虑因素之一。对于用户量极大的软件,如网银系统、在线购物商城等,更是必须保证其高效稳定的性能。在这种背景下,优化项目的编译速度就显得尤为重要。本文将介绍如

    2024年01月20日
    浏览(44)
  • 前端vue简单实用折叠面板可以折叠收起展开内容区域

    随着技术的发展,开发的复杂度也越来越高,传统开发方式将一个系统做成了整块应用,经常出现的情况就是一个小小的改动或者一个小功能的增加可能会引起整体逻辑的修改,造成牵一发而动全身。通过组件化开发,可以有效实现单独开发,单独维护,而且他们之间可以随

    2024年02月06日
    浏览(50)
  • 代码优化- 前端优化

    基本思想:在编译期间计算表达式的值(编译时静态计算) 例如:a = 3 + 5 == a = 8,if (true false) ... == if (false) 好处是:语法树的节点数量减少了,意味着编译器要维护的中间表示所要耗费的计算资源(比如内存)减少了;将来生成机器码的话,指令也减少了。 常量折叠把进行

    2023年04月23日
    浏览(21)
  • C++代码性能优化的好处与缺点?有哪些编译器优化选项?

    性能优化是C++编程中的一个重要方面,它可以带来许多好处,但也有一些潜在的缺点。 以下是C++代码性能优化的一些优缺点: 优点: 提高执行速度 : 优化后的代码可以更快地执行,这对于需要处理大量数据或需要快速响应的应用程序尤其重要。 减少资源消耗 : 优化可以减少

    2024年03月27日
    浏览(55)
  • 编译代码性能优化实践:理解循环展开(pragma unroll)

    引言: CUDA的矩阵乘优化经常见到 pragma unroll 的使用,本文通过简单的示例,展示了CPU和CUDA对循环展开前后的性能表现,来通俗理解循环展开的优化策略。         简单理解:将代码中的for循环展开,减少循环次数;循环展开的本质是,利用CPU指令级并行,来降低循环的

    2024年03月27日
    浏览(43)
  • JVM 常量池、即时编译与解析器、逃逸分析

    常量池底层使用HashTable key 是字符串和长度生成的hashValue,然后再hash生成index, 该index就是key;Value是一个HashTableEntry; 1、key     hashValue = hash string(name, len)     index = hash to index(hashValue);     1、根据字符串(即 name)以及字符串的长度计算出hashValue     2、根据hashValue计算出

    2024年02月11日
    浏览(54)
  • Golang 基本常量声明及 iota 使用

    普通声明时,与局部变量声明的方式一致: 多行常量声明时,如果常量值表达式为空,则会和前一个常量的值表达式相同。 iota 是常量声明时的一个自增的特殊变量; iota 在const 内部的第一行出现时,值为0,后续每新增一行,iota都会自增1。(可以理解为行索引或者行号)

    2024年02月13日
    浏览(45)
  • Rust变量、常量声明与基本数据类型

    Rust是一门系统级别的编程语言,注重安全性、性能和并发。在这篇博客中,我们将介绍Rust中的变量、常量声明以及基本数据类型,并通过示例说明每一种类型的用法。 在Rust中,使用 let 声明变量。变量默认是不可变的,要使其可变,需要使用 mut 。 常量使用

    2024年01月18日
    浏览(62)
  • 二、GoLang输出HelloWorld、基本数据类型、变量常量定义、基本类型转换

    go语言中,想要输出内容到控制台,package必须是main,包括方法名也必须是main, go语言输出的语法是 fmt 库。 Go语言的基本类型有: boolean:布尔类型 true / false string :字符串类型 数值型: int8:有符号8位整型(-128到127)长度 int16:有符号16位整型(-32768到32767)长度 int32:有

    2024年02月09日
    浏览(59)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包