编程珠玑<续>之性能监视工具

   这一章主要说明了一个问题,也就是写代码过程中最重要又最容易被忽略的问题-----代码的执行效率。

   验证一个程序的正确与否,最直观的是看输出是否达到预期。但评价一个程序的好坏,还是得从性能上去评估。

    学习编程之初就学到时间复杂度和空间复杂度的概念,可是如何提高代码的效率,如何很好的减小各种系统开销却没有很明确的说法。

    就像医生用听诊器去诊断病人的患处一样,程序员用性能监视器来观察一个程序执行各个部分的频率。

文章举例了一个“查找1000以内的所有素数”的例子,然后通过对问题的进一步分析一步步对代码进行优化,从监视器里很明显看到无论是从执行时间还是CPU占用率上,修改后的代码所执行的频率要少的多。这里得到的收获就是:

1、小细节能解决大问题,比如说P3中多开辟了一个存储空间bound来单独存放sqrt的开方结果,这样可以减少for中调用sqrt的次数;

2、深入对问题的分析找规律,这个例子求得是素数,当了解到什么是素数的概念后找出特性规律,可以进一步的改写代码结构,一般的质数是指“只能够被1和自己整除”,而合数都是指能被“能够被自己和1以外的数整除的数”,并且近3/4的数都包含了质因子2,3,5,利用这个特性可以很大程度的减少比较次数。

3、能用乘法就不要开方,能加法就不要做乘法,由于计算机只会做加法运算,其他的运算都是在加法的基础上做移位求反,因此越复杂的计算越费时需要的执行次数越多。

一个很重要的研究结果是:一个程序中不到4%的语句通常占用了一半以上的运行时间。也就是说操作系统一半的时间花在一个只有少数几条指令的循环上


以上是本人的薄见.....如有不对欢迎指正拍砖~~~

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
优化这段代码<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>图书购物车</title> <style> </style> <script src="js/vue.js"></script> </head> <body> <div id="demo"> <table border="1"> <tr> <td></td> <td>书籍名称</td> <td>出版日期</td> <td>价格</td> <td>购买数量</td> <td>操作</td> </tr> <tr> <td></td> <td>{{books1.name}}</td> <td>{{books1.date}}</td> <td>¥{{books1.price}}</td> <td><button @click="down(books1)">-</button>{{books4.count}}<button @click="up(books1)">+</button></td> <td><button @click="del">移除</button></td> </tr> <tr> <td></td> <td>{{books2.name}}</td> <td>{{books2.date}}</td> <td>¥{{books2.price}}</td> <td> <button @click="down(books2)">-</button>{{books4.count}}<button @click="up(books2)">+</button> </td> <td><button @click="del">移除</button></td> </tr> <tr> <td></td> <td>{{books3.name}}</td> <td>{{books3.date}}</td> <td>¥{{books3.price}}</td> <td> <button @click="down(books3)">-</button>{{books4.count}}<button @click="up(books3)">+</button> </td> <td><button @click="del">移除</button></td> </tr> <tr> <td></td> <td>{{books4.name}}</td> <td>{{books4.date}}</td> <td>¥{{books4.price}}</td> <td> <button @click="down(books4)">-</button>{{books4.count}}<button @click="up(books4)">+</button> </td> <td><button @click="del">移除</button></td> </tr> </table> <div>总价: ¥{{sum}}</div> </div> <!-- js部分 --> <script> const vm = new Vue({ el: "#demo", data: { books1: { name: '《算法导论》', date: '2006-9', price: 85.00, count: 1 }, books2: { name: '《UNIX编程艺术》', date: '2006-2', price: 59.00, count: 1 }, books3: { name: '《编程珠玑》', date: '2008-10', price: 39.00, count: 1 }, books4: { name: '《代码大全》', date: '2006-3', price: 128.00, count: 1 } }, computed: { sum () { return this.books1.price * this.books1.count + this.books2.price * this.books2.count + this.books3.price * this.books3.count + this.books4.price * this.books4.count } }, methods: { down (books1) { this.books1.count = books1.count - 1; } } }) </script> </body> </html>
04-21
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值