国产精品亚洲lv粉色,色偷偷女男人的天堂亚洲网,相泽亚洲一区中文字幕http://www.tkk7.com/xtitan/學習與生活的痕跡zh-cnSat, 10 May 2025 19:01:29 GMTSat, 10 May 2025 19:01:29 GMT60openlayers 標記1http://www.tkk7.com/xtitan/archive/2010/03/16/315568.html泰坦泰坦Tue, 16 Mar 2010 03:59:00 GMThttp://www.tkk7.com/xtitan/archive/2010/03/16/315568.htmlhttp://www.tkk7.com/xtitan/comments/315568.htmlhttp://www.tkk7.com/xtitan/archive/2010/03/16/315568.html#Feedback0http://www.tkk7.com/xtitan/comments/commentRss/315568.htmlhttp://www.tkk7.com/xtitan/services/trackbacks/315568.html    OpenLayers基礎知識:
      OpenLayers是一個開源的js框架,用于在您的瀏覽器中實現地圖瀏覽的效果和基本的zoom,pan等功能。OpenLayers支持的地圖來源 包括了WMS,GoogleMap,KaMap,MSVirtualEarth等等,您也可以用簡單的圖片作為源,在這一方面OPenLayers提供了 非常多的選擇。
      要使用OpenLayers,您可以到它的官方網站http://www.openlayers.org下載他的壓縮 包,解壓后可以看到其中的一些目錄和 文件??截恉ist目錄下的OpenLayer.js、根目錄下的lib目錄、根目錄下的img目錄到你網站的scripts目錄下(當然,這個只是例 子,您網站的目錄結構您自己說得算,只要保證OpenLayers.js,/lib,/img在同一目錄中即可)。
      OpenLayers中最重要的2個對象Map和Layer.
      OpenLayers.Map的實體化方法:
         var map = new OpenLayers.Map("map");
         這里參數"map"對應頁面中顯示Map地圖的DIV的id名稱。
     OpenLayers.Layer為創建圖層對象,OpenLayers提供了很多圖層的擴展:
         * OpenLayers.Layer.Image
         * OpenLayers.Layer.HTTPRequest
         * OpenLayers.Layer.Grid
         * OpenLayers.Layer.WMS
         * OpenLayers.Layer.KaMap
         * OpenLayers.Layer.EventPane
         * OpenLayers.Layer.Google
         * OpenLayers.Layer.VirtualEarth
         * OpenLayers.Layer.Markers
         * OpenLayers.Layer.Text
         * OpenLayers.Layer.GeoRSS
         * OpenLayers.Layer.Boxes
         * OpenLayers.Layer.TMS

         Image類封裝一個實際圖象作為圖曾內容
         HTTPRequest類可以接收一個動態生成的圖片,你可以通過HTTPRequest類的參數向 服務器發送參數
         Grid類是HTTPRequest類的子類,提供更加詳細的方法
         WMS類用于連接WMS服務器以獲得圖象
         KaMap 類用于連接MapServer
         EventPane類作為用于接收用戶操作的圖層
         Google類用于從Google獲得圖象,它仍然需 要你從Google獲得API KEY,并且include
         VirtualEarth類用于操作VirtualEarth的圖層
         Markers 類用于生成接收和顯示用戶本地標記的圖層
         Text類用于接收CSV文件
         GeoRSS類是Marker類的子類,用于封裝接收 GeoRSS并在圖層中作出marker
         Boxes同樣也是Marker類的子類,可以用div來做marker,而非image
         TMS 用于接收TMS服務器的地圖

     OpenLayers還提供了豐富的Control類為地圖瀏覽添加一些工具,繼承自OpenLayers.Control類

         * OpenLayers.Control.LayerSwitcher
         * OpenLayers.Control.MouseDefaults
         * OpenLayers.Control.MousePosition
         * OpenLayers.Control.MouseToolbar
         * OpenLayers.Control.OverviewMap
         * OpenLayers.Control.PanZoom
         * OpenLayers.Control.PanZoomBar
         * OpenLayers.Control.Permalink
         * OpenLayers.Control.Scale

     這些類的實例會在地圖瀏覽的“窗口”上增加一些工具欄或是“按鈕”,增加互動性和功 能性。

         OpenLayers對常用的數據結構進行了封裝
         # OpenLayers.LonLat
         # OpenLayers.Size
         # OpenLayers.Pixel
         # OpenLayers.Bounds以便于操作。

     現在寫個最簡單的例子做記錄:
     
<%@ page language="java" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  
<head>
    
<title>WMS MAP INIT</title>
    
<script src="http://localhost:8080/geoserver/openlayers/OpenLayers.js" type="text/javascript"></script>
    
<style type="text/css">
        #map 
{
            width
: 100%;
            height
: 100%;
            border
: 1px solid black;
        
}
    
</style>
    
<script defer="defer" type="text/javascript">
        
function init(){
            
//數據存儲的左、下、右、上的范圍,默認為NULL
            var bounds = new OpenLayers.Bounds(
                
17831.79991085.208,
                
18221.79991287.26
            );
            
//創建一個OpenLayers.Map構造新的地圖。
            var options = {
                controls: [],
                maxExtent: bounds,
                maxResolution: 
1.5234375,
                projection: 
"EPSG:4326",
                units: 'degrees'
            };
            
var map = new OpenLayers.Map('map', options);
            
//創建一個圖層信息
            var layer = new OpenLayers.Layer.WMS("State""http://127.0.0.1:8080/geoserver/wms", {
                        layers: 
"dwg:0_line"
                    });
//
            //將創建的圖層對象添加到Map對象
            map.addLayer(layer);
            
//顯示地圖
            map.zoomToMaxExtent();
        }
    
</script>
  
</head>
  
  
<body onload="init()">
    
<div id="map"></div>
  
</body>
</html>


