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

📄 discoverpeerjob.java

📁 CoolFace是基于jxta的P2P系统
💻 JAVA
字号:
package com.cn.darkblue.job;

import java.util.Map;

import net.jxta.discovery.DiscoveryService;
import net.jxta.peergroup.PeerGroup;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.jobs.Job;

import com.cn.darkblue.listener.CFPGQueryListener;
import com.cn.darkblue.listener.CFPeerQueryListener;
import com.cn.darkblue.util.CFDefData;

public class DiscoverPeerJob extends Job{
	private static final Log log = LogFactory.getLog(DiscoverPeerJob.class);

	int seconds = 2;
	int times = 0;
	PeerGroup parentPg = null;
	Map conditions = null;
	
	DiscoveryService discovery;
	CFPeerQueryListener listener;
	
	public Map getConditions() {
		return conditions;
	}
	public void setConditions(Map conditions) {
		this.conditions = conditions;
	}
	public PeerGroup getParentPg() {
		return parentPg;
	}
	public void setParentPg(PeerGroup parentPg) {
		this.parentPg = parentPg;
	}
	public int getSeconds() {
		return seconds;
	}
	public void setSeconds(int seconds) {
		this.seconds = seconds;
	}
	public int getTimes() {
		return times;
	}
	public void setTimes(int times) {
		this.times = times;
	}
	public DiscoverPeerJob(String name,PeerGroup pg){
		super(name);
		parentPg = pg;
		
		discovery = parentPg.getDiscoveryService();
		listener = new CFPeerQueryListener(parentPg);
		listener.init(conditions);
		discovery.addDiscoveryListener(listener);
	}
	public DiscoverPeerJob(PeerGroup pg){
		this("DiscoverPeer",pg);

	}
	@Override
	protected IStatus run(IProgressMonitor monitor) {
		if(times<seconds){
			try{
				
				discovery.getLocalAdvertisements(DiscoveryService.PEER, null, null);
				discovery.getRemoteAdvertisements(null, DiscoveryService.PEER,
						null, null, CFDefData.MAX_RESPONSE);
				
			}catch(Exception e){
				e.printStackTrace();
				log.error(e.getMessage());
			}finally{
				schedule(CFDefData.STAND_SLEEP);
				times++;
				log.info(" Sertch the peer time : "+(seconds-times));
			}
		}
		return null;
	}

}

⌨️ 快捷键说明

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