码迷,mamicode.com
首页 > 数据库 > 详细

Dao持久层定义sql语句拼接参数之String和StringBuffer区别

时间:2020-11-24 12:07:25      阅读:8      评论:0      收藏:0      [点我收藏+]

标签: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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!