读Java性能权威指南(第2版)笔记04_ Java SE API技巧下

读Java性能权威指南(第2版)笔记04_ Java SE API技巧下

1.异常

1.1.代码应该仅在发生意料之外的事情时抛出异常

1.1.1.防御性编程性能好

1.2.异常的处理成本未必很高

1.2.1.应该只在适当的时候使用

1.2.2.栈越深,处理异常的成本就越高

1.3.对于频繁创建的系统异常,JVM会优化获取栈轨迹的性能开销

1.4.在异常中禁用栈轨迹有时可以提高性能,但会丢失一些关键信息

2.日志

2.1.一直开启GC日志

2.2.基本原则

2.2.1.在日志的数据和日志的级别之间找到平衡

2.2.2.使用细粒度的日志记录器

2.2.2.1.开启过多的日志通常会改变生产环境,使原来的问题无法显现

2.2.3.即使没有开启日志,也很容易在无意间写出具有副作用的日志代码

2.3.应该包含大量日志以帮助用户找出问题所在,但日志默认应该是关闭的

2.3.1.如果日志记录器的参数需要调用方法或者分配对象,那么不要忘记在调用记录器之前检验日志级别

3.Java集合API

3.1.根据算法选择集合类是至关重要的

3.2.LinkedList不适合搜索

3.3.HashMap用于访问一段随机的数据

3.4.TreeMap用于数据需要保持有序

3.5.HashMap是根据键值查找条目的最快方法

3.6.ArrayList用于数据通过索引访问

3.6.1.不适用将数据插入到数组中

3.7.集合的大小会对性能产生很大的影响

3.7.1.太大,会拖慢垃圾回收器的速度

3.7.2.太小,会需要大量的复制操作和大小调整操作

3.8.使用同步集合,降低由此带来的性能影响

3.8.1.是否值得花费时间和精力为了线程安全而面向未来编程

4.Lambda和匿名类

4.1.Lambda并不是通过匿名类实现的

4.2.Lambda的代码会创建一个静态方法

4.2.1.该方法通过一个特殊的帮助类来调用

4.3.匿名类是真正的Java类

4.3.1.它有单独的类文件,并会通过类加载器加载

4.3.2.启动有很多匿名类(相对于有很多Lambda)的应用程序,可能会出现更大的差异

4.4.性能几乎没有区别

4.4.1.在类加载很重要的环境中,Lambda会稍快一些

5.流和过滤器

5.1.流最重要的性能优势

5.1.1.它们被实现为延迟处理的数据结构

5.1.2.延迟处理的过滤器实现可以在完成需要做的事情后结束处理,这样处理的数据更少

5.2.过滤器比迭代器快得多的原因

5.2.1.它们可以进行算法上的优化

5.3.即使处理整个数据集,单个过滤器的性能也会略优于迭代器

5.4.多个过滤器是有开销的,要确保编写性能良好的过滤器

6.对象序列化

6.1.一种将对象的二进制状态写出来,以便之后重新创建的方法

6.2.数据的序列化可能是很大的性能瓶颈

6.3.降低对象序列化成本的方法是序列化更少的数据

6.3.1.将字段标记为transient来做到,标记后它们默认不会被序列化

6.3.2.可以让序列化更快,并减少需要传输的数据量

6.4.优化序列化往往就是对对象引用进行特殊处理

6.4.1.做得正确,序列化代码的性能会大幅提高

6.4.2.做得不正确,就会引入不易察觉的bug

6.4.3.避免写出重复的对象引用

6.5.压缩序列化数据,传输速度会更快

6.5.1.压缩序列化数据然后延迟解压会非常有用,特别是当目标是节省CPU内存而不是节省CPU时间的时候

6.5.2.在快速的网络上,压缩数据的时间很容易比传输更少的数据所节省的时间长,在较慢的网络上,情况可能正好相反

6.6.实现Externalizable接口

6.6.1.当writeObject()方法调用defaultWriteObject()方法时

6.6.1.1.Serializable接口会写出非瞬时字段

6.6.1.2.Externalizable接口不会写出非瞬时字段

6.6.2.Externalizable类必须明确地写出它要传输的所有字段

6.6.2.1.不管这些字段是不是瞬时的

6.7.即使一个对象的所有字段都是瞬时的,最好还是实现Serializable接口并调用defaultWriteObject()方法

6.7.1.会让代码更容易维护

6.8.通过writeObject()方法和readObject()方法进行的其他优化可以大幅加快序列化的速度

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容