泰坦 2010-03-16 11:59 發表評論
]]>
GEOSERVER2.0.1 NG 應用配置指南(1)http://www.tkk7.com/xtitan/archive/2010/03/15/315423.html泰坦泰坦Mon, 15 Mar 2010 01:30:00 GMThttp://www.tkk7.com/xtitan/archive/2010/03/15/315423.htmlhttp://www.tkk7.com/xtitan/comments/315423.htmlhttp://www.tkk7.com/xtitan/archive/2010/03/15/315423.html#Feedback0http://www.tkk7.com/xtitan/comments/commentRss/315423.htmlhttp://www.tkk7.com/xtitan/services/trackbacks/315423.html   下載地址:http://nchc.dl.sourceforge.net/project/geoserver/GeoServer/2.0.1/geoserver-2.0.1-ng.exe

  1.點擊安裝文件將geoserver進行安裝,并填寫服務器管理的賬號和密碼
  2.點擊Start GeoServer 啟動服務器
  3.打開http://localhost:8080/geoserver/web/進入服務器管理頁面,輸入賬號密碼進行登錄
  4.點擊workspaces(左側),點擊Add new workspace,填寫Name和Namespace URI,點擊save確定一個工作空間
  5.點擊Store,點擊Add new Store,選擇PostGIS   - PostGIS Database(這個是配置連接數據庫的,如果是直接使用shp文件則選擇Shapefile   - ESRI(tm) Shapefiles (*.shp))
  6.選擇Workspace(第四步建立的),填寫數據源名稱(Data Source Name),填寫Connection Parameters的內容(數據庫的連接信息),勾上Enabled為啟動后save保存。(服務器會自動判斷是否連接上,連不上有提示進行查看修改)
  7.點擊Layers進行圖層配置,點擊Add a new resource,選擇圖層的來源(剛才填寫的工作空間和數據源名稱)
  8.這時可以查看到數據源中的所有圖層列表,選擇一個需要配置的點擊Publish進行配置
  9.主要配置有:
      
Declared SRS(使用的4326):用來構建像素坐標系與真實世界的大地坐標系(或其它一些本地坐標系)之間雙向的映射關系。
       SRS handling(第一個):其中有三個選型
           第一個是 大概意思是說強制使用你在SRS里設置的那個,本地投影文件忽略。
           第二個是 大概意思是說使用本地投影文件重投影你設置的SRS。
           第三個是 大概意思是說保留使用本地投影文件
       Native Bounding Box:點擊下方的Compute from data
       Lat/Lon Bounding Box:點擊下方的Compute from native bounds
       Publishing:點擊上面的第二頁Publishing,這里主要是配置圖層的樣式,樣式添加在后面會介紹
     圖層就配置完成了,點擊save保存。
  10.左側菜單欄最下面的Layer Preview找到自己配置的圖層點擊OpenLayers就可以查看圖層是否正常使用,并查看效果


  附1:圖層組
    1.左側Data中點擊Layer Groups,點擊Add new layer group,輸入圖層組名稱后提交
    2.Bounds中點擊find查找SRS(4326)
    3.點擊Generate Bounds 自動填寫坐標系信息
    4.點擊Add Layer來添加圖層
    5.save保存
    6.Layer Preview中點擊圖層組的OpenLayers進行效果查看

  附2:樣式
    1.左側Data中點擊Style,點擊Add a new style來創建一個新的樣式
    2.填寫名稱,將樣式代碼輸入編輯框或者下方SLD file直接上傳樣式文件
    3.點擊submit提交保存
    我使用的編寫圖層樣式工具udig
              


泰坦 2010-03-15 09:30 發表評論
]]>
分析整合整套WEBGIS的應用框架http://www.tkk7.com/xtitan/archive/2010/03/12/315284.html泰坦泰坦Fri, 12 Mar 2010 07:45:00 GMThttp://www.tkk7.com/xtitan/archive/2010/03/12/315284.htmlhttp://www.tkk7.com/xtitan/comments/315284.htmlhttp://www.tkk7.com/xtitan/archive/2010/03/12/315284.html#Feedback0http://www.tkk7.com/xtitan/comments/commentRss/315284.htmlhttp://www.tkk7.com/xtitan/services/trackbacks/315284.html
     Shapefile格式地圖文件:存儲地圖信息
     shp2pgsql工具:將Shp地圖文件信息導入postgis空間數據庫
     Geoserver2.0.1:GIS地圖服務器,連接postgis空間數據庫取得數據,配置圖層文件后可以用于WEBGIS顯示
     OpenLayers:用于開發WebGIS客戶端的JavaScript包。頁面顯示GIS的各項操作都在這里編輯。也是學習研究如何應用的重點
     Geotools:一套開放源碼的 Java API,它提供了一套空間數據操作的核心算法,為在兼容OGC標準的空間對象模型中進行基礎的幾何操作提供2D空間謂詞API.

     流程:
     使用shp2pgsql工具將Shapefile格式地圖文件的數據信息導入postgis空間數據庫進行存儲,在Geoserver中配置數據庫連接后取得圖層,配置圖層信息和樣式后為可用狀態。
     在JAVA的WEBGIS項目中連接Geoserver取得空間數據,用Geotools進行數據運算處理后將數據傳輸給前臺顯示層的OpenLayers,用OpenLayers制作出各種顯示功能及樣式。
     
     寫的也許不對,請大家指教。我現在是準備將WEBGIS框架進行分析整理后進行逐個攻克,然后延伸。


泰坦 2010-03-12 15:45 發表評論
]]>
(轉)12條有用的Flex代碼http://www.tkk7.com/xtitan/archive/2009/04/13/265221.html泰坦泰坦Mon, 13 Apr 2009 01:50:00 GMThttp://www.tkk7.com/xtitan/archive/2009/04/13/265221.htmlhttp://www.tkk7.com/xtitan/comments/265221.htmlhttp://www.tkk7.com/xtitan/archive/2009/04/13/265221.html#Feedback0http://www.tkk7.com/xtitan/comments/commentRss/265221.htmlhttp://www.tkk7.com/xtitan/services/trackbacks/265221.html
System.setClipboard(strContent); 
2.復制一個ArrayCollection
//dummy solution( well, it works ) 
var bar:ArrayCollection = new ArrayCollection(); 
   
