嗯看看写文章高级模式好用不(不管哪个模式从没觉得好用过,泪奔)
从头开始说,移动P2P数据分发算法研究,看得出来杨小姐从提出这个课题到看见我到寒假后到进度汇报会后,期望值越来越低了 - -... 她肯定希望一个年级排名前10外加英文超好的动手派,从无到有凭空变个完整的程序给她。无奈遇到我这种赖皮,java局限于入门,外加也没做过什么项目。杨小姐已经明确给了我份硕士论文看,说努力实现这个算法就好,我看完只觉得为什么背景要介绍那么多,实现说得那么少。
寒假买了本JXTA技术手册,迟迟不动手。没办法,java课上又没教过如何用现有的jar包。好在本人运气不是一般的好,3月初的实训(jsp+tomcat+oracle等)我啥都没听到就注意上了eclipse,主要就是知道了如何添加jar包 -_- 当然人样衰是不能怪社会的,谁知道我第一次在家用eclipse建立工作台就出了个乌龙,简单的说就是导致后面运行第一个jxta程序时配置文件(PlatformConfig)出不来。在学校后我又误打误撞把这个故事给ok了,嘿嘿作为经验保留我不写出来。
然后应该是最简单的HelloWorld里,JXTA技术手册上第一个建立NetPeerGroup的方法就失效了。这本是老书,而现在JXTA都发展到2.5了。这让我对该书产生很大的不信任感,如此基础的都能失效,那后面岂不是满江红么。嗯好在看完第四章也没什么问题。顺便说一下这个方法的修改吧:
原:
import net.jxta.peergroup.PeerGroupFactory;
...
PeerGroup netpg = null;
netpg = PeerGroupFactory.newNetPeerGroup();
现:
import net.jxta.peergroup.NetPeerGroupFactory;
...
PeerGroup netpg = null;
netpg = (new NetPeerGroupFactory()).getWeakInterface();
上例除了Net还有World版本。
再把JXTA制作组鄙视一万遍啊一万遍。
鄙视那么多也挺累的,HelloWorld没什么说头,说通告吧。
技术手册上用的例子是餐馆与食客的。
对于餐馆类来说,结构如下:
1、花现现有的对等组(RestoNet)通告。
a. 本地缓存
DiscoveryService hdisco = netpg.getDiscoveryService();
Enumeration ae = null;
ae = hdisco.getLocalAdvertisement(DiscoveryService.GROUP,"Name","RestoNet");
b. 发送请求,有响应就丢进缓存
hdisco = getRemoteAdvertisement(null,DiscoveryService.GROUP,"Name","RestoNet",1,null);
第一个null指发向对等组全体
c. Thread.sleep();
d. 察看缓存
2、没花现,就先创建通告,再创建对等组。
ModuleImplAdvertisement implAdv = netpg.getAllPurposePeerGroupImplAdvertisement();
restoNet = netpg.newGroup(mkGroupID().implAdv,"RestoNet","RestoNet, Inc");
3、花现了,就使用通告加入对等组。
restoNetAdv = (PeerGroupAdvertisement) ae.nextElement();
restoNet = netpg.newGroup(restoNetAdv);
对于食客类:
没太大不同,就是不用建立对等组了而已(为啥不用?省力而已,没特别原因)。
运行这俩要不同的project,这样才能保证有不同的PlatformConfig(记得两个对等体的端口要设置成不一样噢)。运行过一次后,对等组通告会保留在本地缓存中。
本例只负责把这俩都加入到同一对等组中,食客想去餐馆吃东西的话,请看下一篇:
JXTA 管道