Jade:如何多次运行同一个代理?

时间:2016-12-20 11:00:24

标签: java eclipse-plugin agent agents-jade multi-agent

我需要多次运行我的代理。每次所有代理都应该

  • 创建
  • 执行他们的行为并
  • 从平台中删除。

我的问题是最后一步。

如何从平台中删除代理,或者如何关闭平台以便稍后执行另一个代理?

我尝试了这段代码,但仍然无法关闭RMA:

for( int i=0; i<10;i++)
{
    System.out.println("******************************iteration************************"+i);
    // Récupération du conteneur (Main Container) en cours d'execution de Jade                  
    Runtime rt = Runtime.instance();
    // Création du profil par défault
    ProfileImpl p = new ProfileImpl(false);
    AgentContainer container =rt.createAgentContainer(p);
    AgentController Agent=null;     


    for (int j=0; j<Ag.length;j++)
    {//loop to create all the existing agents in Ag (array).
        try { System.out.println("creation de l'agent"+j);
            Agent = container.createNewAgent(Ag[j], "jade.project."+Ag[j], null);
            Agent.start();  

        } catch (StaleProxyException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }       


    //shut down
    System.out.println("******************************Fin iteration************************"+i);

}

我怎样才能每次都关闭主容器?感谢

2 个答案:

答案 0 :(得分:0)

您可以尝试使用container.kill()来关闭平台。

答案 1 :(得分:0)

我通常使用代理管理系统。使用AMS有很多代码和管理员,但它允许您对响应采取行动(通知/失败)。

public void destroyAgent(final AID AgentName) {
    log("kill agent initiated by " + this.getLocalName());
    KillAgent ka = new KillAgent();
    ka.setAgent(AgentName);

    Action actExpr = new Action(this.getAMS(), ka);
    ACLMessage AMSRequest = new ACLMessage(ACLMessage.REQUEST);
    AMSRequest.addReceiver(this.getAMS());

    AMSRequest.setOntology(JADEManagementOntology.getInstance().getName());
    AMSRequest.setLanguage(FIPANames.ContentLanguage.FIPA_SL);
    AMSRequest.setProtocol(FIPANames.InteractionProtocol.FIPA_REQUEST);
    try {
        getContentManager().fillContent(AMSRequest, actExpr);

        addBehaviour(new AchieveREInitiator(this, AMSRequest) {

            protected void handleInform(ACLMessage inform) {
                log(Level.INFO, "Agent successfully Destroyed name:" + AgentName);
            }

            protected void handleFailure(ACLMessage failure) {
                log(Level.SEVERE, "Agent kill failed name: " + AgentName);
            }
        });
    } catch (Exception e) {
        e.printStackTrace();
    }

}