for each ( var i:Object in ac )
       bar.addItem( i ); 
   }
 
   
// fantastic ! // 
   var bar:ListCollectionView = new ListCollectionView( ListCollectionView( ac ).list ); 
3.打開一個新瀏覽器窗口
navigateToURL(new URLRequest('http://ntt.cc'), '_blank'); 
4.刷新瀏覽器
navigateToURL(new URLRequest("javascript:location.reload();"),"_self"
5.關閉瀏覽器
navigateToURL(new URLRequest("javascript:window.close()"),"_self"); 
6.設置Alert 窗口的背景為透明
Alert 
    

    modalTransparency:
0.0;   
    modalTransparencyBlur:
0
    }
 
7.取隨機顏色
lbl.setStyle('color'0xffffff*Math.random()); 

8.清除子串左側空格

public function LTrim(s : String):String 
    

      var i : Number 
= 0
      
while(s.charCodeAt(i) == 32 || s.charCodeAt(i) == 13 || s.charCodeAt(i) == 10 || s.charCodeAt(i) == 9
      

        i
++
      }
 
      
return s.substring(i,s.length); 
    }
9.清除字串右側空格
public function RTrim(s : String):String 
    

      var i : Number 
= s.length - 1
      
while(s.charCodeAt(i) == 32 || s.charCodeAt(i) == 13 || s.charCodeAt(i) == 10 ||s.charCodeAt(i) == 9
      

        i
--
      }
 
      
return s.substring(0,i+1); 
    }
 
10.清除字串左右的空格
public function Trim(s : String):String 
    

      
return LTrim(RTrim(s)); 
    }
 
11.獲取數據類型
getQualifiedClassName(data)
12.生成隨機字符串.
private function GenerateCheckCode():String 
   

       
//init 
       var ran:Number; 
       var number:Number; 
       var code:String; 
       var checkCode:String 
=""
       
//get 4 radom 
      for(var i:int=0; i<4; i++
      

          ran
=Math.random(); 
          number 
=Math.round(ran*10000);            //get result like 0.1234 
          if(number % 2 == 0
            code 
= String.fromCharCode(48+(number % 10));        //0's ASCII code is 48 
          else 
            code 
= String.fromCharCode(65+(number % 26)) ;        // A's ASCII code is 65 
          checkCode += code; 
      }
 
      
return checkCode; 
  }
 



泰坦 2009-04-13 09:50 發表評論
]]>
Java多線程程序設計詳細解析http://www.tkk7.com/xtitan/archive/2009/03/16/260136.html泰坦泰坦Mon, 16 Mar 2009 15:47:00 GMThttp://www.tkk7.com/xtitan/archive/2009/03/16/260136.htmlhttp://www.tkk7.com/xtitan/comments/260136.htmlhttp://www.tkk7.com/xtitan/archive/2009/03/16/260136.html#Feedback0http://www.tkk7.com/xtitan/comments/commentRss/260136.htmlhttp://www.tkk7.com/xtitan/services/trackbacks/260136.html 多線程是這樣一種機制,它允許在程序中并發執行多個指令流,每個指令流都稱為一個線程,彼此間互相獨立。
線程又稱為輕量級進程,它和進程一樣擁有獨立的執行控制,由操作系統負責調度,區別在于線程沒有獨立的存儲空間,而是和所屬進程中的其它線程共享一個存儲空間,這使得線程間的通信遠較進程簡單。
多個線程的執行是并發的,也就是在邏輯上“同時”,而不管是否是物理上的“同時”。如果系統只有一個CPU,那么真正的“同時”是不可能的,但是由于CPU的速度非???,用戶感覺不到其中的區別,因此我們也不用關心它,只需要設想各個線程是同時執行即可。
多線程和傳統的單線程在程序設計上最大的區別在于,由于各個線程的控制流彼此獨立,使得各個線程之間的代碼是亂序執行的,由此帶來的線程調度,同步等問題,將在以后探討。
二、在Java中實現多線程
我們不妨設想,為了創建一個新的線程,我們需要做些什么?很顯然,我們必須指明這個線程所要執行的代碼,而這就是在Java中實現多線程我們所需要做的一切!
真是神奇!Java是如何做到這一點的?通過類!作為一個完全面向對象的語言,Java提供了類java.lang.Thread來方便多線程編程,這個類提供了大量的方法來方便我們控制自己的各個線程,我們以后的討論都將圍繞這個類進行。
那么如何提供給 Java 我們要線程執行的代碼呢?讓我們來看一看 Thread 類。Thread 類最重要的方法是run(),它為Thread類的方法start()所調用,提供我們的線程所要執行的代碼。為了指定我們自己的代碼,只需要覆蓋它!
方法一:繼承 Thread 類,覆蓋方法 run(),我們在創建的 Thread 類的子類中重寫 run() ,加入線程所要執行的代碼即可。下面是一個例子:
public class MyThread extends Thread
{
int count= 1, number;
public MyThread(int num)
{
number = num;
System.out.println
("創建線程 " + number);
}
public void run() {
while(true) {
System.out.println
("線程 " + number + ":計數 " + count);
if(++count== 6) return;
}
}
public static void main(String args[])
{
for(int i = 0;
i 〈 5; i++) new MyThread(i+1).start();
}
}

