<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    2008年12月6日

    1.       書目

    精通RMI——Java與EJB企業(yè)級應(yīng)用開發(fā)

    Java™ RemoteMethodInvocation Specification

    Java tutorial- RMI

    2.       基礎(chǔ)知識

    2.1 網(wǎng)絡(luò)通信協(xié)議

    網(wǎng)絡(luò)通信層是分布式計算環(huán)境中使用客戶/服務(wù)器結(jié)構(gòu)的一個核心技術(shù),而網(wǎng)絡(luò)編程中大體有兩種通信模式,無連接和面向連接的協(xié)議。

                 UDP

    UDP (universal datagram protocol)是一種用于無連接通信的標準化協(xié)議,其建立在IP協(xié)議之上,而IP協(xié)議是internet使用的基本數(shù)據(jù)傳輸協(xié)議。UDP協(xié)議的主要作用是將網(wǎng)絡(luò)數(shù)據(jù)流量壓縮成數(shù)據(jù)報文的形式。一個典型的數(shù)據(jù)報文就是一個二進制數(shù)據(jù)的傳輸單位。每一個數(shù)據(jù)報的前8個字節(jié)用來包含報頭信息,剩余字節(jié)則用來包含具體的傳輸數(shù)據(jù)。UDP協(xié)議并不提供數(shù)據(jù)傳送的保證機制。如果在從發(fā)送方到接收方的傳遞過程中出現(xiàn)數(shù)據(jù)報的丟失,協(xié)議本身并不能做出任何檢測或提示。因此,通常人們把UDP協(xié)議稱為不可靠的傳輸協(xié)議。一般用來傳輸少量數(shù)據(jù),它資源消耗小,處理速度快。

     TCP

    TCP(transport control protocol)傳輸控制協(xié)議,標準化的面向連接的通信協(xié)議。在使用TCP協(xié)議中發(fā)送者和接收者必須在通信之前建立連接,連接建立之后被看成是一個數(shù)據(jù)流,發(fā)送者將數(shù)據(jù)發(fā)到該數(shù)據(jù)流上,接收者從該數(shù)據(jù)流上讀取數(shù)據(jù)。如果接收者也同時是發(fā)送者則連接是雙向的。通信完成后任何一方都可以關(guān)閉連接,之后的讀寫操作都會失敗。TCP協(xié)議提供了可靠的面向?qū)ο蟮臄?shù)據(jù)流傳輸服務(wù)的規(guī)則和約定。簡單的說在TCP模式中,對方發(fā)一個數(shù)據(jù)包給你,你要發(fā)一個確認數(shù)據(jù)包給對方。Java提供的類庫都將TCP/IP協(xié)議的使用借助套接字(Socket)進行了抽象。套接字包含了建立與遠程主機的連接,與主機進行通信以及關(guān)閉連接所需要的所有操作,而這些操作實際上還是由TCP/IP來執(zhí)行的。

    編組

    在應(yīng)用復雜尤其是面向?qū)ο蟮臅r候,一方面會遇到處理數(shù)據(jù)或者對象的結(jié)構(gòu)的問題。另一方面還會遇到面向流的用來發(fā)送字節(jié)或字符塊的網(wǎng)絡(luò)連接問題。此時需要將對象轉(zhuǎn)換成連接可以處理的格式,從而使自定義的對象可以通過連接管道。

    編組(marshalling)是一個將負責對象轉(zhuǎn)換成字節(jié)流的過程,然后在使用反過程----反編組將字節(jié)流轉(zhuǎn)換成對象。Java中編組的實現(xiàn)方式是序列化(serialization)。


        代理

    代理是一個實現(xiàn)給定接口的對象,但是不直接執(zhí)行一些代碼計算結(jié)果,而是代表其他一些對象執(zhí)行實際計算的對象。


        
        代理可以代表其他的庫或者某種類似的可以代替它執(zhí)行網(wǎng)絡(luò)通信的東西。這就是RMI工作的原理,代理在RMI也即存根(Stub)。

    引用位于服務(wù)器中的對象的代理是如何構(gòu)造的?客戶端不能有一個真的Java引用,因為Java引用只在對象位于同一個JVM時才能正常工作。構(gòu)造的基本思想是為服務(wù)器對象分配一個唯一的標識序號,該序號由代理保存,此外還有對象所在的主機名。



        客戶如何請求代理

    在獲取代理時我們需要一個間接層把所有細節(jié)抽象,通過使用名字去獲得對應(yīng)對象的思想就是命名。命名的一個主要作用是通過使用對象的名字,簡化獲得對象的任務(wù)。

    對于RMI來說,最通用的命名實現(xiàn)時RMI注冊,它具有bind和lookup操作,對于命名服務(wù)來說,客戶端其實存在一個它的代理。

    命名使用示例圖

    posted @ 2009-05-19 21:37 遲來的兵 閱讀(463) | 評論 (0)編輯 收藏

    一.String對象的比較,+操作和intern方法
    這里從一個問題入手來看看。

    package testPackage;
       public class Test {
            
    public static void main(String[] args) {
                String hello 
    = "Hello", lo = "lo";
                System.out.print((hello 
    == "Hello"+ " ");
                System.out.print((Other.hello 
    == hello) + " ");
                System.out.print((other.Other.hello 
    == hello) + " ");
                System.out.print((hello 
    == ("Hel" + "lo")) + " ");
                System.out.print((hello 
    == ("Hel" + lo)) + " ");
                System.out.println(hello 
    == ("Hel" + lo).intern());
            }

        }
        class Other {
            
    static String hello = "Hello";
        }


    package other;
        public class Other {
            
    static String hello = "Hello";
        }

    正確答案:true true true true false true
    主要要點有:
    1.所有內(nèi)容相同的String指向同一個內(nèi)存塊。但String對象不能是通過new操作創(chuàng)建出來。主要原因是JVM對String做了優(yōu)化,String加載之后會持有一個常量池,
    只要在常量池中找到內(nèi)容相同的String就會把其引用返回。而new操作是直接在內(nèi)存中分配新空間。



    2.Java中有兩種綁定,靜態(tài)和動態(tài)。如果+操作的兩邊是常量表達式那么會在采用靜態(tài)綁定,也就是說編譯之后值已經(jīng)定下來了。而如果有一邊是通過new操作創(chuàng)建出
    來的那么會采用動態(tài)綁定,只有在運行的時候才知道其具體的值。
    3.String的intern方法會到常量池里面找是否有相同內(nèi)容的String,如果有則返回其引用。如果沒有則把這個String對象添加到常量池之中并放回其引用。額外說
    下,intern在英文中有保留區(qū)的意思,這樣好理解其作用。intern方法還是native的。
    二.String中的正則表達式使用

    String中有些方法是需要正則表達式作為參數(shù)的。這個時候就要主要不要傳錯參數(shù)。最典型的例子就是replaceAll(String regex, String replacement)。第一個
    參數(shù)是需要正則表達式的,而第二參數(shù)是普通的字符串。
            String ss = "???";
            ss 
    = ss.replaceAll("?""=");//運行到這里會拋出PatternSyntaxException,因為“?”在正則表達式里面是特殊符號,需要轉(zhuǎn)義。
            ss = ss.replaceAll("[?]""=");//正確,我個人比較傾向于這種寫法。
            ss = ss.replaceAll("\\?""=");//正確,對“?”做轉(zhuǎn)義。

    因此在使用split,replaceAll,replaceFirst等方法時要特別注意是不是需要轉(zhuǎn)義.

    posted @ 2008-12-06 19:39 遲來的兵 閱讀(233) | 評論 (0)編輯 收藏


    posts - 6, comments - 8, trackbacks - 0, articles - 1

    Copyright © 遲來的兵

    主站蜘蛛池模板: 亚洲一本综合久久| 亚洲av永久无码精品表情包| 亚洲黄色网址大全| 波多野结衣免费一区视频| 亚洲国产精品一区二区第一页免| 亚洲爆乳无码专区www| 日韩一区二区a片免费观看 | 亚洲Av无码专区国产乱码DVD| jizz免费在线影视观看网站| 亚洲精品尤物yw在线影院| 五月天婷婷精品免费视频| 亚洲人成色7777在线观看不卡| 免费大片av手机看片高清| 亚洲av无码成人精品区| 一区在线免费观看| 亚洲国产精品无码成人片久久| 国内精品免费在线观看| 久久久久久亚洲精品成人| 国产成人免费网站| 亚洲AV无码一区二区大桥未久 | 三级黄色免费观看| 国产AV无码专区亚洲AV毛网站| a视频免费在线观看| 久久精品7亚洲午夜a| 亚洲高清视频免费| 亚洲精品天堂成人片AV在线播放| 国产精品国产午夜免费福利看| 亚洲AV日韩综合一区| 婷婷综合缴情亚洲狠狠尤物| 羞羞漫画小舞被黄漫免费| 国产亚洲精品免费视频播放| 午夜不卡久久精品无码免费| wwwxxx亚洲| 亚洲一级黄色视频| 69精品免费视频| 成人亚洲国产精品久久| 亚洲日韩人妻第一页| 8090在线观看免费观看| 亚洲AV无码成人精品区狼人影院| 国产亚洲老熟女视频| 99久久免费国产精品特黄|