亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? zipintmultshorthashmap.java

?? 手機郵箱撒的方式方式方式的
?? JAVA
字號:
//#condition MUJMAIL_COMPRESSED_CONNECTION/* * Created on 30-Nov-2005 at 23:12:37. *  * Copyright (c) 2005 Robert Virkus / Enough Software * * This file is part of J2ME Polish. * * J2ME Polish 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. *  * J2ME Polish 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 J2ME Polish; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA *  * Commercial licenses are also available, please * refer to the accompanying LICENSE.txt or visit * http://www.j2mepolish.org for details. */package mujmail.connections.gzip;/** * <p>Provides the functionality of the J2SE java.util.HashMap for J2ME applications and uses reference checks for comparing keys.</p> * <p>WARNING: Only use this implementation when you can ensure that you always *    use the original keys! (see below) * </p> * <p>In contrast to the java.util.Hashtable (which is available on J2ME platforms), *    this implementation is not synchronized and faster. This implementation *    also uses only reference checks (==) for testing keys and values on *    equality instead of calling equals() for comparing them. This is considerably *    faster, but you need to ensure that you only use references (=the original) keys when *    storing or retrieving values. * </p> * <p>This implementation uses chains for resolving collisions, that means *    when a key-value pair has the same hash code as a previous inserted item, *    the new item is linked to the previous item. Depending on your situation *    The OpenAddressingHashMap implementation might be better, especially when you *    do not have many collisions (items with the same hash code). * </p> * * <p>Copyright (c) Enough Software 2005 - 2008</p> * <pre> * history *        30-Nov-2005 - rob creation *        28-Jun-2007 - Simon boiled down to short arrays * </pre> * @author Robert Virkus, j2mepolish@enough.de */public class ZipIntMultShortHashMap{	//	/** The default capacity is 16 *///	public static final int DEFAULT_INITIAL_CAPACITY = 16;	/** The default load factor is 75 (=75%), so the HashMap is increased when 75% of it's capacity is reached */ 	public static final int DEFAULT_LOAD_FACTOR = 75;		public static final int SUB_ELEMENT_SIZE =3;		private final int loadFactor;		private Element[] buckets;	private final boolean isPowerOfTwo;	private int size;	/*/**	 * Creates a new HashMap with the default initial capacity 16 and a load factor of 75%. 	 */	/*public ZipIntMultShortHashMap() {		this( DEFAULT_INITIAL_CAPACITY, DEFAULT_LOAD_FACTOR );	}*/		/**	 * Creates a new HashMap with the specified initial capacity.	 * 	 * @param initialCapacity the initial number of elements that this map can hold without needing to 	 *        increase it's internal size.	 */	public ZipIntMultShortHashMap(int initialCapacity ) {		this( initialCapacity, DEFAULT_LOAD_FACTOR );	}	/**	 * Creates a new HashMap with the specified initial capacity and the specified load factor.	 * 	 * @param initialCapacity the initial number of elements that this map can hold without needing to 	 *        increase it's internal size.	 * @param loadFactor the loadfactor in percent, a number between 0 and 100. When the loadfactor is 100,	 *        the size of this map is only increased after all slots have been filled. 	 */	public ZipIntMultShortHashMap(int initialCapacity, int loadFactor) {		initialCapacity = (initialCapacity * 100) / loadFactor;		// check if initial capacity is a power of 2:		int capacity = 1;		while (initialCapacity > capacity) {			capacity <<= 1;		}		this.isPowerOfTwo = (capacity == initialCapacity);		//System.out.println("isPowerOfTwo: " + this.isPowerOfTwo );		this.buckets = new Element[ initialCapacity ];		this.loadFactor = loadFactor;	}		/* (non-Javadoc)	 * @see de.enough.polish.util.Map#put(java.lang.Object, java.lang.Object)	 */	public boolean put( int key, short value ) {		if ( (this.size * 100) / this.buckets.length > this.loadFactor ) {			increaseSize();		}				int index;		if (this.isPowerOfTwo) {			index = (key & 0x7FFFFFFF) & (this.buckets.length - 1);		} else {			index = (key & 0x7FFFFFFF) % this.buckets.length;		}		Element element = this.buckets[ index ];		if (element == null) {			// new List			// new element			element = new Element( key, new short[SUB_ELEMENT_SIZE] );			element.values[0]=value;			element.size++; //==1						this.buckets[index] = element;			this.size++;			return true;		} else {			// add a value to the array			Element lastElement = element;			do {				if (element.key == key ) {					// element found!					element.size++;					// add data					if(element.size==element.values.length){						// increase the value array						short[] newValues = new short[element.values.length*2];//TODO constant						System.arraycopy(element.values, 0, newValues, 0, element.values.length);						element.values=newValues;					}					element.values[element.size-1]=value;										return true;				}				lastElement = element;				element = element.next;			} while ( element != null );						// insert new element at the end since no other was found						// new element			element = new Element( key, new short[SUB_ELEMENT_SIZE] );			element.values[0]=value;			element.size++; //==1						this.buckets[index] = element;			this.size++;			lastElement.next = element;			return true;		}	}		/* (non-Javadoc)	 * @see de.enough.polish.util.Map#get(java.lang.Object)	 */	public Element get( int key ) {		int index;		if (this.isPowerOfTwo) {			index = (key & 0x7FFFFFFF) & (this.buckets.length - 1);		} else {			index = (key & 0x7FFFFFFF) % this.buckets.length;		}		Element element = this.buckets[ index ];		if (element == null) {			return null;		}		do {			if (element.key == key ) {				return element;			}			element = element.next;		} while (element != null);		return null;	}		/* (non-Javadoc)	 * @see de.enough.polish.util.Map#remove(java.lang.Object)	 */	public short remove( int key ) {		int index;		if (this.isPowerOfTwo) {			index = (key & 0x7FFFFFFF) & (this.buckets.length - 1);		} else {			index = (key & 0x7FFFFFFF) % this.buckets.length;		}		Element element = this.buckets[ index ];		if (element == null) {			//System.out.println("remove: No bucket found for key " + key + ", containsKey()=" + containsKey(key));			return -1;		}		Element lastElement = null;		do {			if (element.key == key ) {				if (lastElement == null) {					this.buckets[ index ] = element.next;				} else {					lastElement.next = element.next;				}				this.size--;				return 1;//element.values;			}			lastElement = element;			element = element.next;		} while (element != null);		//System.out.println("No element found for key " + key + ", containsKey()=" + containsKey(key));		return -1;	}		/* (non-Javadoc)	 * @see de.enough.polish.util.Map#isEmpty()	 */	public boolean isEmpty() {		return (this.size == 0);	}		/* (non-Javadoc)	 * @see de.enough.polish.util.Map#size()	 */	public int size() {		return this.size;	}		/* (non-Javadoc)	 * @see de.enough.polish.util.Map#containsKey(java.lang.Object)	 */	public boolean containsKey( int key ) {		return get( key ) != null;	}	/* (non-Javadoc)	 * @see de.enough.polish.util.Map#containsValue(java.lang.Object)	 */	/*public boolean containsValue( short value ) {		for (int i = 0; i < this.buckets.length; i++) {			Element element = this.buckets[i];			while (element != null) {				if (element.values == value ) {					return true;				}				element = element.next;			}		}		return false;	}*/		/* (non-Javadoc)	 * @see de.enough.polish.util.Map#clear()	 */	public void clear() {		for (int i = 0; i < this.buckets.length; i++) {			this.buckets[i] = null;		}		this.size = 0;	}		/* (non-Javadoc)	 * @see de.enough.polish.util.Map#values()	 */	/*public short[] values() {		return values( new short[ this.size ] );	}*/	/* (non-Javadoc)	 * @see de.enough.polish.util.Map#values(java.lang.Object[])	 */	/*public short[] values(short[] objects) {		int index = 0;		for (int i = 0; i < this.buckets.length; i++) {			Element element = this.buckets[i];			while (element != null) {				objects[index] = element.values;				index++;				element = element.next;			}		}		return objects;	}*/	/* (non-Javadoc)	 * @see de.enough.polish.util.Map#keys()	 */	public int[] keys() {		int[] keys = new int[ this.size ];		int index = 0;		for (int i = 0; i < this.buckets.length; i++) {			Element element = this.buckets[i];			while (element != null) {				keys[index] = element.key;				index++;				element = element.next;			}		}		return keys;	}		/**	 * Returns String containing the String representations of all objects of this map.	 * 	 * @return the stored elements in a String representation.	 */	/*public String toString() {		StringBuffer buffer = new StringBuffer( this.size * 23 );		buffer.append( super.toString() ).append( "{\n" );		short[] values = values();		for (int i = 0; i < values.length; i++) {			buffer.append( values[i] );			buffer.append('\n');		}		buffer.append('}');		return buffer.toString();	}*/		/**	 * Increaases the internal capacity of this map.	 */	private void increaseSize() {		int newCapacity;		if (this.isPowerOfTwo) {			newCapacity = this.buckets.length << 1; // * 2		} else {			newCapacity = (this.buckets.length << 1) - 1; // * 2 - 1 		}		Element[] newBuckets = new Element[ newCapacity ];		for (int i = 0; i < this.buckets.length; i++) {			Element element = this.buckets[i];			while (element != null) {								int index;				if (this.isPowerOfTwo) {					index = (element.key & 0x7FFFFFFF) & (newCapacity - 1);				} else {					index = (element.key & 0x7FFFFFFF) % newCapacity;				}				Element newElement = newBuckets[ index ];				if (newElement == null ) {					newBuckets[ index ] = element;				} else {					// add element at the end of the bucket:					while (newElement.next != null) {						newElement = newElement.next;					}					newElement.next = element;									}				Element lastElement = element;				element = element.next;				lastElement.next = null;			}		}		this.buckets = newBuckets;	}	                /**          * Class internally used by {@link mujmail.connections.gzip.ZipIntMultShortHashMap}.         * Represents pair <key, value>.         */	public static final class Element {		public final int key;		public short[] values;		public short size; // TODO undefined == value<0		public Element next;		public Element ( int key, short[] value ) {			this.key = key;			this.values = value;		}	}}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲视频一区二区免费在线观看| 日韩限制级电影在线观看| 久久奇米777| 国产一区二区三区综合| 亚洲国产精品成人综合| 成人精品视频一区二区三区| 国产精品动漫网站| 欧美性大战久久久久久久蜜臀| 亚洲成人动漫av| 欧美一区二区三区免费观看视频| 久久99精品国产麻豆不卡| 国产亚洲1区2区3区| 99这里都是精品| 亚洲不卡在线观看| 日韩精品高清不卡| 亚洲精品一区二区三区福利 | 极品少妇一区二区三区精品视频 | 久久综合色8888| 成人av资源在线| 亚洲图片欧美综合| 日韩欧美一区二区免费| 成人一区在线看| 亚洲高清免费一级二级三级| 日韩精品在线网站| 北岛玲一区二区三区四区| 亚洲午夜在线视频| 26uuu国产电影一区二区| 99国产一区二区三精品乱码| 午夜伦欧美伦电影理论片| 久久综合九色综合欧美98| 91碰在线视频| 国产一区999| 亚洲一区二区欧美日韩| 26uuu色噜噜精品一区二区| 91视频.com| 国产伦精一区二区三区| 一区二区三区在线观看网站| 精品国产污污免费网站入口 | 国产电影一区在线| 视频一区视频二区中文字幕| 国产精品网站在线| 91精品国产综合久久久蜜臀粉嫩| 成人免费观看视频| 久久99久久久久久久久久久| 亚洲柠檬福利资源导航| 久久―日本道色综合久久| 欧美日精品一区视频| 成人午夜电影久久影院| 久久不见久久见免费视频7| 亚洲精选视频在线| 国产精品私房写真福利视频| 日韩一区二区在线观看视频播放| 色婷婷久久久综合中文字幕| 国产九色精品成人porny| 五月天一区二区三区| 亚洲女人小视频在线观看| 亚洲国产激情av| 精品99一区二区三区| 日韩欧美国产综合| 在线不卡免费av| 欧洲精品一区二区三区在线观看| 成人在线视频一区二区| 国产在线乱码一区二区三区| 免费的国产精品| 日韩高清在线一区| 亚洲成人精品影院| 亚洲一区av在线| 亚洲一区二区五区| 一区二区三区.www| 亚洲图片一区二区| 亚洲成a人v欧美综合天堂下载 | 亚洲欧洲日产国产综合网| 亚洲精品一区二区三区四区高清| 日韩欧美国产综合一区| 欧美一级片在线看| 日韩色视频在线观看| 欧美一级高清片在线观看| 亚洲国产成人精品视频| 一区二区三区日本| 亚洲制服丝袜av| 亚洲综合色成人| 亚洲第一狼人社区| 青青草原综合久久大伊人精品 | 99久久精品免费看| 91视频国产资源| 色婷婷亚洲精品| 在线观看日韩国产| 在线不卡欧美精品一区二区三区| 91精品国产91久久久久久一区二区| 精品视频在线免费观看| 欧美精品成人一区二区三区四区| 欧美一区二区在线看| 欧美一级二级在线观看| 久久综合九色综合欧美98| 国产免费观看久久| 亚洲精品欧美在线| 五月综合激情网| 久久国产日韩欧美精品| 国产精品一区二区在线看| 成人午夜视频在线| 一本色道**综合亚洲精品蜜桃冫| 欧美性生活一区| 日韩欧美在线一区二区三区| 一区二区三区在线免费| 韩国成人福利片在线播放| 亚洲一级电影视频| 欧美日韩和欧美的一区二区| 亚洲成a人v欧美综合天堂下载 | 亚洲精品视频在线观看网站| 亚洲一区二区三区影院| 日本不卡不码高清免费观看| 国产一区二区三区日韩| 色视频欧美一区二区三区| 91精品国产免费久久综合| 国产婷婷一区二区| 亚洲精品综合在线| 久久91精品国产91久久小草| 成人国产精品免费观看| 91精品国产综合久久精品图片| 久久精品人人爽人人爽| 亚洲综合在线第一页| 国内偷窥港台综合视频在线播放| 91在线视频网址| 久久免费看少妇高潮| 一区二区三区成人| 国产91在线观看| 欧美精品色一区二区三区| 国产精品久久看| 理论电影国产精品| 欧美日韩国产综合久久| 国产精品不卡在线| 激情国产一区二区| 精品污污网站免费看| 亚洲日本va在线观看| 国产一区在线观看视频| 欧美日韩电影在线| 亚洲欧洲精品一区二区三区不卡 | 亚洲国产成人av好男人在线观看| 国精产品一区一区三区mba视频 | 久久国产精品99久久久久久老狼| 94-欧美-setu| 国产亚洲va综合人人澡精品| 蜜桃精品在线观看| 欧美午夜视频网站| 中文字幕欧美一区| 丰满岳乱妇一区二区三区| 欧美一区欧美二区| 水野朝阳av一区二区三区| 91在线视频播放| 国产女主播一区| 国产成人日日夜夜| 久久久亚洲午夜电影| 青青草国产精品97视觉盛宴| 欧美伊人久久久久久午夜久久久久| 亚洲国产高清不卡| 国产成人综合网站| 久久先锋影音av鲁色资源 | 免费高清成人在线| 欧美二区三区的天堂| 亚洲成人免费观看| 制服视频三区第一页精品| 香蕉久久一区二区不卡无毒影院| 色菇凉天天综合网| 一区二区成人在线| 欧美在线看片a免费观看| 亚洲乱码国产乱码精品精98午夜| av在线不卡免费看| 亚洲精品美腿丝袜| 91国在线观看| 一区二区三区蜜桃网| 91黄色免费版| 午夜不卡av在线| 欧美一区二区久久| 久草中文综合在线| 国产香蕉久久精品综合网| 国产成人精品一区二区三区网站观看| 久久影院电视剧免费观看| 国产中文字幕一区| 国产精品不卡视频| 欧美性视频一区二区三区| 日韩电影在线免费看| 日韩三级免费观看| 国产乱色国产精品免费视频| 国产欧美一区二区精品秋霞影院| 成人午夜av在线| 亚洲综合自拍偷拍| 欧美一卡在线观看| 国产精品亚洲视频| 亚洲欧美aⅴ...| 欧美精品777| 国产精品一区不卡| 一区二区在线观看视频| 欧美日韩和欧美的一区二区| 久久国产精品72免费观看| 国产婷婷一区二区| 欧美日韩一区二区在线视频| 麻豆国产精品官网| 日韩理论片网站| 日韩精品在线看片z| 成人黄色大片在线观看|