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

📄 gap.java

📁 JMule是一个基于Java开发
💻 JAVA
字号:
/* *  JMule - Java file sharing client *  Copyright (C) 2007-2008 JMule team ( jmule@jmule.org / http://jmule.org ) * *  Any parts of this program derived from other projects, or contributed *  by third-party developers are copyrighted by their respective authors. * *  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. * *  This program is distributed in the hope that it will be useful, *  but WITHOUT ANY WARRANTY; without even the implied warranty of *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the *  GNU General Public License for more details. * *  You should have received a copy of the GNU General Public License *  along with this program; if not, write to the Free Software *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA. * */package org.jmule.core.sharingmanager;/** *  * @author pola * @version $$Revision: 1.2 $$ * Last changed by $$Author: binary256_ $$ on $$Date: 2008/08/11 15:20:39 $$ */public class Gap implements Cloneable {	long start;	long end;  	public Gap(long start, long end) {		this.start = start;		this.end = end;	}     	public long size() {		return end - start;	}    	public boolean intersects(Gap gap) {		return ((gap.start >= this.start) && (gap.start < this.end) ||			(this.start >= gap.start) && (this.start < gap.end));	}   	public boolean covers(Gap gap) {		return (this.start <= gap.start) && (this.end >= gap.end);	}       	public long chop(Gap gap) {		long previousSize = this.size();		if(this.start < gap.start) this.end = Math.min(this.end, gap.start);		else if(gap.start < this.start) this.start = Math.max(this.start, gap.end);		return this.size() - previousSize;	}       	public long merge(Gap gap) {		long previousSize = this.size();		this.start = Math.min(this.start, gap.start);		this.end = Math.max(this.end, gap.end);		return this.size() - previousSize;	}      	public Gap intersect(Gap gap) {		if(! this.intersects(gap))			return null;		try {			Gap result = (Gap) this.clone();			result.start = Math.max(result.start, gap.start);			result.end = Math.min(result.end, gap.end);						return result;		} catch (ClassCastException cce) {			// You should never get here :-)			return null;			} catch (CloneNotSupportedException cnse) {			// You should never get here :-)			return null;			}	} 	public String toString() {		return Long.toString(start) + ":" + Long.toString(end);	}     	public Object clone() throws CloneNotSupportedException  {		return super.clone();		}	public boolean contain(long pos){		if ((start<pos)&&(pos<=end))			return true;		return false;	}      	public long getEnd() {		return end;	}        	public long getStart() {		return start;	}}

⌨️ 快捷键说明

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