读书笔记: Java并发编程实战(5)

5 性能、可伸缩性与测试

线程的最主要目的是提高程序的运行性能。线程可以使程序更加充分地发挥系统的可用处理能力,从而提高系统的资源利用率。

资源越多,使用线程进行并发处理就越能提高程序的性能。可伸缩性就是用来描述这种性质的。可伸缩性是指:增加计算资源(如CPU,内存)时,程序的吞吐量或处理能力得到相应的提升。在日常使用大型软件或系统时,应该能体会到这一点。


5.1 提高可伸缩性

应用程序的性能可以采用多个指标来衡量,而可伸缩性只是其中一种。

性能的不同指标有一定的独立性,有时候甚至是互相矛盾的。因此在做性能优化时,需要对各种性能权衡因素进行评估。当然最重要的一点是,先要保证程序的正确性,然后再想办法进行优化。这里只讨论可伸缩性这个指标。

在程序中引入线程,将可并行处理的部分并行化,可以提升程序的可伸缩性。

5.1.1 线程引入的开销

要想提高程序的可伸缩性,那么必须使用并行编程。

在单线程程序中,增加计算资源对程序的性能基本不会有太大提升,因为始终只有一个主线程,利用的资源是有上限的。 而引入多线程进行并行编程之后,对资源的利用率大大提升,才有较好的伸缩性表现。

但是引入线程是存在开销的,对于为了提升性能而引入的线程来说,并行带来的性能提升必须超过并发导致的开销。引入线程带来的开销表现在上下文切换内存同步线程阻塞几个方面。

5.1.2 减少锁的竞争

在并发程序中,锁竞争是一个主要的影响可伸缩性的因素。降低锁竞争程度的方式有以下几种:

  • 减少锁的持有时间。
  • 降低锁的请求频率。
  • 使用非独占锁或非阻塞锁。

减少锁的持有时间,可以将一些与锁无关的代码移出同步代码块,或者减小锁的粒度。

放弃独占锁,转而使用更为友好并发的方式,如并发容器、读-写锁、不可变对象以及原子变量来管理共享状态,也可以降低锁的竞争。

5.2 并发程序的测试

并发性测试大致分为两类,即安全性测试与活跃性测试。安全性可理解为程序的正确性,活跃性可理解为线程并发执行的能力(不发生死锁,长时间阻塞,饥饿等)。

并发程序中的潜在错误的发生并不具有确定性,而是随机的。

在进行安全性测试的时候,通常会采用测试不变形条件的形式,即判断某个类的行为是否与其规范保持一致。活跃性测试包括进展测试和无进展测试两方面,都是很难量化的。与活跃性测试相关的是性能测试,可以通过多个方面来衡量,如吞吐量、响应性、可伸缩性。

其他测试方法

测试的目标不是更多地发现错误,而是提高代码能够按照预期方式工作的可信度。由于找出所有的错误是不现实的,所以质量保证QA的目标该是在给定的测试资源下实现最高的可信度。

测试是一种非常重要的首选,但并不是唯一可用的QA方法。还有一些其他的QA方法,通过和测试方法互相补充,进一步提高代码的可信度。

这些方法主要有:代码审查,静态分析工具(FindBugs,CheckStyle),面向方面(AOP)的测试技术,分析与检测工具(jVisualVM)。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值