`
piao_bo_yi
  • 浏览: 4334 次
  • 性别: Icon_minigender_1
  • 来自: 北京
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

关于性能优化

阅读更多
我发现一个现象,很多两三年以下的人写代码动不动就扯性能,其实他们大部分人根本不知道到底哪是性能瓶颈,函数调用的效率,CPU执行指令需要的时间...工作效率低不说,还考虑很多没用的东西。个人感觉,性能这个东西应该考虑:
1.考虑程序的应用范围。如果你是给核反应堆写实时程序,那每一步你可能都得考虑,其他就大部分通用程序而言,你不用每一步都考虑。
2.性能要考虑关键瓶颈。不是每一步都是关键,关键瓶颈不是写之前提前考虑出来的,而是测出来的。很多你以为瓶颈的地方往往不是瓶颈。
3.低效的算法+大量的处理数据两者结合往往是导致效率低下的根本原因,而函数调用,拆分函数等不是。JAVA初学者喜欢怀疑函数调用,C++派则彻底怀疑继承结构和堆上的数据,很有意思的现象。即使低效的算法处理小量数据也没必要优化,e.g.冒泡排序和快速排序在排少量数据的时候的性能差异不需要考虑。

大家说说自己的看法。

P.S.编程里面真的有很多不符合直觉的结论。比如边开发边考虑性能优化是否必要,比如添加人手是否能提高项目进度,真的是很有意思。
分享到:
评论
15 楼 ouchxp 2010-11-16  
zhxing 写道
如果按你说的ArrayList和LinkedList在编程中是不需要注意的了,随便用就行了。。

代码写多了,对代码的要求也会高点,我们也希望能写出性能高效,优雅简洁的代码。。简洁和高性能一般都会有冲突的,这需要我们去权衡。。

ps:架构决定了性能的大部分,所以架构搭的好,总体性能也就不会差。代码的优化算不上什么。。但就是看不惯。。


LZ的前提 是小数据量 和 新手程序员
14 楼 ouchxp 2010-11-16  
抛出异常的爱 写道
对于性能
1.对于新手.不要优化.
2.对于老手.建议不要优化.

+1
不出问题建议不要轻易优化.
13 楼 piao_bo_yi 2010-11-16  
zhxing 写道
如果按你说的ArrayList和LinkedList在编程中是不需要注意的了,随便用就行了。。。

1.我的观点恰好认为ArrayList和LinkedList可以在平常“随便”用。因为如果你处理的是小数据量,这些根本不需要考虑(我知道链表插入删除只需要两步,数组需要x步,以及随机访问和线性遍历的查找...但是任何对此类无聊问题的考虑都会影响你的开发效率和你的思路。要将思路集中于对关键的逻辑的处理,这样你才能编程快和准。
zhxing 写道

代码写多了,对代码的要求也会高点,我们也希望能写出性能高效,优雅简洁的代码。。简洁和高性能一般都会有冲突的,这需要我们去权衡。。

2.对于通用应用程序,你写一部分代码,除非你那段代码是瓶颈,否则你对代码的性能优化会让他们难以维护(这还是在你知道如何优化的前提下)。一般情况,性能优化是没有必要的,可读性优化才更有价值。
12 楼 ouchxp 2010-11-16  
bitray 写道
赞成2楼和三楼的观点。虽然可能平时大家注意的并不是真正的性能瓶颈。但是如果不重视自己代码的书写规范和简洁,那么写出来的代码就是隐藏的瓶颈,是你最后很难优化出来的东西。有习惯的程序员用stringbuffer和stringbuilder,但是如果是不重视,就会有人用+连接,在多处,一定数据量的情况下,都可能产生隐含问题等


JDK自己已经有优化了. 不合理的优化反而会降低效率
比如字符串常量拼接
String str ="aaa" + "bbb" +"ccc" + "ddd";

StringBuilder sb = new StringBuilder();
sb.append("aaa");
sb.append("bbb");
sb.append("ccc");
sb.append("ddd");
String str = sb.toString();

哪种效率高? 答案是第一种. 对于新手来说想优化很容易适得其反.
反编译看一下就知道为什么了.
11 楼 trydofor 2010-11-16  
╮(╯▽╰)╭,很多人毁了Java :D

包括但不限于:
* 精通 java,jsp ...
* 精通 SSH ... 框架
* 开发 ...管理系统

性能优化?嘛是性能,啥是优化。
10 楼 william_ai 2010-11-16  
╮(╯▽╰)╭,java毁了很多人。
国内用得起java做的系统的,电信、移动等大客户居多。给他们做系统,性能上不去了,多弄两台小机、大机就ok了。
可是这个世界上除了这些java平台上的系统,真的还有许多许多领域的。举个子,总不能在火星车上装台superdome跑java的ERP吧。
9 楼 ironsabre 2010-11-16  
qianhd 写道
对于新手 写的时候动动脑子 别写出内存泄漏的代码 就谢天谢地了

有些人习惯性的爱写内存泄漏的代码
真不知道怎么想的


我觉得新手想要写出内存泄漏的代码是很难的,或者说你让他写一段内存泄漏的代码他都写不出来。要不你写一个试试?
8 楼 qianhd 2010-11-16  
对于新手 写的时候动动脑子 别写出内存泄漏的代码 就谢天谢地了

有些人习惯性的爱写内存泄漏的代码
真不知道怎么想的
7 楼 LifeFree 2010-11-16  
piao_bo_yi 写道
我发现一个现象,很多两三年以下的人写代码动不动就扯性能,其实他们大部分人根本不知道到底哪是性能瓶颈,函数调用的效率,CPU执行指令需要的时间...工作效率低不说,还考虑很多没用的东西。个人感觉,性能这个东西应该考虑:
1.考虑程序的应用范围。如果你是给核反应堆写实时程序,那每一步你可能都得考虑,其他就大部分通用程序而言,你不用每一步都考虑。
2.性能要考虑关键瓶颈。不是每一步都是关键,关键瓶颈不是写之前提前考虑出来的,而是测出来的。很多你以为瓶颈的地方往往不是瓶颈。
3.低效的算法+大量的处理数据两者结合往往是导致效率低下的根本原因,而函数调用,拆分函数等不是。JAVA初学者喜欢怀疑函数调用,C++派则彻底怀疑继承结构和堆上的数据,很有意思的现象。即使低效的算法处理小量数据也没必要优化,e.g.冒泡排序和快速排序在排少量数据的时候的性能差异不需要考虑。

大家说说自己的看法。


比较同意楼主的看法。
我经常遇到的一个情况是系统一慢,直觉就是数据库抓个快照,拿出来一分析,加两索引,改几个sql查询;系统好了。

90%以上都不是应用服务器并发性能,代码函数调用等其他原因引起的性能问题。


还是那句老话:Premature optimization is the root of all evil.

以上情况建立在编程平均水平比较低的普通国内软件企业。水平高的请飘过。
6 楼 抛出异常的爱 2010-11-16  
对于性能
1.对于新手.不要优化.
2.对于老手.建议不要优化.
5 楼 forgood 2010-11-16  
对于性能问题,我同意lz 2.性能要考虑关键瓶颈。不是每一步都是关键,关键瓶颈不是写之前提前考虑出来的,而是测出来的。很多你以为瓶颈的地方往往不是瓶颈。 只有找到了瓶颈才能想法击破。。。
4 楼 bitray 2010-11-16  
赞成2楼和三楼的观点。虽然可能平时大家注意的并不是真正的性能瓶颈。但是如果不重视自己代码的书写规范和简洁,那么写出来的代码就是隐藏的瓶颈,是你最后很难优化出来的东西。有习惯的程序员用stringbuffer和stringbuilder,但是如果是不重视,就会有人用+连接,在多处,一定数据量的情况下,都可能产生隐含问题等
3 楼 hyl1234 2010-11-16  
xixix2004 写道
1,性能确实不需要每一步都考虑,但是也是不能不考虑的。作为一个程序员,不是代码写出来,跑的通就可以心安理得的,对吗。

2,对于没有经验的程序员,性能问题是测出来的;对于有经验的程序员,性能问题是预测出来的。即使预测的有偏差,未雨绸缪也总好过亡羊补牢,对吗。

3,你自己也说了“小量数据”,“少量数据”,对吗。

心态放平和点,对于成长有好处。


赞成xixix2004 的说法,很多时候,你能预见到的问题,就没有必要到测试的时候才去发现,改正
2 楼 zhxing 2010-11-16  
如果按你说的ArrayList和LinkedList在编程中是不需要注意的了,随便用就行了。。

代码写多了,对代码的要求也会高点,我们也希望能写出性能高效,优雅简洁的代码。。简洁和高性能一般都会有冲突的,这需要我们去权衡。。

ps:架构决定了性能的大部分,所以架构搭的好,总体性能也就不会差。代码的优化算不上什么。。但就是看不惯。。
1 楼 xixix2004 2010-11-16  
1,性能确实不需要每一步都考虑,但是也是不能不考虑的。作为一个程序员,不是代码写出来,跑的通就可以心安理得的,对吗。

2,对于没有经验的程序员,性能问题是测出来的;对于有经验的程序员,性能问题是预测出来的。即使预测的有偏差,未雨绸缪也总好过亡羊补牢,对吗。

3,你自己也说了“小量数据”,“少量数据”,对吗。

心态放平和点,对于成长有好处。

相关推荐

    DB2 性能优化PDF

    DB2性能优化 DB2性能优化 DB2性能优化 DB2性能优化

    oracle性能优化技术内幕

    书中就多年以来关于性能优化人们一直认为是正确的某些错误观点和方法提出了批判,令人信服地证明了这些观点和方法的荒诞,提出了较为正确的观点和方法。 本书可供具有一定基础的Oracle数据库管理人员和应用编程人员...

    Oracle性能优化技术内幕

    本书讲述Oracle 性能优化技术。书中对给出的每一种优化方法和措施都从...年以来关于性能优化人们一直认为是正确的某些错误观点和方法提出了批判,令人信服地证明了这些观 点和方法的荒诞,提出了较为正确的观点和方法。

    linux性能优化和分析.ppt

    很高兴能有这样的机会,把我自己多年工作中对服务器硬件、软件方面的性能分析的经验和体会,以及性能优化的经验和... 本文涉及的内容基于Gnu/Linux系统平台,但关于性能优化分析和优化的思路也能适用于其他系统平台。

    jpa性能优化ppt

    关于性能优化的ppt,我觉得总结还真不错。

    大型网站性能优化实战

    具体内容包括:基于用户体验的性能优化要素、前端性能优化实战、网站性能分析、服务端性能优化、TCP优化、DNS优化、CDN优化、大型网站性能监控体系、大型网站容量评估、高性能系统架构模式、大促保障体系、数据分析...

    EBS性能调优之全面挖掘_V4.2(ebs性能优化、oracle性能优化、linux性能优化)

    数据库优化包括:实例的性能优化和SQL语句的性能优化,实例优化和sql优化均可以通过AWR报告来分析并作出优化方案。 这篇文档描述了如何调查EBS系统性能下降原因、如何使用和理解AWR报告、分别阐述了数据库层/应用层/...

    oracle数据库性能优化.pdf

    oracle数据库性能优化.pdforacle数据库性能优化.pdforacle数据库性能优化.pdforacle数据库性能优化.pdforacle数据库性能优化.pdf

    ORACLE SQL性能优化系列

    ORACLE SQL性能优化系列 ORACLE SQL性能优化系列 ORACLE SQL性能优化系列

    阿里巴巴Java性能调优实战(2021-2022华山版)+Java架构核心宝典+性能优化手册100技巧.rar

    性能优化手册是一套java性能学习研究小技巧,包含内容:Java性能优化、JVM性能优化、服务器性能优化、数据库性能优化、前端性能优化等。 内容包括但不限于: String 性能优化的 3 个小技巧 HashMap 7 种遍历方式...

    java性能优化java性能优化

    java性能优化介绍java性能优化方面的好的书籍,希望大家下载

    mysql 性能优化

    mysql 性能优化mysql 性能优化mysql 性能优化mysql 性能优化mysql 性能优化mysql 性能优化mysql 性能优化mysql 性能优化mysql 性能优化mysql 性能优化mysql 性能优化mysql 性能优化mysql 性能优化mysql 性能优化...

    Android性能优化.pdf

    Android性能优化:ANR问题解析 crash监控方案 启动速度与执行效率优化 内存优化 耗电优化 网络传输与数据存储优化 APK大小优化

    threejs性能优化与GPU优化.md

    threejs性能优化与GPU优化

    前端性能优化与实践.zip

    前端性能优化与实践.zip

    SQLServer性能优化与管理的艺术

    资源名称:SQL Server性能优化与管理的艺术内容简介:本书共15章,分为三部分,第一部分(第1-2章)为概述部分,阐述SQLServer方面的“性能”及相关概念。并给出常规的性能及性能相关的问题侦测的“方法论”,读者...

    性能优化-网站性能监测与优化

    Web前端性能优化数据 性能优化Web前端性能优化数据 性能优化Web前端性能优化数据 性能优化Web前端性能优化数据 性能优化

    系统性能分析与优化以及介绍常见的分析及监控系统

    很高兴能有这样的机会,把我自己多年工作中对服务器硬件、软件方面的性能分析的经验和体会,以及性能优化的经验和... 本文涉及的内容基于Gnu/Linux系统平台,但关于性能优化分析和优化的思路也能适用于其他系统平台。

Global site tag (gtag.js) - Google Analytics