日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

erlang talk to java

系統(tǒng) 3180 0

Erlang: Let’s talk to java

August 29th, 2007 :: jackyz

試了一下傳說中的 JInterface ,使用 OtpErlang.jar 的整個(gè)過程其實(shí)非常簡(jiǎn)單,似乎比 JMS 的程序都簡(jiǎn)單。

首先,我們要用 java 實(shí)現(xiàn)的原始 erlang 程序如下,沒錯(cuò),就是巨簡(jiǎn)單的 echo ,我們的目標(biāo)是要把它用 java 來改寫,不僅寫服務(wù)端,也要寫客戶端。

  1. - module ( echo_client ) .
  2. ?
  3. - export ([ run / 0 ]) .
  4. ?
  5. run () ?->
  6. ? ?? Msg ?=? " Hello Echo! " ,
  7. ? ? { echo ,? abc @ merlin } ! { self () ,? Msg },
  8. ? ?? io : format ( " send ~p ~n " ,? [ Msg ]) ,
  9. ? ?? receive
  10. ? ? ? ?? Res ?->
  11. ? ? ? ? ? ?? io : format ( " received ~p ~n " ,? [ Res ])
  12. ? ?? end .
  1. - module ( echo_server ) .
  2. ?
  3. - export ([ start / 0 ]) .
  4. ?
  5. start () ?->
  6. ? ?? register ( echo ,? self ()) ,
  7. ? ?? io : format ( " echo start~n " ,? []) ,
  8. ? ?? loop () .
  9. ?
  10. loop () ?->
  11. ? ?? receive
  12. ? ? ? ? { Pid ,? Msg } ->
  13. ? ? ? ? ? ?? io : format ( " received ~p from ~p~n " ,? [ Msg ,? Pid ]) ,
  14. ? ? ? ? ? ?? Pid ?!? Msg ;
  15. ? ? ? ?? Any ?->
  16. ? ? ? ? ? ?? io : format ( " received ~p ~n " ,? [ Any ])
  17. ? ?? end ,
  18. ? ?? loop () .

寫得并不嚴(yán)密,用了一堆硬編碼,主要是個(gè)示例,就那么個(gè)意思,大家將就著看。

先說一下 JInterface 的一些基本概念。JInterface 的目的是:為 Java 提供一個(gè)包,使得 Java 程序在外部可以看起來就像一個(gè)標(biāo)準(zhǔn)的 Erlang Node 能以標(biāo)準(zhǔn)的 Erlang 方式與其他的節(jié)點(diǎn)進(jìn)行通訊。它包裝了 Erlang 節(jié)點(diǎn)之間分布式的通訊協(xié)議,編碼解碼,以及基本的 Erlang 操作,也就是 pid register send receive link unlink 等等,樸實(shí)無華。不過,作為兩個(gè)語言之間的接口包,有了這些基本功能也就足夠了。

根據(jù) Erlang 的目錄慣例, JInterface 的 Jar 在 ERLANG_HOME/lib/jinterface-x.x/priv 目錄下,名字為 OtpErlang.jar 。注意,必須使用和你當(dāng)前 Erlang 版本下的包,否則出了什么妖怪問題,別來問我,就算是問我,我也不知道該怎么辦。:D 之前一直有一個(gè)誤解,想當(dāng)然的以為 JInterface 會(huì)用 JNI 什么的來實(shí)現(xiàn),而自從碰過一次以后,對(duì) JNI 這種“難以掌控”的東西總覺得有點(diǎn)畏難,所以,遲遲都沒有動(dòng)手,沒想到,竟是純 Java 實(shí)現(xiàn)的一個(gè)包。用起來方便,部署起來也漂亮。爽!

閑話休提,直接上代碼得了。先是 Client 的代碼。

  1. package ? com . test . erlang ;
  2. ?
  3. import ? java . io . IOException ;
  4. ?
  5. import ? com . ericsson . otp . erlang .*;
  6. ?
  7. public ? class ? ErlangEchoClient ?{
  8. ? ?
  9. ? ?? public ? static ? void ? main ( String [] ? args ) ? throws ? IOException ?{
  10. ? ? ? ?
  11. ? ? ? ?? String ? v ?= System . getProperties () . getProperty ( " OtpConnection.trace " ) ;
  12. ? ? ? ?? System . out . println ( " OtpConnection.trace= " + v ) ;
  13. ? ? ? ?
  14. ? ? ? ?? OtpNode ? self ?=? new ? OtpNode ( " bcd " ,? " 123 " ) ;
  15. ? ? ? ?
  16. ? ? ? ?? System . out . println ( " node: " + self . node ()) ;
  17. ? ? ? ?? System . out . println ( " cookie: " + self . cookie ()) ;
  18. ? ? ? ?
  19. ? ? ? ?? if ? ( self . ping ( " abc " ,? 2000 )) ?{
  20. ? ? ? ? ? ?? System . out . println ( " remote is up " ) ;
  21. ? ? ? ? }? else ?{
  22. ? ? ? ? ? ?? System . out . println ( " remote is not up " ) ;
  23. ? ? ? ? ? ?? return ;
  24. ? ? ? ? }
  25. ? ? ? ?
  26. ? ? ? ?? String ? text ?=? " Hi there " ;
  27. ? ? ? ?
  28. ? ? ? ?? OtpMbox ? mbox ?=? self . createMbox () ;
  29. ? ? ? ?
  30. ? ? ? ?? OtpErlangObject [] ? msg ?=? new ? OtpErlangObject [ 2 ] ;
  31. ? ? ? ?? msg [ 0 ] ?=? mbox . self () ;
  32. ? ? ? ?? msg [ 1 ] ?=? new ? OtpErlangString ( text ) ;
  33. ? ? ? ?? OtpErlangTuple ? tuple ?=? new ? OtpErlangTuple ( msg ) ;
  34. ?
  35. ? ? ? ?? mbox . send ( " echo " ,? " abc " ,? tuple ) ;
  36. padding-top: 0px !important; padding-right: 0px !important; padding-bottom: 0px !important; padding-left: 20px; display: list-item !important; font-size: 12px !important; line-height: 20px !important; border-left-width: 1px; border-left-style: solid; border-left-color: #c3ced9; border-top-width: 1px; border-top-style: solid; border-top-color: #e3eef9 !important; background-color: #f9fbfc !impo
分享到:
評(píng)論

erlang talk to java


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 辽阳县| 安平县| 长丰县| 黄梅县| 松江区| 永顺县| 依兰县| 德格县| 灵台县| 区。| 读书| 华坪县| 龙泉市| 古交市| 临邑县| 葵青区| 宁化县| 正宁县| 瓦房店市| 昌宁县| 梅州市| 曲周县| 长泰县| 平顶山市| 扎鲁特旗| 凤阳县| 南溪县| 若尔盖县| 哈巴河县| 靖州| 紫云| 砚山县| 上林县| 普宁市| 邹平县| 赤峰市| 桂林市| 定南县| 体育| 新龙县| 饶平县|