1.什么是数据字典?解决了什么问题?
<select>
<option value="1">北京</option>
<option value="2">上海</option>
<option value="3">重庆</option>
<option value="4">天津</option>
</select>
例如:上面这一段代码中,这是一段下拉框的前段代码,城市信息是写死的,而这样的关于城市的代码在一个项目中大概率是会重复出现多次,所以问题出现了,客户后期如果提出了需求,例如:把北京改为北京市等.这样是要在项目中找到这些写死的信息并且一个一个修改,非常麻烦.
解决方案:数据字典
这是在数据库表格中的数据字典表格,前者是字典类型,后者是字典值.(对应到上面的代码,城市就是字典类型,城市命就是字典值),这样,客户要修改就可以修改数据库表中的值了,<option value="1">北京</option>,中的北京可以用EL表达式写入从后台数据库中查询出来的值了.
2.服务器缓存机制
存储器的分级
存储器是分层次的,离CPU越近 ,速度越快,每字节的成本也越高,同时容量也因此越小。寄存器离CPU最近,因此速度最快,成本最高,所以个数和容量有限。其次是高速缓存(缓存也是分级,有L1,L2等缓存),再次是主存(普通内存),再次是本地磁盘。
寄存器:中央处理器内的组成部份。寄存器是有限存贮容量的高速存贮部件,它们可用来暂存指令、数据和位址。在中央处理器的控制部件中,包含的寄存器有指令寄存器(IR)和程序计数器(PC)。在中央处理器的算术及逻辑部件中,包含的寄存器有累加器(ACC)
cache:即高速缓冲存储器,由静态存储芯片(SRAM)组成,是位于CPU与主内存间的一种容量较小但速度很高的存储器。由于CPU的速度远高于主内存,CPU直接从内存中存取数据要等待一定时间周期,Cache中保存着CPU刚用过或循环使用的一部分数据,当CPU再次使用该部分数据时可从Cache中直接调用,这样就减少了CPU的等待时间,提高了系统的效率。Cache又分为一级Cache(L1 Cache)和二级Cache(L2 Cache),L1 Cache集成在CPU内部,L2 Cache早期一般是焊在主板上,现在也都集成在CPU内部,常见的容量有256KB或512KB L2 Cache。
内存:内存包含的范围非常广,一般分为只读存储器(ROM)、随机存储器(RAM)和高速缓存存储器(cache)
存储器分级,利用的是局部性原理。我们可以以经典的阅读书籍为例。我在读的书,捧在手里(寄存器),我最近频繁阅读的书,放在书桌上(缓存),随时取来读。当然书桌上只能放有限几本书。我更多的书在书架上(内存)。如果书架上没有的书,就去图书馆(磁盘)。我要读的书如果手里没有,那么去书桌上找,如果书桌上没有,去书架上找,如果书架上没有去图书馆去找。可以对应寄存器没有,则从缓存中取,缓存中没有,则从内存中取到缓存,如果内存中没有,则先从磁盘读入内存,再读入缓存,再读入寄存器。
(所以数据字典的值因为是来自数据库中的,所以不可能每一次查询值都到数据库中查找,这样效率太低了,那么就建议在程序运行的一开始就把数据写入到服务器内存放入到ServletContext作用域之中之中,提升查询效率)