2007年7月25日

          Javascript的IE和Firefox兼容性匯編

               摘要: 以下以 IE 代替 Internet Explorer,以 MF 代替 Mozzila Firefox 1. document.form.item 問題     (1)現(xiàn)有問題:         現(xiàn)有代碼中存在許多 document.formName.item("itemName") 這樣的語...  閱讀全文

          posted @ 2007-09-06 09:26 萬博 閱讀(1665) | 評論 (0)編輯 收藏

          OSCache 緩存對象的總結(jié)

          OSCache是當前運用最廣的緩存方案。其主被用的最廣泛功能是緩存頁面,這里主要是用其緩存文件對象。
          運用OScache的步驟:
           1.取得oscache.jar 文件放到 /WEB-INF/lib 或相應(yīng)類庫目錄 目錄中。
           2.oscache.jar依賴commons-collections.jar包。如果你的jdk版本為1.3,
             建議在lib中加入Apache Common Lib 的commons-collections.jar包。
             如jdk是1.4以上則不必要。
           3.src根目錄或發(fā)布環(huán)境的/WEB-INF/classes 目錄下放入oscache.properties。
           
           cache.memory
           值為true 或 false ,默認為在內(nèi)存中作緩存,
           如設(shè)置為false,那cache只能緩存到數(shù)據(jù)庫或硬盤中,那cache還有什么意義:)

           cache.capacity
           緩存元素個數(shù)

           cache.persistence.class
           持久化緩存類,如此類打開,則必須設(shè)置cache.path信息

           cache.cluster 相關(guān)
           為集群設(shè)置信息。
           如cache.cluster.multicast.ip為廣播IP地址
             cache.cluster.properties為集群屬性

          cache.path   
          硬盤持久化時存放文件的目錄。如果目錄不存在OSCache會自動創(chuàng)建。
          Windows系統(tǒng):c:\\myapp\\cache。其它:/opt/myapp/cache

          cache.persistence.overflow.only*   
          是否只有當指定的內(nèi)存緩存已經(jīng)滿時才進行持久化。推薦使用true,flase是為向后兼容。

          cache.unlimited.disk   
          硬盤緩存是否有限制。缺省為cache.capacity指定的值

          運用:
              com.opensymphony.oscache.general.GeneralCacheAdministrator
          GeneralCacheAdministrator主要對實現(xiàn)持久化對象的保存以及取出的相關(guān)的操作。

          Object getFromCache(String key)    //根據(jù)key獲取緩存對象
          Object getFromCache(String key , int refreshInterval)//refreshInterval時間內(nèi),根據(jù)key獲取緩存對象
          void putInCache(String key ,Object obj) //保存被緩存對象
          void flushAll()                                              //刪除所有被緩存的對象
          void flushAll(Date date)                            //在指定的時間去刪除所有被緩存的對象
          void cancelUpdate(String key)                //取消未確定的更新

          Java代碼
           1 package com.iflytek;   
           2    
           3 import java.io.BufferedInputStream;   
           4 import java.io.BufferedOutputStream;   
           5 import java.io.File;   
           6 import java.io.FileInputStream;   
           7 import java.io.IOException;   
           8 import java.text.SimpleDateFormat;   
           9 import java.util.Date;   
          10    
          11 import javax.servlet.ServletException;   
          12 import javax.servlet.http.HttpServlet;   
          13 import javax.servlet.http.HttpServletRequest;   
          14 import javax.servlet.http.HttpServletResponse;   
          15 import javax.servlet.http.HttpSession;   
          16    
          17 import com.opensymphony.oscache.base.NeedsRefreshException;   
          18 import com.opensymphony.oscache.general.GeneralCacheAdministrator;   
          19    
          20    
          21 public class DisplayChart extends HttpServlet {   
          22    
          23     /**  
          24      * Default constructor.  
          25      */   
          26     public DisplayChart() {   
          27         super();   
          28     }   
          29    
          30     /**  
          31      * Init method.  
          32      *  
          33      * @throws ServletException never.  
          34      */   
          35     public void init() throws ServletException {   
          36         return;   
          37     }   
          38    
          39       
          40     public static GeneralCacheAdministrator cacheAdmin = new GeneralCacheAdministrator();   
          41     public void service(HttpServletRequest request,    
          42                         HttpServletResponse response)   
          43             throws ServletException, IOException {   
          44        
          45         String path = getServletContext().getRealPath("/");    
          46         File file = null;   
          47         SimpleDateFormat sdf= new SimpleDateFormat("hh-mm-ss");   
          48         try {   
          49             file = (File)cacheAdmin.getFromCache(sdf.format(new Date()));   
          50             System.out.println("來自緩存!"+ sdf.format(new Date()));   
          51         } catch (NeedsRefreshException e) {   
          52             file = new File(path+"xmls\\Pipe11.xml");   
          53             cacheAdmin.putInCache(sdf.format(new Date()), file);   
          54             System.out.println("--緩存沒有!"+sdf.format(new Date()));              
          55         }   
          56         sendResponse(file,response);   
          57         return;   
          58     }   
          59     /**  
          60      * 把文件用響應(yīng)流寫出  
          61      * @param file  
          62      * @param response  
          63      * @throws IOException  
          64      */   
          65     public void sendResponse(File file,HttpServletResponse response) throws IOException{   
          66         BufferedInputStream  bis = new BufferedInputStream(new FileInputStream(file));   
          67         BufferedOutputStream bos = new BufferedOutputStream(response.getOutputStream());   
          68         byte[] input = new byte[1024];   
          69         boolean eof = false;   
          70         while (!eof) {   
          71             int length = bis.read(input);   
          72             if (length == -1) {   
          73                 eof = true;   
          74             }    
          75             else {   
          76                 bos.write(input, 0, length);   
          77             }   
          78         }   
          79         bos.flush();   
          80         bis.close();   
          81         bos.close();   
          82     }   
          83    
          84 }   
          85 

          posted @ 2007-07-26 15:58 萬博 閱讀(1970) | 評論 (0)編輯 收藏

          lazy initialization 實現(xiàn) Singleton 時 synchronized 的必要性說明

          首先了解一下Singleton模式通常的兩種表現(xiàn)形式:
          第一種形式:
          public class Singleton { 
              
          private Singleton(){} 
              
          //在自己內(nèi)部定義自己一個實例,是不是很奇怪? 
              
          //注意這是private 只供內(nèi)部調(diào)用 
              private static Singleton instance = new Singleton(); 
              
          //這里提供了一個供外部訪問本class的靜態(tài)方法,可以直接訪問 
              public static Singleton getInstance() { 
                 
          return instance; 
              }
          }
          第二種形式:
          public class Singleton { 
             private static Singleton instance = null
             public static synchronized Singleton getInstance() { 
                //這個方法比上面有所改進,不用每次都進行生成對象,只是第一次 
                //使用時生成實例,提高了效率! 
                if (instance==null) instance=new Singleton(); 
                return instance; 
             } 
          }
             
          使用Singleton.getInstance()可以訪問單態(tài)類。 
             上面第二中形式就是lazy initialization,也就是說第一次調(diào)用時初始Singleton,以后就不用再生成了。 
             注意到lazy initialization形式中的synchronized,這個synchronized很重要,如果沒有synchronized,那么使用getInstance()是有可能得到多個Singleton實例。

             那么為什么只有使用synchronized關(guān)鍵字才可以達到單態(tài)的目的呢?synchronized到底有什么含義呢?
             synchronized 關(guān)鍵字,它包括兩種用法:synchronized 方法和 synchronized 塊。
          1. synchronized 方法:通過在方法聲明中加入 synchronized關(guān)鍵字來聲明 synchronized 方法。如:
          public synchronized void accessVal(int newVal); 
             synchronized 方法控制對類成員變量的訪問:每個類實例對應(yīng)一把鎖,每個 synchronized 方法都必須獲得調(diào)用該方法的類實例的鎖方能執(zhí)行,否則所屬線程阻塞,方法一旦執(zhí)行,就獨占該鎖,直到從該方法返回時才將鎖釋放,此后被阻塞的線程方能獲得該鎖,重新進入可執(zhí)行狀態(tài)。這種機制確保了同一時刻對于每一個類實例,其所有聲明為 synchronized 的成員函數(shù)中至多只有一個處于可執(zhí)行狀態(tài)(因為至多只有一個能夠獲得該類實例對應(yīng)的鎖),從而有效避免了類成員變量的訪問沖突(只要所有可能訪問類成員變量的方法均被聲明為 synchronized)。 
             在 Java 中,不光是類實例,每一個類也對應(yīng)一把鎖,這樣我們也可將類的靜態(tài)成員函數(shù)聲明為 synchronized ,以控制其對類的靜態(tài)成員變量的訪問。 
             synchronized 方法的缺陷:若將一個大的方法聲明為synchronized 將會大大影響效率,典型地,若將線程類的方法 run() 聲明為 synchronized ,由于在線程的整個生命期內(nèi)它一直在運行,因此將導(dǎo)致它對本類任何 synchronized 方法的調(diào)用都永遠不會成功。當然我們可以通過將訪問類成員變量的代碼放到專門的方法中,將其聲明為 synchronized ,并在主方法中調(diào)用來解決這一問題,但是 Java 為我們提供了更好的解決辦法,那就是 synchronized 塊。
          2. synchronized 塊:通過 synchronized關(guān)鍵字來聲明synchronized 塊。語法如下:
          synchronized(syncObject) { 
             //允許訪問控制的代碼 
          synchronized 塊是這樣一個代碼塊,其中的代碼必須獲得對象 syncObject (如前所述,可以是類實例或類)的鎖方能執(zhí)行,具體機制同前所述。由于可以針對任意代碼塊,且可任意指定上鎖的對象,故靈活性較高。


          對synchronized(this)的一些理解

          一、當兩個并發(fā)線程訪問同一個對象object中的這個synchronized(this)同步代碼塊時,一個時間內(nèi)只能有一個線程得到執(zhí)行。另一個線程必須等待當前線程執(zhí)行完這個代碼塊以后才能執(zhí)行該代碼塊。

          二、然而,當一個線程訪問object的一個synchronized(this)同步代碼塊時,另一個線程仍然可以訪問該object中的非synchronized(this)同步代碼塊。

          三、尤其關(guān)鍵的是,當一個線程訪問object的一個synchronized(this)同步代碼塊時,其他線程對object中所有其它synchronized(this)同步代碼塊的訪問將被阻塞。

          四、第三個例子同樣適用其它同步代碼塊。也就是說,當一個線程訪問object的一個synchronized(this)同步代碼塊時,它就獲得了這個object的對象鎖。結(jié)果,其它線程對該object對象所有同步代碼部分的訪問都被暫時阻塞。

          五、以上規(guī)則對其它對象鎖同樣適用

          posted @ 2007-07-25 14:14 萬博 閱讀(475) | 評論 (0)編輯 收藏

          <2007年7月>
          24252627282930
          1234567
          891011121314
          15161718192021
          22232425262728
          2930311234

          導(dǎo)航

          統(tǒng)計

          留言簿(1)

          隨筆檔案(13)

          搜索

          積分與排名

          最新隨筆

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 连山| 萨嘎县| 团风县| 出国| 楚雄市| 五原县| 五华县| 双峰县| 聂拉木县| 康马县| 绥宁县| 阳春市| 济宁市| 定南县| 礼泉县| 台江县| 上高县| 大城县| 广州市| 南城县| 肇庆市| 万荣县| 遂昌县| 清涧县| 读书| 潢川县| 和硕县| 灌云县| 随州市| 纳雍县| 读书| 化隆| 体育| 南皮县| 伊通| 达日县| 同心县| 皋兰县| 汝城县| 尤溪县| 武清区|