标签:bsp 使用 lte build list blog 复制 的区别 template
Dao层代码:
@Override
public int findTotalCount(int cid,String rname) {
//String sql = "select count(*) from tab_route where cid = ?";
//1.定义sql模板
String sql = "select count(*) from tab_route where 1=1 ";
StringBuilder sb = new StringBuilder(sql);
List params = new ArrayList();//条件们
//2.判断参数是否有值
if(cid != 0){
sb.append( " and cid = ? ");
params.add(cid);//添加?对应的值
}
if(rname != null && rname.length() > 0){
sb.append(" and rname like ? ");
params.add("%"+rname+"%");
}
sql = sb.toString();
return template.queryForObject(sql,Integer.class,params.toArray());
}
String和StringBuffer区别
转载自:http://pengcqu.iteye.com/blog/487538
Java笔试题经常考到“String和StringBuffer的区别”,对于二者区别网上已经有很多,实际应用中也要主要到二者的区别,二者性能的差别很大。本人通过小例子来比较二者性能,效果显著!
String:是对象不是原始类型.
为不可变对象,一旦被创建,就不能修改它的值.
对于已经存在的String对象的修改都是重新创建一个新的对象,然后把新的值保存进去.
String 是final类,即不能被继承.
StringBuffer:
是一个可变对象,当对他进行修改的时候不会像String那样重新建立对象
它只能通过构造函数来建立,
StringBuffer sb = new StringBuffer();
对象被建立以后,在内存中就会分配内存空间,并初始保存一个null.通过它的append方法向其赋值.
sb.append("hello");
字符串连接操作中StringBuffer的效率要明显比String高:
String对象是不可变对象,每次操作Sting 都会重新建立新的对象来保存新的值.
StringBuffer对象实例化后,只对这一个对象操作。
我这里写了一个小的例子,来测试String和StringBuffer在时间和空间使用上的差别。
1 public class Test { 2 public static void main(String args[]) { 3 4 String str = "abc"; 5 StringBuffer sb = new StringBuffer("abc"); 6 Runtime runtime = Runtime.getRuntime(); 7 long start = System.currentTimeMillis(); 8 long startFreememory = runtime.freeMemory(); 9 for (int i = 0; i < 10000; i++) { 10 str += i; 11 //测试StringBuffer时候把注释打开 12 //sb.append(i); 13 } 14 long endFreememory = runtime.freeMemory(); 15 long end = System.currentTimeMillis(); 16 System.out.println("操作耗时:" + (end - start) + "ms," + "内存消耗:" 17 + (startFreememory - endFreememory)/1024 + "KB"); 18 } 19 }
测试结果:
使用String做10000次向一字符串后添加字符串
操作耗时:1872ms,内存消耗:1301KB
使用StringBuffer做10000次向一字符串后添加字符串
操作耗时:15ms,内存消耗:162KB
差别显著!
Dao持久层定义sql语句拼接参数之String和StringBuffer区别
标签:bsp 使用 lte build list blog 复制 的区别 template
原文地址:https://www.cnblogs.com/Yi-ling/p/14006917.html