這種方法簡單明了,符合大家的習慣,但是,它也有一個很大的缺點,那就是如果我們的類已經從一個類繼承(如小程序必須繼承自 Applet 類),則無法再繼承 Thread 類,這時如果我們又不想建立一個新的類,應該怎么辦呢?
我們不妨來探索一種新的方法:我們不創建Thread類的子類,而是直接使用它,那么我們只能將我們的方法作為參數傳遞給 Thread 類的實例,有點類似回調函數。但是 Java 沒有指針,我們只能傳遞一個包含這個方法的類的實例。
那么如何限制這個類必須包含這一方法呢?當然是使用接口!(雖然抽象類也可滿足,但是需要繼承,而我們之所以要采用這種新方法,不就是為了避免繼承帶來的限制嗎?)
Java 提供了接口 java.lang.Runnable 來支持這種方法。
方法二:實現 Runnable 接口
Runnable接口只有一個方法run(),我們聲明自己的類實現Runnable接口并提供這一方法,將我們的線程代碼寫入其中,就完成了這一部 分的任務。但是Runnable接口并沒有任何對線程的支持,我們還必須創建Thread類的實例,這一點通過Thread類的構造函數public Thread(Runnable target);來實現。下面是一個例子:
public class MyThread implements Runnable
{
int count= 1, number;
public MyThread(int num)
{
number = num;
System.out.println("創建線程 " + number);
}
public void run()
{
while(true)
{
System.out.println
("線程 " + number + ":計數 " + count);
if(++count== 6) return;
}
}
public static void main(String args[])
{
for(int i = 0; i 〈 5;
i++) new Thread(new MyThread(i+1)).start();
}
}

嚴格地說,創建Thread子類的實例也是可行的,但是必須注意的是,該子類必須沒有覆蓋 Thread 類的 run 方法,否則該線程執行的將是子類的 run 方法,而不是我們用以實現Runnable 接口的類的 run 方法,對此大家不妨試驗一下。
使用 Runnable 接口來實現多線程使得我們能夠在一個類中包容所有的代碼,有利于封裝,它的缺點在于,我們只能使用一套代碼,若想創建多個線程并使各個線程執行不同的代 碼,則仍必須額外創建類,如果這樣的話,在大多數情況下也許還不如直接用多個類分別繼承 Thread 來得緊湊。
綜上所述,兩種方法各有千秋,大家可以靈活運用。
下面讓我們一起來研究一下多線程使用中的一些問題。
三、線程的四種狀態
1. 新狀態:線程已被創建但尚未執行(start() 尚未被調用)。
2. 可執行狀態:線程可以執行,雖然不一定正在執行。CPU 時間隨時可能被分配給該線程,從而使得它執行。
3. 死亡狀態:正常情況下 run() 返回使得線程死亡。調用 stop()或 destroy() 亦有同樣效果,但是不被推薦,前者會產生異常,后者是強制終止,不會釋放鎖。
4. 阻塞狀態:線程不會被分配 CPU 時間,無法執行。
四、線程的優先級
線程的優先級代表該線程的重要程度,當有多個線程同時處于可執行狀態并等待獲得 CPU 時間時,線程調度系統根據各個線程的優先級來決定給誰分配 CPU 時間,優先級高的線程有更大的機會獲得 CPU 時間,優先級低的線程也不是沒有機會,只是機會要小一些罷了。
你可以調用 Thread 類的方法 getPriority() 和 setPriority()來存取線程的優先級,線程的優先級界于1(MIN_PRIORITY)和10(MAX_PRIORITY)之間,缺省是5(NORM_PRIORITY)。
五、線程的同步
由于同一進程的多個線程共享同一片存儲空間,在帶來方便的同時,也帶來了訪問沖突這個嚴重的問題。Java語言提供了專門機制以解決這種沖突,有效避免了同一個數據對象被多個線程同時訪問。
由于我們可以通過 private 關鍵字來保證數據對象只能被方法訪問,所以我們只需針對方法提出一套機制,這套機制就是 synchronized 關鍵字,它包括兩種用法:synchronized 方法和 synchronized 塊。
1. synchronized 方法:通過在方法聲明中加入 synchronized關鍵字來聲明 synchronized 方法。如:
public synchronized void accessVal(int newVal);

synchronized 方法控制對類成員變量的訪問:每個類實例對應一把鎖,每個 synchronized 方法都必須獲得調用該方法的類實例的鎖方能執行,否則所屬線程阻塞,方法一旦執行,就獨占該鎖,直到從該方法返回時才將鎖釋放,此后被阻塞的線程方能獲得 該鎖,重新進入可執行狀態。
這種機制確保了同一時刻對于每一個類實例,其所有聲明為 synchronized 的成員函數中至多只有一個處于可執行狀態(因為至多只有一個能夠獲得該類實例對應的鎖),從而有效避免了類成員變量的訪問沖突(只要所有可能訪問類成員變 量的方法均被聲明為 synchronized)。
在 Java 中,不光是類實例,每一個類也對應一把鎖,這樣我們也可將類的靜態成員函數聲明為 synchronized ,以控制其對類的靜態成員變量的訪問。
synchronized 方法的缺陷:若將一個大的方法聲明為synchronized 將會大大影響效率,典型地,若將線程類的方法 run() 聲明為 synchronized ,由于在線程的整個生命期內它一直在運行,因此將導致它對本類任何 synchronized 方法的調用都永遠不會成功。當然我們可以通過將訪問類成員變量的代碼放到專門的方法中,將其聲明為 synchronized ,并在主方法中調用來解決這一問題,但是 Java 為我們提供了更好的解決辦法,那就是 synchronized 塊。
2. synchronized 塊:通過 synchronized關鍵字來聲明synchronized 塊。語法如下:
synchronized(syncObject)
{
//允許訪問控制的代碼
}

