Peersim如何解析文件

开始接触peersim的时候,最早想知道的问题就是peersim如何读取配置文件,如何获取配置信息。

有关配置文件处理的类都在报peersim.config中,主要看Configuration和FastConfig两个类来获取配置信息。

1)configContainer将所有配置信息储存在变量config(import java.util.Properties)中;

/**

* The properties object that stores all configuration information.

*/

privatePropertiesconfig;

并封装了很多读取配置信息的方法,但是都是提供给Configration类调用,用户通过调用Configuration中的方法获取配置信息:

可根据需要获取不同类型的返回值


2)configProperites,继承了Properties,扩展了Properties的功能。

3)Configuration,获取配置信息,主要是对configContainer的方法进行了封装,使获取配置信息更方便;

注意这一个配置参数:

static final String PAR_INCLUDE = "include";#用来配置init或者control的运行先后顺序

4)FastConfig,专门快速获取在协议中配置的linkable和transport:

private static final String PAR_LINKABLE = "linkable";

private static final String PAR_TRANSPORT = "transport";

public static int getLinkable(int pid)

public static int getTransport(int pid)

其实用户只需要调用Configuration中的方法来获取配置的信息,例如,

这是一个用户自定义的观测各节点数值的control类,只列出构造函数:

01
02publicclassAverageObserverimplementsControl{
03
04privatestaticfinalStringPAR_ACCURACY="accuracy";
05
06privatestaticfinalStringPAR_PROT="protocol";
07
08privatefinalStringname;
09
10privatefinaldoubleaccuracy;
11
12/**Protocolidentifier;obtainedfromconfigproperty{@link#PAR_PROT}.*/
13privatefinalintpid;
14
15publicAverageObserver(Stringname){
16this.name=name;
17accuracy=Configuration.getDouble(name+"."+PAR_ACCURACY,-1);
18pid=Configuration.getPid(name+"."+PAR_PROT);
19}

20 }
看这个实现control接口的类,接受accuracy和protocol两个参数,配置的时候应该是:

protocol.avg example.aggregation.AverageFunction

control.avgo AverageObserver

control.avgo.protocol avg #avg就是上面第一行配置好的protocol

accuray没有配置,configuraiton就把默认值-1传给它(Configuration.getDouble(name+"."+PAR_ACCURACY,-1)

注意:构造函数的参数name就是前缀control.avgo,想要配置参数,类的构造函数就必须有且只有一个string参数。

上面说的主要是peersim如何获取配置信心的过程,下面列出peersim内核中所有可能的配置信息(即非用户定义的配置参数):

network.node

network.initialCapacity

network.size

simulation.cycles

simulation.nodefaultcycle

simulation.endtime

simulation.logtime

simulation.eventqueue

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Eclipse下PeerSim仿真(2010-07-24 14:21:16) 转载▼ 标签: 杂谈 Eclipse下PeerSim仿真 时间: 2010.06.25 23:00:00 标签: PeerSim ,Eclipse http://hi.baidu.com/bookpage/blog/item/1bc32a341a8f46bbd0a2d3c6.html ******************** Eclipse下PeerSim仿真 ******************** ------------------------ 本文参考: http://peersim.sourceforge.net/ http://blog.sina.com.cn/s/blog_453a60170100hyno.html http://hi.baidu.com/bookpage/blog/item/1bc32a341a8f46bbd0a2d3c6.html ------------------------ 0、关于PeerSim 主页:http://peersim.sourceforge.net/ 下载:http://sourceforge.net/projects/peersim/ P2P仿真软件,基于JAVA语言。 2004年发布0.0版,最新版本1.0.5发布于2009年9月29日。 1、安装JDK和Eclipse 网上很多资料,此处不多说。 关于JDK版本,没有找到相关说明,下载较新版本即可,如JDK1.6就可以。 Eclipse最新有一个Helios(太阳神)版。 2、示例(PeerSim的"hello world") (1)创建一个java project,命名为PeerSim。 (2)将下载的peersim-1.0.5.zip中的src目录下的文件都拷贝到工程主目录下的src目录下。 (3)将下载的peersim-1.0.5.zip中主目录下的jar文件拷贝到工程主目录下。 (4)添加libraries。Project--Properties--Java Build Path。 Add External JARs,将主目录下的jar文件都添加进去。 (5)编写仿真配置文件。这里使用peersim-1.0.5的example目录下的config-example1.txt。将这个txt文件拷贝到工程主目录下。 (6)运行,在Eclipse的Package Explore栏找到这个txt文件,右键,Run as--Run Configurations。 Main:在Name中输入Application名称,比如PeerSimApp;在main class中输入peersim.Simulator,或者搜索之。 Arguments:在Program arguments中输入config-example1.txt,也就是配置文件。 (7)第6步完成之后,点击运行,会出现错误: peersim.config.IllegalParameterException: Parameter "protocol.lnk": The class peersim.core.IdleProtocol appears more than once in the classpath; please check your classpath to avoid duplications. At peersim.config.ConfigContainer.getClazz:582 解决方法: 在第6步,右键,Run as--Run Configurations,配置Classpath,使得User Entries中只保留djep-1.0.0.jar,peersim-1.0.5.jar,jep-2.3.0.jar,也就是删除peersim-doclet.jar。这个时候再运行,仿真就能正常结束了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值