posts - 110, comments - 101, trackbacks - 0, articles - 7
  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理

 


    
public static int getStrLenth(String str){
        
if(str==null || str.length()<0){
            
return 0;
        }

        
int len=0;
        
char c;
        
for(int i=str.length()-1;i>=0;i--){
            c
=str.charAt(i);
            
if (c > 255{
                
/*
                 * GBK 编码格式 中文占两个字节
                 * UTF-8 编码格式中文占三个字节 len += 3;
                 
*/

                len 
+= 2;
            }
 else {
                len
++;
            }

        }

        
return len;
    }


同时 获取一个字符串的长度 还可以使用
str.getBytes("GBK").length 这个和上面的代码一样的效果
如果工程的编码格式 是utf-8 那上面的getStrLenth(String str) 得到的长度 就不对了
str.getBytes("UTF-8").length 




posted @ 2011-06-12 22:10 云云 阅读(1550) | 评论 (0)编辑 收藏

1.char 

char的长度是固定的,最大支持2000个字节。 char的长度是固定的,比如说,你定义了char(20),即使你你插入abc,不足二十个字节,数据库也会在abc后面自动加上17个空格,以补足二十个字节; char是区分中英文的,中文在char中占两个字节,而英文占一个,所以char(20)你只能存20个字母或10个汉字。 char适用于长度比较固定的,一般不含中文的情况 

2.varchar/varchar2 

varchar是长度不固定的,最大支持4000个字节。 varchar是长度不固定的,比如说,你定义了varchar(20),当你插入abc,则在数据库中只占3个字节。 varchar同样区分中英文,这点同char。 varchar的效率低于char。 varchar2基本上等同于varchar,它是oracle自己定义的一个非工业标准varchar,不同之处在于,varchar2用null代替varchar的空字符串 varchar/varchar2适用于长度不固定的,一般不含中文的情况 

3.nvarchar/nvarchar2 

nvarchar和nvarchar2是长度不固定的 nvarchar不区分中英文,比如说:你定义了nvarchar(20),你可以存入20个英文字母/汉字或中英文组合,这个20定义的是字符数而不是字节数 nvarchar2基本上等同于nvarchar,不同在于nvarchar2中存的英文字母也占两个字节 nvarchar/nvarchar2适用于存放中文

posted @ 2011-06-12 21:49 云云 阅读(578) | 评论 (0)编辑 收藏

    /**
     * 取得指定子串在字符串中出现的次数。
     * <p/>
     * <p>
     * 如果字符串为<code>null</code>或空,则返回<code>0</code>。
     * <pre>
     * StringUtil.countMatches(null, *)       = 0
     * StringUtil.countMatches("", *)         = 0
     * StringUtil.countMatches("abba", null)  = 0
     * StringUtil.countMatches("abba", "")    = 0
     * StringUtil.countMatches("abba", "a")   = 2
     * StringUtil.countMatches("abba", "ab")  = 1
     * StringUtil.countMatches("abba", "xxx") = 0
     * </pre>
     * </p>
     * 
@param str    要扫描的字符串
     * 
@param subStr 子字符串
     * 
@return 子串在字符串中出现的次数,如果字符串为<code>null</code>或空,则返回<code>0</code>
     
*/

    
public static int countMatches(String str, String subStr) {
        
if ((str == null|| (str.length() == 0|| (subStr == null|| (subStr.length() == 0)) {
            
return 0;
        }


        
int count = 0;
        
int index = 0;

        
while ((index = str.indexOf(subStr, index)) != -1{
            count
++;
            index 
+= subStr.length();
        }


        
return count;
    }

posted @ 2011-05-26 13:51 云云 阅读(1749) | 评论 (0)编辑 收藏

1.声明一个map: Map map = new HashMap(); 
2.向map中放值,注意:map是key-value的形式存放的.如:

map.put(”sa”,”dd”);

3.从map中取值:String str = map.get(”sa”).toString();结果是:str = ”dd”;

4.遍历一个map,从中取得key 和value

JDK1.
5

Map m 
= new HashMap(); 
for (Object o : map.keySet()) 
map.get(o); 
}


JDK1.
4

Map map 
= new HashMap() ; 

Iterator it 
= map.entrySet().iterator() ; 
while (it.hasNext()) 

Map.Entry entry 
= (Map.Entry) it.next() ; 
Object key 
= entry.getKey() ; 
Object value 
= entry.getValue() ; 
}

遍历效率对比:
第一种:

  Map map 
= new HashMap();

  Iterator iter 
= map.entrySet().iterator();

  
while (iter.hasNext()) {

  Map.Entry entry 
= (Map.Entry) iter.next(); Object key = entry.getKey();

  Object val 
= entry.getValue();

  }


  效率高,以后一定要使用此种方式
!

  第二种:

  Map map 
= new HashMap();

  Iterator iter 
= map.keySet().iterator();

  
while (iter.hasNext()) {

  Object key 
= iter.next();

  Object val 
= map.get(key);

  }


  效率低,以后尽量少使用
!

  HashMap的遍历有两种常用的方法,那就是使用keyset及entryset来进行遍历,但两者的遍历速度是有差别的,下面请看实例:

  
public class HashMapTest {

  
public static void main(String[] args) {

  HashMap hashmap 
= new HashMap();

  
for (int i = 0; i <1000; i ) {

  hashmap.put(
"" i, "thanks");

  }


  
long bs = Calendar.getInstance().getTimeInMillis();

  Iterator iterator 
= hashmap.keySet().iterator();

  
while (iterator.hasNext()) {

  System.out.print(hashmap.get(iterator.next()));

  }


  System.out.println();

  System.out.println(Calendar.getInstance().getTimeInMillis() 
- bs);

  listHashMap();

  }


  
public static void listHashMap() {

  java.util.HashMap hashmap 
= new java.util.HashMap();

  
for (int i = 0; i <1000; i ) {

  hashmap.put(
"" i, "thanks");

  }


  
long bs = Calendar.getInstance().getTimeInMillis();

  java.util.Iterator it 
= hashmap.entrySet().iterator();

  
while (it.hasNext()) {

  java.util.Map.Entry entry 
= (java.util.Map.Entry) it.next();

  
// entry.getKey() 返回与此项对应的键

  
// entry.getValue() 返回与此项对应的值

  System.out.print(entry.getValue());

  }


  System.out.println();

  System.out.println(Calendar.getInstance().getTimeInMillis() 
- bs);

  }


  }


  对于keySet其实是遍历了2次,一次是转为iterator,一次就从hashmap中取出key所对于的value。而entryset只是遍历了第一次,他把key和value都放到了entry中,所以就快了。

  注:Hashtable的遍历方法和以上的差不多
!

posted @ 2011-05-12 21:13 云云 阅读(10252) | 评论 (3)编辑 收藏

<SCRIPT LANGUAGE="JavaScript">
<!--
    function getGener()
{
      var gender
=document.forms[0].gener;     
      var genderValue
="";
      
if(gender.length){
          
for(var i=0;i<gender.length;i++){
             
if(gender[i].checked){
               genderValue
=gender[i].value;
               
break;
             }

          }

      }
else{
          
if(gender.checked){
               genderValue
=gender.value;
        }

      }

      alert(genderValue);
      
return false;
    }

//-->
</SCRIPT>
 
<BODY>
  
<form name="" onsubmit="return getGener()">
     
<input  type="radio" name="gener" value="Man">Man
     
<input type="radio" name="gener" value="Women">Women
     
<input type="submit" value="提交"> 
  
</form>
 
</BODY>

posted @ 2011-05-11 22:20 云云 阅读(760) | 评论 (4)编辑 收藏

     摘要: package com.ali.luna.commons.util; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; /** *//**  * 鏃ユ湡鏃堕棿宸ュ叿绫伙紝杩涜鍚勭鏃ユ湡鏃堕...  阅读全文

posted @ 2011-05-05 18:29 云云 阅读(932) | 评论 (0)编辑 收藏


以前通常是用svn客户端提交文件 用起来不太方便
所以后来用myeclipse的插件来管理

第一次用myeclipse的svn插件提交时就出了问题
不知不觉就把class文件和log还有target文件夹提交上去了

好了总结了这个问题 希望对新人有帮助 不要出了问题找不到原因

先把项目share到svn库
然后选择项目中的target文件夹 右键 选择Team ---添加至svn:ignore

按照这样设置你不想提交到svn库的文件

posted @ 2011-05-04 15:29 云云 阅读(11039) | 评论 (1)编辑 收藏

http://blog.sina.com.cn/s/blog_3fed3a390100kn7d.html

posted @ 2011-04-11 09:57 云云 阅读(1597) | 评论 (0)编辑 收藏

setTimeout(表达式,延迟时间); 单位:ms(毫秒);1s=1000ms; 

  setInterval(表达式,交互时间);  单位:ms(毫秒);1s=1000ms; 

  window.setTimeout()

   在执行时,它从载入后延迟指定的时间去执行一个表达式或者是函数;仅执行一次;和window.clearTimeout一起使用.

  window.setInterval()

   在执行时,它从载入页面后每隔指定的时间执行一个表达式或者是函数;(功能类似于递归函数);和window.clearInterval一起使用.

  1,基本用法:

   执行一段代码:  var i=0;

   setTimeout("i+=1;alert(i)",1000);

   执行一个函数:

   var i=0;

   setTimeout(function(){i+=1;alert(i);},1000);

   //注意比较上面的两种方法的不同。

   下面再来一个执行函数的:

  var i=0;
function test(){
i+=1;
alert(i);
}
setTimeout("test()",1000);
也可以这样:
setTimeout(test,1000);

   总结:

   setTimeout的原型是这样的:

   iTimerID = window.setTimeout(vCode, iMilliSeconds [, sLanguage])

  setTimeout有两种形式

  setTimeout(code,interval)

  setTimeout(func,interval,args)

  其中code是一个字符串

  func是一个函数.

  注意"函数"的意义,是一个表达式,而不是一个语句.

  比如你想周期性执行一个函数

 function a(){
//...
}

  可写为

  setInterval("a()",1000)

  或

  setInterval(a,1000)

  这里注意第二种形式中,是a,不要写成a(),切记!!!

  展开来说,不管你这里写的是什么,如果是一个变量,一定是一个指向某函数的变量;如果是个函数,那它的返回值就 要是个函数

  2,用setTimeout实现setInterval的功能

  思路很简单,就是在一个函数中调用不停执行自己,有点像递归

  var i=0;
function xilou(){
i+=1;
if(i>10){alert(i);return;}
setTimeout("xilou()",1000);
//用这个也可以
//setTimeout(xilou,1000);
}

  3,在类中使用setTimeout

  终于到正题了,其实在类中使用大家遇到的问题都是关于this的,只要解决了这个this的问题就万事无忧了。

  呵呵。让我们来分析一下:

  function xilou(){
//by 西楼冷月 www.chinacms.org
this.name="xilou";
this.sex="男";
this.num=0;
}
xilou.prototype.count=function(){
this.num+=1;
alert(this.num);
if(this.num>10){return;}
//下面用四种方法测试,一个一个轮流测试。
setTimeout("this.count()",1000);//A:当下面的x.count()调用时会发生错误:对象不支持此属性或方法。
setTimeout("count()",1000);//B:错误显示:缺少对象
setTimeout(count,1000);//C:错误显示:'count'未定义
//下面是第四种 by 西楼冷月 www.chinacms.org
var self=this;
setTimeout(function(){self.count();},1000);//D:正确

}

var x=new xilou();
x.count();

  错误分析:

  A:中的this其实指是window对象,并不是指当前实例对象

  B:和C:中的count()和count其实指的是单独的一个名为count()的函数,但也可以是window.count(),因为window.count()可以省略为count()

  D:将变量self指向当前实例对象,这样js解析引擎就不会混肴this指的是谁了。

  话说回来,虽然我们知道setTimeout("this.count()",1000)中的this指的是window对象,但还是不明白为什么会是

  window对象^_^(有点头晕...)

  那我们可以想象一下这个setTimeout是怎样被定义的:

  setTimeout是window的一个方法,全称是这样的:window.setTimeout()

  那应该是这样被定义的:

  window.setTimeout=function(vCode, iMilliSeconds [, sLanguage]){
//.....代码
return timer//返回一个标记符
}

  所以当向setTimeout()传入this的时候,当然指的是它所属的当前对象window了

posted @ 2011-04-09 00:25 云云 阅读(1523) | 评论 (0)编辑 收藏

HttpSession常见问题
    1、session在何时被创建 

    一个常见的误解是以为session在有客户端访问时就被创建,然而事实是直到某server端程序调用 HttpServletRequest.getSession(true)这样的语句时才被创建,注意如果JSP没有显示的使用 <%@page session="false"%> 关闭session,则JSP文件在编译成Servlet时将会自动加上这样一条语句HttpSession session = HttpServletRequest.getSession(true);这也是JSP中隐含的session对象的来历。 

    由于session会消耗内存资源,因此,如果不打算使用session,应该在所有的JSP中关闭它。 

    2、session何时被删除 

    综合前面的讨论,session在下列情况下被删除a.程序调用HttpSession.invalidate();或b.距离上一次收到客户端发送的session id时间间隔超过了session的超时设置;或c.服务器进程被停止(非持久session) 

    3、如何做到在浏览器关闭时删除session 

    严格的讲,做不到这一点。可以做一点努力的办法是在所有的客户端页面里使用javascript代码window.oncolose来监视浏览器的关闭动作,然后向服务器发送一个请求来删除session。但是对于浏览器崩溃或者强行杀死进程这些非常规手段仍然无能为力。 

    4、有个HttpSessionListener是怎么回事 

    你可以创建这样的listener去监控session的创建和销毁事件,使得在发生这样的事件时你可以做一些相应的工作。注意是session的创建和销毁动作触发listener,而不是相反。类似的与HttpSession有关的listener还有 HttpSessionBindingListener,HttpSessionActivationListener和 HttpSessionAttributeListener。 

    5、存放在session中的对象必须是可序列化的吗 

    不是必需的。要求对象可序列化只是为了session能够在集群中被复制或者能够持久保存或者在必要时server能够暂时把session交换出内存。在 Weblogic Server的session中放置一个不可序列化的对象在控制台上会收到一个警告。我所用过的某个iPlanet版本如果session中有不可序列化的对象,在session销毁时会有一个Exception,很奇怪。 

    6、如何才能正确的应付客户端禁止cookie的可能性 

    对所有的URL使用URL重写,包括超链接,form的action,和重定向的URL,具体做法参见[6]
http://e-docs.bea.com/wls/docs70/webapp/sessions.html#100770 

    7、开两个浏览器窗口访问应用程序会使用同一个session还是不同的session 

    参见第三小节对cookie的讨论,对session来说是只认id不认人,因此不同的浏览器,不同的窗口打开方式以及不同的cookie存储方式都会对这个问题的答案有影响。 

    8、如何防止用户打开两个浏览器窗口操作导致的session混乱 

    这个问题与防止表单多次提交是类似的,可以通过设置客户端的令牌来解决。就是在服务器每次生成一个不同的id返回给客户端,同时保存在session里,客户端提交表单时必须把这个id也返回服务器,程序首先比较返回的id与保存在session里的值是否一致,如果不一致则说明本次操作已经被提交过了。可以参看《J2EE核心模式》关于表示层模式的部分。需要注意的是对于使用javascript window.open打开的窗口,一般不设置这个id,或者使用单独的id,以防主窗口无法操作,建议不要再window.open打开的窗口里做修改操作,这样就可以不用设置。 

    9、为什么在Weblogic Server中改变session的值后要重新调用一次session.setValue 
    
    做这个动作主要是为了在集群环境中提示Weblogic Server session中的值发生了改变,需要向其他服务器进程复制新的session值。 

    10、为什么session不见了 

    排除session正常失效的因素之外,服务器本身的可能性应该是微乎其微的,虽然笔者在iPlanet6SP1加若干补丁的Solaris版本上倒也遇到过;浏览器插件的可能性次之,笔者也遇到过3721插件造成的问题;理论上防火墙或者代理服务器在cookie处理上也有可能会出现问题。
出现这一问题的大部分原因都是程序的错误,最常见的就是在一个应用程序中去访问另外一个应用程序。我们在下一节讨论这个问题。 

    七、跨应用程序的session共享 

    常常有这样的情况,一个大项目被分割成若干小项目开发,为了能够互不干扰,要求每个小项目作为一个单独的web应用程序开发,可是到了最后突然发现某几个小项目之间需要共享一些信息,或者想使用session来实现SSO(single sign on),在session中保存login的用户信息,最自然的要求是应用程序间能够访问彼此的session。 

    然而按照Servlet规范,session的作用范围应该仅仅限于当前应用程序下,不同的应用程序之间是不能够互相访问对方的session的。各个应用服务器从实际效果上都遵守了这一规范,但是实现的细节却可能各有不同,因此解决跨应用程序session共享的方法也各不相同。 

    首先来看一下Tomcat是如何实现web应用程序之间session的隔离的,从Tomcat设置的cookie路径来看,它对不同的应用程序设置的 cookie路径是不同的,这样不同的应用程序所用的session id是不同的,因此即使在同一个浏览器窗口里访问不同的应用程序,发送给服务器的session id也可以是不同的。
 
    
    根据这个特性,我们可以推测Tomcat中session的内存结构大致如下。


    笔者以前用过的iPlanet也采用的是同样的方式,估计SunONE与iPlanet之间不会有太大的差别。对于这种方式的服务器,解决的思路很简单,实际实行起来也不难。要么让所有的应用程序共享一个session id,要么让应用程序能够获得其他应用程序的session id。

    iPlanet中有一种很简单的方法来实现共享一个session id,那就是把各个应用程序的cookie路径都设为/(实际上应该是/NASApp,对于应用程序来讲它的作用相当于根)。

    <session-info>
    <path>/NASApp</path>
    </session-info>

    需要注意的是,操作共享的session应该遵循一些编程约定,比如在session attribute名字的前面加上应用程序的前缀,使得setAttribute("name", "neo")变成setAttribute("app1.name", "neo"),以防止命名空间冲突,导致互相覆盖。

    在Tomcat中则没有这么方便的选择。在Tomcat版本3上,我们还可以有一些手段来共享session。对于版本4以上的Tomcat,目前笔者尚未发现简单的办法。只能借助于第三方的力量,比如使用文件、数据库、JMS或者客户端cookie,URL参数或者隐藏字段等手段。

    我们再看一下Weblogic Server是如何处理session的。


    从截屏画面上可以看到Weblogic Server对所有的应用程序设置的cookie的路径都是/,这是不是意味着在Weblogic Server中默认的就可以共享session了呢?然而一个小实验即可证明即使不同的应用程序使用的是同一个session,各个应用程序仍然只能访问自己所设置的那些属性。这说明Weblogic Server中的session的内存结构可能如下:

    对于这样一种结构,在session机制本身上来解决session共享的问题应该是不可能的了。除了借助于第三方的力量,比如使用文件、数据库、JMS 或者客户端cookie,URL参数或者隐藏字段等手段,还有一种较为方便的做法,就是把一个应用程序的session放到ServletContext 中,这样另外一个应用程序就可以从ServletContext中取得前一个应用程序的引用。示例代码如下, 

    应用程序A :
    context.setAttribute("appA", session); 

    应用程序B :
    contextA = context.getContext("/appA"); 
    HttpSession sessionA = (HttpSession)contextA.getAttribute("appA"); 

    值得注意的是这种用法不可移植,因为根据ServletContext的JavaDoc,应用服务器可以处于安全的原因对于context.getContext("/appA");返回空值,以上做法在Weblogic Server 8.1中通过。 

    那么Weblogic Server为什么要把所有的应用程序的cookie路径都设为/呢?原来是为了SSO,凡是共享这个session的应用程序都可以共享认证的信息。一个简单的实验就可以证明这一点,修改首先登录的那个应用程序的描述符weblogic.xml,把cookie路径修改为/appA访问另外一个应用程序会重新要求登录,即使是反过来,先访问cookie路径为/的应用程序,再访问修改过路径的这个,虽然不再提示登录,但是登录的用户信息也会丢失。注意做这个实验时认证方式应该使用FORM,因为浏览器和web服务器对basic认证方式有其他的处理方式,第二次请求的认证不是通过session来实现的。具体请参看[7] secion 14.8 Authorization,你可以修改所附的示例程序来做这些试验。 

    八、总结 

    session机制本身并不复杂,然而其实现和配置上的灵活性却使得具体情况复杂多变。这也要求我们不能把仅仅某一次的经验或者某一个浏览器,服务器的经验当作普遍适用的经验,而是始终需要具体情况具体分析。 

posted @ 2011-04-09 00:04 云云 阅读(8521) | 评论 (2)编辑 收藏

仅列出标题
共12页: First 上一页 4 5 6 7 8 9 10 11 12 下一页