synchronized 塊是這樣一個代碼塊,其中的代碼必須獲得對象 syncObject (如前所述,可以是類實例或類)的鎖方能執行,具體機制同前所述。由于可以針對任意代碼塊,且可任意指定上鎖的對象,故靈活性較高。
六、線程的阻塞
為了解決對共享存儲區的訪問沖突,Java 引入了同步機制,現在讓我們來考察多個線程對共享資源的訪問,顯然同步機制已經不夠了,因為在任意時刻所要求的資源不一定已經準備好了被訪問,反過來,同 一時刻準備好了的資源也可能不止一個。為了解決這種情況下的訪問控制問題,Java 引入了對阻塞機制的支持。
阻塞指的是暫停一個線程的執行以等待某個條件發生(如某資源就緒),學過操作系統的同學對它一定已經很熟悉了。Java 提供了大量方法來支持阻塞,下面讓我們逐一分析。
1. sleep() 方法:sleep() 允許 指定以毫秒為單位的一段時間作為參數,它使得線程在指定的時間內進入阻塞狀態,不能得到CPU 時間,指定的時間一過,線程重新進入可執行狀態。典型地,sleep() 被用在等待某個資源就緒的情形:測試發現條件不滿足后,讓線程阻塞一段時間后重新測試,直到條件滿足為止。
2. suspend() 和 resume() 方法:兩個方法配套使用,suspend()使得線程進入阻塞狀態,并且不會自動恢復,必須其對應的resume() 被調用,才能使得線程重新進入可執行狀態。典型地,suspend() 和 resume() 被用在等待另一個線程產生的結果的情形:測試發現結果還沒有產生后,讓線程阻塞,另一個線程產生了結果后,調用 resume() 使其恢復。
3. yield() 方法:yield() 使得線程放棄當前分得的 CPU 時間,但是不使線程阻塞,即線程仍處于可執行狀態,隨時可能再次分得 CPU 時間。調用 yield() 的效果等價于調度程序認為該線程已執行了足夠的時間從而轉到另一個線程。
4. wait() 和 notify() 方法:兩個方法配套使用,wait() 使得線程進入阻塞狀態,它有兩種形式,一種允許 指定以毫秒為單位的一段時間作為參數,另一種沒有參數,前者當對應的 notify() 被調用或者超出指定時間時線程重新進入可執行狀態,后者則必須對應的 notify() 被調用。
初看起來它們與 suspend() 和 resume() 方法對沒有什么分別,但是事實上它們是截然不同的。區別的核心在于,前面敘述的所有方法,阻塞時都不會釋放占用的鎖(如果占用了的話),而這一對方法則相反。
上述的核心區別導致了一系列的細節上的區別。
首先,前面敘述的所有方法都隸屬于 Thread 類,但是這一對卻直接隸屬于 Object 類,也就是說,所有對象都擁有這一對方法。初看起來這十分不可思議,但是實際上卻是很自然的,因為這一對方法阻塞時要釋放占用的鎖,而鎖是任何對象都具有 的,調用任意對象的 wait() 方法導致線程阻塞,并且該對象上的鎖被釋放。
而調用 任意對象的notify()方法則導致因調用該對象的 wait() 方法而阻塞的線程中隨機選擇的一個解除阻塞(但要等到獲得鎖后才真正可執行)。
其次,前面敘述的所有方法都可在任何位置調用,但是這一對方法卻必須在 synchronized 方法或塊中調用,理由也很簡單,只有在synchronized 方法或塊中當前線程才占有鎖,才有鎖可以釋放。
同樣的道理,調用這一對方法的對象上的鎖必須為當前線程所擁有,這樣才有鎖可以釋放。因此,這一對方法調用必須放置在這樣的 synchronized 方法或塊中,該方法或塊的上鎖對象就是調用這一對方法的對象。若不滿足這一條件,則程序雖然仍能編譯,但在運行時會出現 IllegalMonitorStateException 異常。
wait() 和 notify() 方法的上述特性決定了它們經常和synchronized 方法或塊一起使用,將它們和操作系統的進程間通信機制作一個比較就會發現它們的相似性:synchronized方法或塊提供了類似于操作系統原語的功 能,它們的執行不會受到多線程機制的干擾,而這一對方法則相當于 block 和wakeup 原語(這一對方法均聲明為 synchronized)。
它們的結合使得我們可以實現操作系統上一系列精妙的進程間通信的算法(如信號量算法),并用于解決各種復雜的線程間通信問題。關于 wait() 和 notify() 方法最后再說明兩點:
第一:調用 notify() 方法導致解除阻塞的線程是從因調用該對象的 wait() 方法而阻塞的線程中隨機選取的,我們無法預料哪一個線程將會被選擇,所以編程時要特別小心,避免因這種不確定性而產生問題。
第二:除了 notify(),還有一個方法 notifyAll() 也可起到類似作用,唯一的區別在于,調用 notifyAll() 方法將把因調用該對象的 wait() 方法而阻塞的所有線程一次性全部解除阻塞。當然,只有獲得鎖的那一個線程才能進入可執行狀態。
談到阻塞,就不能不談一談死鎖,略一分析就能發現,suspend() 方法和不指定超時期限的 wait() 方法的調用都可能產生死鎖。遺憾的是,Java 并不在語言級別上支持死鎖的避免,我們在編程中必須小心地避免死鎖。
以上我們對 Java 中實現線程阻塞的各種方法作了一番分析,我們重點分析了 wait() 和 notify()方法,因為它們的功能最強大,使用也最靈活,但是這也導致了它們的效率較低,較容易出錯。實際使用中我們應該靈活使用各種方法,以便更好 地達到我們的目的。
七、守護線程
守護線程是一類特殊的線程,它和普通線程的區別在于它并不是應用程序的核心部分,當一個應用程序的所有非守護線程終止運行時,即使仍然有守護線程在運 行,應用程序也將終止,反之,只要有一個非守護線程在運行,應用程序就不會終止。守護線程一般被用于在后臺為其它線程提供服務。
可以通過調用方法 isDaemon() 來判斷一個線程是否是守護線程,也可以調用方法 setDaemon() 來將一個線程設為守護線程。
八、線程組
線程組是一個 Java 特有的概念,在 Java 中,線程組是類ThreadGroup 的對象,每個線程都隸屬于唯一一個線程組,這個線程組在線程創建時指定并在線程的整個生命期內都不能更改。
你可以通過調用包含 ThreadGroup 類型參數的 Thread 類構造函數來指定線程屬的線程組,若沒有指定,則線程缺省地隸屬于名為 system 的系統線程組。
在 Java 中,除了預建的系統線程組外,所有線程組都必須顯式創建。在 Java 中,除系統線程組外的每個線程組又隸屬于另一個線程組,你可以在創建線程組時指定其所隸屬的線程組,若沒有指定,則缺省地隸屬于系統線程組。這樣,所有線 程組組成了一棵以系統線程組為根的樹。
Java 允許我們對一個線程組中的所有線程同時進行操作,比如我們可以通過調用線程組的相應方法來設置其中所有線程的優先級,也可以啟動或阻塞其中的所有線程。
Java 的線程組機制的另一個重要作用是線程安全。線程組機制允許我們通過分組來區分有不同安全特性的線程,對不同組的線程進行不同的處理,還可以通過線程組的分層結構來支持不對等安全措施的采用。
Java 的 ThreadGroup 類提供了大量的方法來方便我們對線程組樹中的每一個線程組以及線程組中的每一個線程進行操作。
九、總結
在本文中,我們講述了 Java 多線程編程的方方面面,包括創建線程,以及對多個線程進行調度、管理。我們深刻認識到了多線程編程的復雜性,以及線程切換開銷帶來的多線程程序的低效性,這也促使我們認真地思考一個問題:我們是否需要多線程?何時需要多線程?
多線程的核心在于多個代碼塊并發執行,本質特點在于各代碼塊之間的代碼是亂序執行的。我們的程序是否需要多線程,就是要看這是否也是它的內在特點。
假如我們的程序根本不要求多個代碼塊并發執行,那自然不需要使用多線程;假如我們的程序雖然要求多個代碼塊并發執行,但是卻不要求亂序,則我們完全可 以用一個循環來簡單高效地實現,也不需要使用多線程;只有當它完全符合多線程的特點時,多線程機制對線程間通信和線程管理的強大支持才能有用武之地,這時 使用多線程才是值得的。

