一、List<PolicyBasicBo> listPolicyBasic = new ArrayList<>();java
List list = new ArrayList();
这是个典型的向下转型,即多态性的表现.
由于list是一个接口,接口的方法须要被覆写才可以直接拿过来使用.数据库
至关于:Animal a=new Monkey();猴子也是动物的一种。编程
这是用父类的引用指向子类对象。
面向接口编程都是这么写的。如:public void test(List list) {
//do something...
}若是这个方法带的参数是ArrayList类型的,那么只有ArrayList的对象才能够传过来
而如今是用List作为参数,就表示只要是List接口的子类对象均可以传进来,如ArrayList,LinkedList,Vector 。设计模式
List<String> list = new ArrayList<String>();
编译时类型是List,运行时类型是ArrayList,而List接口的实现类不仅有ArrayList一个,用一个List类型的引用这是“面向接口编程”,好处有不少,提可是尽可能面向接口编程,这里只说一个这样写的好处:
之后咱们会用到不少不是咱们写的类,咱们叫第三方类库,在类库里面极可能会返回一个这样的列表,可是他未必会返给你一个ArrayList,没准是人家自 己写的一个实现类都说不许,那么咱们面向接口编程,不须要了解是什么实现类,咱们都把它们当List接收过来就行了,咱们就当成List来用。提升程序的 透明性,让底层的实现对上层使用者封装。 对底层来讲,这种转换的时间几乎能够忽略不计,这个是实现多态的基础,
若是了解工厂方法设计模式,只有这样才能达到要求,这种作法也是面向对
象程序设计三大特性之一——多态。若是我哪天不用 ArrayList 了,要用
其余的 LinkedList 了,这样我只要在变量声明部分修改就能够了,下面
的代码能够一行不动。
实际上这样作,在 Java 中还有不少,像 JDBC 中的 Connection、
PreparedStatment、ResultSet 等等,这些都是接口,若是不去研究 JDBC
驱动提供的源代码,根本就不会知道其具体的实现类是哪个,对于开发人员
来讲,只要知道这些接口中的方法,以及该如何使用这些方法就足够了,不需
要去考虑底层的实现,正由于如此,换一种数据库只要更改其链接驱动和链接
字符串就够了,其余的根本用不着改。
固然了,若是要使用某个类中的独有的方法,那只能使用第二种写法了。数组
二、if (null != listPolicyBasic && !listPolicyBasic.isEmpty()) {
PolicyBasicBo policyBasic = listPolicyBasic.get(0);
policyBo.setPolicyBasic(policyBasic);
}函数
判断字符串不为空,而后执行逻辑,原来是listPolicyBasic.size()>0, IsEmpty函数 返回Boolean值 。工具
1 java中的length属性是针对数组说的,好比说你声明了一个数组,想知道这个数组的长度则用到了length这个属性.
2 java中的length()方法是针对字符串String说的,若是想看这个字符串的长度则用到length()这个方法.
3.java中的size()方法是针对泛型集合说的,若是想看这个泛型有多少个元素,就调用此方法来查看!
这个例子来演示这两个方法和一个属性的用法
public static void main(String[] args) {
String []list={"ma","cao","yuan"};
String a="macaoyuan";
System.out.println(list.length);
System.out.println(a.length());
List<Object> array=new ArrayList();
array.add(a);
System.out.println(array.size());
}
输出的值为:
3
9
1设计
三、日志
@Repository("polResumeDao")
public class PolResumeDaoImpl implements PolResumeDao {
/**
* 日志管理工具实例.
*/
private static final Logger logger = LoggerFactory.getLogger(PolResumeDaoImpl.class);对象
}
final 是本 logger 不能再指向其余 Logger 对象 , static 修饰的变量是无论建立了new了多少个实例,也只建立一次,节省空间,若是每次都建立Logger的话比较浪费内存, static 是加载即建立实例。使用的时候能够直接拿来 ,用static修饰既节约空间,效率也好 ;
**.class是将你要加入日志的类加进入 假如你的 PolResumeDaoImpl 这个类须要加日志信息就在 private static Logger logger = Logger.getLogger( PolResumeDaoImpl .class); 这是获取一个 PolResumeDaoImpl 类的logger, PolResumeDaoImpl 内定义的日志信息就可以显示出来了,
获得 PolResumeDaoImpl 的Class类型对象,由于Logger.getLogger方法须要传入Class类型对象,这样该logger的信息中会详细体现出是哪一个路径的哪一个类的日志。