这里提到一个概念Over-eager evaluation,可以理解为超前计算,主要有两种方法caching和 prefething,都是以空间换时间来提高效率。
看到这章,让我想起了我以前做的两个项目,一个是给某直辖市做的全市联网XX系统,一个是给某发电厂做的监控环境系统。
1.全市联网系统,由于数据量非常大,导致的性能瓶颈就是每次查询数据库都会很慢,导致用户体验非常不好,而实际情况是数据库中的内容并不是总是频繁改变,所以我采用了catching方式,将数据库中内容预存到内存中,每次读取先从catch中查询,如果有就直接返回,如果没有则再查询数据库,通过这种方式,大大提高了查询效率,这是一个典型的用空间换取时间的方案。
2.发电厂的监控项目是一个需要频繁查询的系统,要实时的更新系统数据,并计算出当时的最大值,最小值和平均值,还要将采集到的数据记录到数据库中以备查询。这里没最麻烦的是计算max,min和ave,因为这些值会根据时长不停的变化,每次查询时都要重新计算,有可能还需要查询数据库,这就导致程序运行非常慢,当时提出一个方案是采用catching方式,提前计算出来结果,并实时更新这些结果,需要的时候,可以直接取。这个方案实施起来非常麻烦,所以我改了下将每次采集的数值计算好,将这些值直接保存到数据库中,然后每次查询都直接读取,效率提高了很多。这种方式可以归结为上述的prefetching方式里。