泰坦 2009-03-16 23:47 發表評論
]]>
js中的replace問題和textarea回車符問題http://www.tkk7.com/xtitan/archive/2008/07/22/216518.html泰坦泰坦Tue, 22 Jul 2008 01:14:00 GMThttp://www.tkk7.com/xtitan/archive/2008/07/22/216518.htmlhttp://www.tkk7.com/xtitan/comments/216518.htmlhttp://www.tkk7.com/xtitan/archive/2008/07/22/216518.html#Feedback12http://www.tkk7.com/xtitan/comments/commentRss/216518.htmlhttp://www.tkk7.com/xtitan/services/trackbacks/216518.html     在js取textarea的時候:
    如果用
    
var str = document.getElementById("textarea").value;
str 
= str.replace("\r\n","<br>");
   則只會將第一個\r\n替換成<br>,如何將所有n個\r\n替換成<br>呢?難道要無限個replace嗎?
  其實不用,replace可以和正則表達式結合,一次替換所有的\r\n。
var reg=new RegExp("\r\n","g");
str
= str.replace(reg,"\r\n");
這樣str中所有的\r\n就替換成<br>了.然后可以將其存入數據庫。

在取出的時候 只用將值在替換回來即可
var reg=new RegExp("<br>","g");
stt
= str.replace(reg,"\r\n");
document.getElementById(
"textarea").value=str;

更加詳細的分析和應用可以參考JavaScript的replace方法與正則表達式結合應用講解

下面是我寫的2個函數 直接放到通用包中  以后使用可以替換
function replaceTextarea1(str){
    
var reg=new RegExp("\r\n","g");
    
var reg1=new RegExp(" ","g");
    
    str 
= str.replace(reg,"<br>");
    str 
= str.replace(reg1,"<p>");
    
    
return str;
}



function replaceTextarea2(str){
    
var reg=new RegExp("<br>","g");
    
var reg1=new RegExp("<p>","g");
    
    str 
= str.replace(reg,"\r\n");
    str 
= str.replace(reg1," ");
    
    
return str;
}


泰坦 2008-07-22 09:14 發表評論
]]>
[網站提速] - 給Tomcat,Apache配置gzip壓縮(HTTP壓縮)功能 (轉載)http://www.tkk7.com/xtitan/archive/2008/07/01/211824.html泰坦泰坦Tue, 01 Jul 2008 02:06:00 GMThttp://www.tkk7.com/xtitan/archive/2008/07/01/211824.html

背景:
HTTP 壓縮可以大大提高瀏覽網站的速度,它的原理是,在客戶端請求網頁后,從服務器端將網頁文件壓縮,再下載到客戶端,由客戶端的瀏覽器負責解壓縮并瀏覽。相對于普通的瀏覽過程HTML ,CSS,Javascript , Text ,它可以節省40%左右的流量。更為重要的是,它可以對動態生成的,包括CGI、PHP , JSP , ASP , Servlet,SHTML等輸出的網頁也能進行壓縮,壓縮效率驚人

一,對于Tomcat5.0以后的版本是支持對輸出內容進行壓縮的. 使用的是gzip壓縮格式

下面是tomcat5.5.20 中的$tomcat_home$/conf/server.xml的原內容

 1      < Connector  port ="80"  maxHttpHeaderSize ="8192"
 2                maxThreads ="150"  minSpareThreads ="25"  maxSpareThreads ="75"
 3                enableLookups ="false"  redirectPort ="8443"  acceptCount ="100"
 4                connectionTimeout ="20000"  disableUploadTimeout ="true"  URIEncoding ="utf-8"   />
 5      <!--  Note : To disable connection timeouts, set connectionTimeout value
 6      to 0  -->
 7     
 8      <!--  Note : To use gzip compression you could set the following properties :
 9     
10                compression="on" 
11                compressionMinSize="2048" 
12                noCompressionUserAgents="gozilla, traviata" 
13                compressableMimeType="text/html,text/xml"
14      -->
從上面的第8行內容可以看出,要使用gzip壓縮功能,你可以在Connector實例中加上如下屬性即可
1) compression="on" 打開壓縮功能
2) compressionMinSize="2048" 啟用壓縮的輸出內容大小,這里面默認為2KB
3) noCompressionUserAgents="gozilla, traviata" 對于以下的瀏覽器,不啟用壓縮 
4) compressableMimeType="text/html,text/xml" 壓縮類型

