⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 retrievenetwork.java

📁 Chord package into p2psim
💻 JAVA
字号:
/***************************************************************************
 *                                                                         *
 *                           RetrieveNetwork.java                          *
 *                            -------------------                          *
 *   date                 : 15.09.2004                                     *
 *   copyright            : (C) 2004-2008 Distributed and                  *
 *                              Mobile Systems Group                       *
 *                              Lehrstuhl fuer Praktische Informatik       *
 *                              Universitaet Bamberg                       *
 *                              http://www.uni-bamberg.de/pi/              *
 *   email                : sven.kaffille@uni-bamberg.de                   *
 *                          karsten.loesing@uni-bamberg.de                 *
 *                                                                         *
 *                                                                         *
 ***************************************************************************/

/***************************************************************************
 *                                                                         *
 *   This program is free software; you can redistribute it and/or modify  *
 *   it under the terms of the GNU General Public License as published by  *
 *   the Free Software Foundation; either version 2 of the License, or     *
 *   (at your option) any later version.                                   *
 *                                                                         *
 *   A copy of the license can be found in the license.txt file supplied   *
 *   with this software or at: http://www.gnu.org/copyleft/gpl.html        *
 *                                                                         *
 ***************************************************************************/

package de.uniba.wiai.lspi.chord.console.command;

import de.uniba.wiai.lspi.chord.console.command.entry.Key;
import de.uniba.wiai.lspi.chord.service.Chord;
import de.uniba.wiai.lspi.util.console.Command;
import de.uniba.wiai.lspi.util.console.ConsoleException;

import java.io.Serializable;
import java.util.Set;

/**
 * <p>
 * {@link Command} to retrieve a value from the remote chord network. 
 * </p>
 * To get a description of this command type <code>retrieveN -help</code> 
 * into the {@link de.uniba.wiai.lspi.chord.console.Main console}.
 * @author  sven
 * @version 1.0.5
 */
public class RetrieveNetwork extends Command {
    
	/**
	 * The name of this {@link Command}. 
	 */
    public static final String COMMAND_NAME = "retrieveN";
    
    /**
     * The name of the parameter, that defines the key to be retrieved. 
     */
    protected static final String KEY_PARAM = "key";
    
    /** Creates a new instance of Retrieve 
     * @param toCommand1 
     * @param out1 */
    public RetrieveNetwork(Object[] toCommand1, java.io.PrintStream out1) {
        super(toCommand1, out1);
    }
    
    public void exec() throws ConsoleException {
        String key = this.parameters.get(KEY_PARAM);
        if ( (key == null) || (key.length() == 0) ){
            throw new ConsoleException("Not enough parameters! " + KEY_PARAM + " is missing.");
        }
        
        Key keyObject = new Key(key);
        
        Chord chord = ((RemoteChordNetworkAccess)this.toCommand[1]).getChordInstance(); 
        try {
            Set<Serializable> vs = chord.retrieve(keyObject);
            Object[] values = vs.toArray(new Object[vs.size()]); 
            this.out.println("Values associated with key '" + key + "': ");
            for (int i = 0; i < values.length; i++) {
                this.out.print(values[i]);
                if ( !(i == (values.length-1)) ) {
                    this.out.print(",");
                }
                this.out.print(" ");
            }
            this.out.println();
        }
        catch (Throwable t){
            ConsoleException e = new ConsoleException("Exception during execution of command. " + t.getMessage());
            e.setStackTrace(t.getStackTrace());
            throw e;
        }
        
    }
    
    public String getCommandName() {
        return COMMAND_NAME;
    }
    
    public void printOutHelp() {
        this.out.println("This command retrieves and displays the values stored for a provided key in the chord network.");
        this.out.println("The search is initiated by the node provided as parameter.");
        this.out.println("Required parameters: ");
        this.out.println("\t" + KEY_PARAM + ": The key for the values.");
        this.out.println();
    }
    
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -