java 复习001
java 复习001
比较随意的记录下我的java复习笔记
ArrayList 内存扩展方法
- 分配一片更大的内存空间,复制原有的数据到新的内存中,让引用指向新的内存地址
- ArrayList在内存不够时默认是扩展为1.5倍 + 1个
ArrayList,LinkedList,Vector 区别
- Vector内存扩展和ArrayList一样,不过Vector是默认扩展为2倍
- Vector支持线程的同步,因此牺牲了访问性能
- ArrayList,Vector都是使用数组实现,插入删除效率低
- LinkedList是链表实现,插入删除效率高,但遍历和随机访问速率低
- LinkedList提供操作链头和链尾的方法,可以轻松实现栈和队列
HashMap和HashTable的区别
HashMap实现详见:vblog-HashMap
Hashtable 类似于 HashMap,但是不允许 null 键和 null 值。它也比 HashMap 慢,因为它是同步的。
附张简单的java集合类关系图
java泛型和c++的区别
- c++叫函数模板(template),在编译期间会转换为模板类的目标代码
- java在编译期间不会转换成泛型类的目标代码,而是生成
Object
的目标代码,然后在Object
前加必要的类型转换代码 - java的泛型是伪泛型,因为只是在编译期间添加了类型转换代码,和自己手动添加没有任何区别,只能起更直观的类型控制作用,没有像c++那样提高效率
- 而且这种类型转换导致java的泛型不能是基础类型(如:int),而c++就没有这个限制了
java内存溢出问题
- 数据库查询条目太多,Hiberate session处理数据时,同个session会缓存所有的条目,导致内存不够溢出了
- 同一个session进行分页查询,注意
session.clear()
- 同一个session进行分页查询,注意
- 特别注意资源调用时注意关闭,容易导致内存泄漏
链条编程
- 方法返回和本身类同样的对象
- 使用效果:
chain.add("1").add("2")
filter(过滤器)
- 一个统一的Filter接口
- 一个
doFilter()
方法
- 一个
- 一个主FilterChain,可能嵌入很多子FilterChain
- 实现了Filter接口
- 多个过滤类的集合(ArrayList)
- 也实现了Filter接口
- 处理程序的
process
方法有待处理的参数和主FilterChain
动态代理(dynamic proxy)->interaptor(拦截器)
- 情景:当你想给一个已经存在且没法改源代码的类,在类的某个方法前后加上处理代码(如:计算运行时间代码)
- 实现方法(面向切面编程AOP):
- 使用
extends
继承,然后重写方法,在父类方法的前后加上处理代码- 不够灵活,因为继承只能是一个确定的类,不能多态,也就不容易嵌套代理
- 使用
implements
实现类的父类的接口,并且保存一个父类的引用(聚合),然后重写方法,在父类方法的前后加上处理代码- 很灵活,实现一个统一的接口能代理所有实现了这个接口的类对象,可以很容易嵌套代理
- 真正体现了多态之强大了
- 根据DynamicHandlerInterface和ObjectInterface动态得到一个代理类
- 底层实现有两种方法:jdk动态代理和cglib动态代理
- 两者区别:jdk动态代理是由java内部的反射机制来实现的,cglib动态代理底层则是借助asm来实现的。总的来说,反射机制在生成类的过程中比较高效,而asm在生成类之后的相关执行过程中比较高效(可以通过将asm生成的类进行缓存,这样解决asm生成类过程低效问题)。还有一点必须注意:jdk动态代理的应用前提,必须是目标类基于统一的接口。如果没有上述前提,jdk动态代理不能应用。由此可以看出,jdk动态代理有一定的局限性,cglib这种第三方类库实现的动态代理应用更加广泛,且在效率上更有优势。csdn
- 使用
工厂模式(Factory)
- 情景:手机切换主题
- 简介:能用来创建一系列实现了相同接口的对象,如:多样的主题类
- 可参考:iteye
单例模式
- 简介:一个类只有一个对象
- 必要条件
- 私有的构造方法
- static的自身引用
- static的
getInstance()
方法
Hibernate
- 对象状态转换图
- 1+N问题
- 问题简述
- 在*@ManyToOne*关系中,给Many的
FetchType
设为EAGER
- 在查询这个类对象时,Hibernate会先发送一条Select语句查询这个类对象,接着发送N条Select语句来查询与之相关的类对象
- 在*@ManyToOne*关系中,给Many的
- 解决方法
- 将这个类的
FetchType
设置为LAZY
;与之相关的类对象查询语句将按需而发 - 在这个类定义前加上
@BatchSize
(批处理);设置批数据大小,也就是一次操作对象的数目,这样可以成倍减少查询语句的条数 - 使用HQL语句
join fetch
,例如:from Topic t left join fetch t.category c
;合并查询,一个对象将只发一条查询语句
- 将这个类的
- 问题简述
- 缓存
- 一级缓存:session级别的缓存
- 二级缓存:SessionFactory级别的缓存,跨session存在
- 经常访问
- 改动不大
- 数量有限
- 事务ACID
- Atomic(原子性):事务不可分
- Consistency(一致性):数据一致,必须满足必要的约束,如:约束条件(a-b=1),如果a=2,那么b必须为1
- Itegrity(完整性):事务之间不会交叉执行,防止数据不一致
- Durability(持久性):事务运行成功后数据将持久到数据库,不会出现意外的回滚
- 事务并发问题
- 脏读:A事务读到B事务没有提交的数据(B可能出现回滚,导致数据不一致)
- 不可重复读:A有两次读数据,第一次在B提交数据之前,第二次在B提交事务之后,出现两次读取的数据不一致
- 幻读:和不可重复读一样,只是突出A在查询时的数据不一致
- 第一类丢失更新:A读取数据然后进行修改,B在A回滚数据之前提交了一次修改过的数据,最后A回滚到最开始的数据,丢失了B的操作
- 第二类丢失更新:A读取数据然后进行修改,在A提交数据之前,B先于A提交了一次修改过的数据,导致B提交的数据丢失了
- 悲观锁:基于数据库的加锁实现
- 思想:程序悲观的认为在它操作期间肯定会有人修改数据,所以先给数据库加把锁,不让其他人操作数据库,直到自己处理完成时才解锁
- 乐观锁:程序控制(不加锁,效率稍高)
- 思想:程序乐观的认为在它操作期间不会有人修改数据,所以先大胆的操作,只是在存数据时检查下是否有人修改过数据
- 具体实现:给数据库表中加上
version
字段,每次update都给version
加一,在update之前先检查version
值是否一致,不一致再重新执行事物,或者采取其他操作
- hibernate与ibatis的对比:
- ibatis非常简单易学,hibernate相对较复杂,门槛较高。
- 二者都是比较优秀的开源产品
- 当系统属于二次开发,无法对数据库结构做到控制和修改,那ibatis的灵活性将比hibernate更适合
- 系统数据处理量巨大,性能要求极为苛刻,这往往意味着我们必须通过经过高度优化的sql语句(或存储过程)才能达到系统性能设计指标。在这种情况下ibatis会有更好的可控性和表现。
- ibatis需要手写sql语句,也可以生成一部分,hibernate则基本上可以自动生成,偶尔会写一些hql。同样的需求,ibatis的工作量比hibernate要大很多。类似的,如果涉及到数据库字段的修改,hibernate修改的地方很少,而ibatis要把那些sql mapping的地方一一修改。
- 以数据库字段一一对应映射得到的po和hibernte这种对象化映射得到的po是截然不同的,本质区别在于这种po是扁平化的,不像hibernate映射的po是可以表达立体的对象继承,聚合等等关系的,这将会直接影响到你的整个软件系统的设计思路。
- hibernate现在已经是主流o/r mapping框架,从文档的丰富性,产品的完善性,版本的开发速度都要强于ibatis。
参考至:http://blog.csdn.net/cdh1213/article/details/5967405
java 复习001的更多相关文章
- java 复习003 之排序篇
由java 复习003跳转过来的C语言实现版见some-sort-algorithms 快速排序(不稳定 O(n log n)) package vell.bibi.sort_algorithms; ...
- java复习(1)---java与C++区别
[系列说明]java复习系列适宜有过java学习或C++基础或了解java初步知识的人阅读,目的是为了帮助学习过java但是好久没用已经遗忘了的童鞋快速捡起来.或者教给想快速学习java的童鞋如何应用 ...
- Java复习11. 单例编程
Java复习11. 单例编程 1.最简单的写法,那个方式是线程不安全的 public class Singleton { private static Singleton instance; ...
- Java复习9网路编程
Java 复习9网路编程 20131008 前言: Java语言在网络通信上面的开发要远远领先于其他编程语言,这是Java开发中最重要的应用,可以基于协议的编程,如Socket,URLConnecti ...
- Java复习8.多线程
Java复习8 多线程知识 20131007 前言: 在Java中本身就是支持多线程程序的,而不是像C++那样,对于多线程的程序,需要调用操作系统的API 接口去实现多线程的程序,而Java是支持多线 ...
- Java复习10.Servlet编程
Java复习10. Servlet编程知识 20131008 前言: 之前在大三下的时候,学习了一个月的JSP和Servlet知识,但是没有什么项目经验,把JSP Web开发学习实录看了前面几张,后面 ...
- Java复习6异常处理
Java复习6.异常处理 20131005 前言: Java中的异常处理机制是非常强大的,相比C++ 来说,更加系统.但是我们开发人员没有很好的使用这一点.一些小的程序是没有什么问题的,但是对于大型项 ...
- Java复习4.数组初始化.
Java复习4.Java中的数组声明方式 20131004 1.数组声明和初始化, 数组元素和变量一样,可以在定义的时候i进行初始化.数组元素的初始化工作实在编译阶段完成的,可以减少运行时间. 在初 ...
- Java复习7.输入输出流
Java复习7.输入输出流 20131005 前言: Java中涉及数据的读写,都是基于流的,这一块的知识相当重要,而且在Java中的数据,char字符是16bit的,所以存在字节流和字符流的区别.如 ...
随机推荐
- jQuery编程基础精华03(RadioButton操作,事件,鼠标)
RadioButton操作 取得RadioButton的选中值,被选中的radio只有一个值,所以直接用val() $('#btn1').click(function () { ...
- Linux Shell脚本读写XML文件
在Linux下如何用Shell脚本读写XML?现有一个config.xml <?xml version="1.0" encoding="UTF-8"?&g ...
- URAL 1957 Wrong Answer 暴力
Wrong Answer 思路: 1.先枚举4的全排列,即球赛的所有可能结果,一共4!=24种情况 2.对于每种情况,DFS 未确定的比赛 的结果,判断这种情况是否可达. 剪枝: 1.对于每种全排列, ...
- tengine lua 开源一 调用内部接口高效发送文件
tengine lua 开源一 调用内部接口高效发送文件 开源自己封装的sendfile 模块,可以高效的通过lua发送文件 源码地址:https://github.com/weinyzhou/Lu ...
- [leetcode72]Edit Distance(dp)
题目链接:https://leetcode.com/problems/edit-distance/ 题意:求字符串的最短编辑距离,就是有三个操作,插入一个字符.删除一个字符.修改一个字符,最终让两个字 ...
- Android中LayoutInflater的使用
Inflater英文意思是膨胀,在Android中应该是扩展的意思吧. LayoutInflater 的作用类似于 findViewById(),不同点是LayoutInflater是用来找layou ...
- int和integer;Math.round(11.5)和Math.round(-11.5)
int是java提供的8种原始数据类型之一.Java为每个原始类型提供了封装类,Integer是java为int提供的封装类.int的默认值为0,而Integer的默认值为null,即Integer可 ...
- UVa 12716 (GCD == XOR) GCD XOR
题意: 问整数n以内,有多少对整数a.b满足(1≤b≤a)且gcd(a, b) = xor(a, b) 分析: gcd和xor看起来风马牛不相及的运算,居然有一个比较"神奇"的结论 ...
- sql server压缩数据库和日志文件
DBCC SHRINKDATABASE 功能:压缩数据库 用法:DBCC SHRINKDATABASE tb_115sou_com 注意:只有产生许多未使用空间的操作(如截断表或删除表操作)后,执行收 ...
- oracle 11g rac 无法自动启动
如果以上的操作依然不能使数据库资源自动启动,那么参考下面这篇文章修改资源AUTO_START属性. 查看资源状态: crsctl status resource 资源 -p crs ...