我這里的配置內容為:
 1    <Connector port="80" maxHttpHeaderSize="8192"
 2               maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
 3               enableLookups="false" redirectPort="8443" acceptCount="100"
 4               connectionTimeout="20000" disableUploadTimeout="true" URIEncoding="utf-8"
 5                  compression="on" 
 6               compressionMinSize="2048" 
 7               noCompressionUserAgents="gozilla, traviata" 
 8               compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain"  />
 9    <!-- Note : To disable connection timeouts, set connectionTimeout value
10     to 0 -->
11    
12    <!-- Note : To use gzip compression you could set the following properties :
13    
14               compression="on" 
15               compressionMinSize="2048" 
16               noCompressionUserAgents="gozilla, traviata" 
17               compressableMimeType="text/html,text/xml"
18    -->
19

二,對于Apache而言,有兩種情況
   
1)針對Apache2.0之前的版本,它原本是不支持的,不過可以通過添加第三方的module_gzip模塊來啟用
   2)針對Apache2.0及之后的版本,Apache提供支持, 不過不叫gzip,而叫mod_deflate
下面就對Apache2.0及之后的版本作一個說明
1) 去掉#LoadModule headers_module modules/mod_headers.so前面的注釋#,
2) 添加LoadModule deflate_module modules/mod_deflate.so
3) 在VirtualHost中添加
1    <Location "/">
2        SetOutputFilter DEFLATE
3        BrowserMatch ^Mozilla/4 gzip-only-text/html
4        BrowserMatch ^Mozilla/4\.0[678] no-gzip
5        BrowserMatch \bMSIE !no-gzip !gzip-only-text/html
6        SetEnvIfNoCase Request_URI \.(?:gif|jpe?g|png)$ no-gzip dont-vary
7        Header append Vary User-Agent env=!dont-vary
8    </Location>
9

我這里面有一個完整的演示
 1# 加載deflate模塊
 2LoadModule headers_module modules/mod_headers.so
 3LoadModule deflate_module modules/mod_deflate.so
 4<VirtualHost *:80>
 5    DocumentRoot f:/apacheTest
 6    <Location "/">
 7        SetOutputFilter DEFLATE
 8        BrowserMatch ^Mozilla/4 gzip-only-text/html
 9        BrowserMatch ^Mozilla/4\.0[678] no-gzip
10        BrowserMatch \bMSIE !no-gzip !gzip-only-text/html
11        SetEnvIfNoCase Request_URI \.(?:gif|jpe?g|png)$ no-gzip dont-vary
12        Header append Vary User-Agent env=!dont-vary
13    </Location>
14</VirtualHost>



泰坦 2008-07-01 10:06 發表評論
]]>
頁面緩存http://www.tkk7.com/xtitan/archive/2007/10/17/153508.html泰坦泰坦Wed, 17 Oct 2007 03:26:00 GMThttp://www.tkk7.com/xtitan/archive/2007/10/17/153508.htmlhttp://www.tkk7.com/xtitan/comments/153508.htmlhttp://www.tkk7.com/xtitan/archive/2007/10/17/153508.html#Feedback0http://www.tkk7.com/xtitan/comments/commentRss/153508.htmlhttp://www.tkk7.com/xtitan/services/trackbacks/153508.html <%
 response.setHeader("Pragma","No-cache");
 response.setHeader("Cache-Control","no-cache");
 response.setDateHeader("Expires", 0);
%>
<META http-equiv="Content-Type" content="text/html; charset=utf-8">
<META HTTP-EQUIV="pragma" CONTENT="no-cache">
<META HTTP-EQUIV="Cache-Control" CONTENT="no-cache, must-revalidate">
<META HTTP-EQUIV="expires" CONTENT="0">

泰坦 2007-10-17 11:26 發表評論
]]>
Log4配置http://www.tkk7.com/xtitan/archive/2007/10/13/152563.html泰坦泰坦Sat, 13 Oct 2007 06:09:00 GMThttp://www.tkk7.com/xtitan/archive/2007/10/13/152563.htmlhttp://www.tkk7.com/xtitan/comments/152563.htmlhttp://www.tkk7.com/xtitan/archive/2007/10/13/152563.html#Feedback0http://www.tkk7.com/xtitan/comments/commentRss/152563.htmlhttp://www.tkk7.com/xtitan/services/trackbacks/152563.html一、常用輸出格式

%c   列出logger名字空間的全稱,如加上{<層數>}表示出從最內層算起的指定層數的名字空間
%X  按MDC(Mapped Diagnostic Context,線程映射表)輸出日志。通常用于多個客戶端連接同一臺服務器,方便服務器區分是那個客戶端訪問留下來的日志。
%p  日志信息級別
%d   %d{<日期格式>}:日志信息產生時間,使用ISO8601定義的日期格式
%C   日志信息所在地(全限類名)
%m   產生的日志具體信息
%n    輸出日志信息換行
%F 顯示調用logger的源文件名
%l     輸出日志事件的發生位置,包括類目名、發生的線程,以及在代碼中的行數
%L    顯示調用logger的代碼行
%M   顯示調用logger的方法名
%r     顯示從程序啟動時到記錄該條日志時已經經過的毫秒數
%t     輸出產生該日志事件的線程名
%% 顯示一個
二、log4j.properties

#控制包中日志輸出級別
log4j.logger.org.apache.struts = debug

# 應用于控制臺
log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender
log4j.appender.Threshold=DEBUG
log4j.appender.CONSOLE.Target=System.out
log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout
log4j.appender.CONSOLE.layout.ConversionPattern=[framework] %d - %-4r [%t] %-5p %c %x - %m%n
#log4j.appender.CONSOLE.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD] n%c[CATEGORY]%n%m[MESSAGE]%n%n

#應用于文件
log4j.appender.FILE=org.apache.log4j.FileAppender
log4j.appender.FILE.File=file.log
log4j.appender.FILE.Append=false
log4j.appender.FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.FILE.layout.ConversionPattern=[framework] %d - %-4r [%t] %-5p %c %x - %m%n
# Use this layout for LogFactor 5 analysis

# 應用于文件回滾
log4j.appender.ROLLING_FILE=org.apache.log4j.RollingFileAppender
log4j.appender.ROLLING_FILE.Threshold=ERROR
log4j.appender.ROLLING_FILE.File=rolling.log
log4j.appender.ROLLING_FILE.Append=true
log4j.appender.ROLLING_FILE.MaxFileSize=100KB
log4j.appender.ROLLING_FILE.MaxBackupIndex=10
log4j.appender.ROLLING_FILE.layout=org.apache.log4j.PatternLayout
log4j.appender.ROLLING_FILE.layout.ConversionPattern=[framework] %d - %-4r [%t] %-5p %c %x - %m%n


#應用于socket
log4j.appender.SOCKET=org.apache.log4j.net.SocketAppender
log4j.appender.SOCKET.RemoteHost=localhost
log4j.appender.SOCKET.Port=5001
log4j.appender.SOCKET.LocationInfo=true
# Set up for Log Facter 5
log4j.appender.SOCKET.layout=org.apache.log4j.PatternLayout
log4j.appender.SOCET.layout.ConversionPattern=[start]%d{DATE}[DATE]%n%p[PRIORITY]%n%x[NDC]%n%t[THREAD]%n%c[CATEGORY]%n%m[MESSAGE]%n%n


# Log Factor 5 Appender
log4j.appender.LF5_APPENDER=org.apache.log4j.lf5.LF5Appender
log4j.appender.LF5_APPENDER.MaxNumberOfRecords=2000

# 發送日志給郵件
log4j.appender.MAIL=org.apache.log4j.net.SMTPAppender
log4j.appender.MAIL.Threshold=FATAL
log4j.appender.MAIL.BufferSize=10
log4j.appender.MAIL.From=web@www.wuset.com
log4j.appender.MAIL.SMTPHost=www.wusetu.com
log4j.appender.MAIL.Subject=Log4J Message
log4j.appender.MAIL.To=web@www.wusetu.com
log4j.appender.MAIL.layout=org.apache.log4j.PatternLayout
log4j.appender.MAIL.layout.ConversionPattern=[framework] %d - %-4r [%t] %-5p %c %x - %m%n

# 用于數據庫
log4j.appender.DATABASE=org.apache.log4j.jdbc.JDBCAppender
log4j.appender.DATABASE.URL=jdbc:mysql://localhost:3306/test
log4j.appender.DATABASE.driver=com.mysql.jdbc.Driver
log4j.appender.DATABASE.user=root
log4j.appender.DATABASE.password=
log4j.appender.DATABASE.sql=INSERT INTO LOG4J (Message) VALUES ('[framework] %d - %-4r [%t] %-5p %c %x - %m%n')
log4j.appender.DATABASE.layout=org.apache.log4j.PatternLayout
log4j.appender.DATABASE.layout.ConversionPattern=[framework] %d - %-4r [%t] %-5p %c %x - %m%n

#每日回滾日志文件
log4j.appender.A1=org.apache.log4j.DailyRollingFileAppender
log4j.appender.A1.File=SampleMessages.log4j
log4j.appender.A1.DatePattern=yyyyMMdd-HH'.log4j'
log4j.appender.A1.layout=org.apache.log4j.xml.XMLLayout

#自定義Appender
log4j.appender.im = net.cybercorlin.util.logger.appender.IMAppender
log4j.appender.im.host = mail.cybercorlin.net
log4j.appender.im.username = username
log4j.appender.im.password = password
log4j.appender.im.recipient = corlin@cybercorlin.net
log4j.appender.im.layout=org.apache.log4j.PatternLayout
log4j.appender.im.layout.ConversionPattern =[framework] %d - %-4r [%t] %-5p %c %x - %m%n



泰坦 2007-10-13 14:09 發表評論
]]>
SVG文件瀏覽器必須插件SVGView30http://www.tkk7.com/xtitan/archive/2007/09/03/142282.html泰坦泰坦Mon, 03 Sep 2007 05:53:00 GMThttp://www.tkk7.com/xtitan/archive/2007/09/03/142282.htmlhttp://www.tkk7.com/xtitan/comments/142282.htmlhttp://www.tkk7.com/xtitan/archive/2007/09/03/142282.html#Feedback0http://www.tkk7.com/xtitan/comments/commentRss/142282.htmlhttp://www.tkk7.com/xtitan/services/trackbacks/142282.html http://ehr.sandai.net/KDHRMS/Public/CHS/SVGView30.exe

泰坦 2007-09-03 13:53 發表評論
]]>
主站蜘蛛池模板: 亚洲国产av高清无码| 毛片免费视频播放| 国产日产亚洲系列| 性色av极品无码专区亚洲| 亚洲av日韩综合一区二区三区| 午夜免费不卡毛片完整版| 亚洲成a人片在线观看久| 免费91麻豆精品国产自产在线观看| 91精品国产免费久久久久久青草| 久久国产亚洲电影天堂| 国产精品亚洲w码日韩中文| 特级av毛片免费观看| 久久精品国产亚洲AV电影 | 亚洲精品无码久久久久APP| 国产V亚洲V天堂无码| 国产大片91精品免费观看男同| 亚洲AV无码一区二区三区网址| 日本黄色免费观看| 成人免费无码大片A毛片抽搐色欲 成人免费无码大片a毛片 | 国产性生大片免费观看性| 国产亚洲欧美在线观看| 蜜芽亚洲av无码精品色午夜| 久久久久久久亚洲精品| 中文字幕在线观看亚洲日韩| 中文字幕乱理片免费完整的| 在线观看免费人成视频色9 | 亚洲夂夂婷婷色拍WW47| 亚洲国产成人久久精品app| 人体大胆做受免费视频| 国产成人免费a在线资源| 国产精品免费观看久久| 国产亚洲人成无码网在线观看 | 亚洲AV日韩AV永久无码下载| 高潮毛片无遮挡高清免费视频| 久久亚洲精品成人777大小说| 亚洲四虎永久在线播放| 亚洲乱码无码永久不卡在线| 免费在线精品视频| 日本免费一区尤物| 成年人免费视频观看| 国产一卡2卡3卡4卡无卡免费视频|