think in 자바 충전 용기(사례 약술)

3670 단어 자바inthink
think in 자바 용기 깊이 연구-충전 용기 라 는 장 을 배 울 때 처음에 본 예 는 매우 혼 란 스 러 웠 고 나중에 자세히 연 구 했 습 니 다.지금 공유 하 겠 습 니 다.
 
think in 자바 에서 따 온 코드:
//: net/mindview/util/CountingMapData.java
// Unlimited-length Map containing sample data.
package net.mindview.util;

import java.util.*;
import java.util.Map.Entry;

public class CountingMapData extends AbstractMap<Integer, String> {
	private int size;
	private static String[] chars = "A B C D E F G H I J K L M N O P Q R S T U V W X Y Z"
			.split(" ");

	public CountingMapData(int size) {
		if (size < 0)
			this.size = 0;
		this.size = size;
	}

	private static class Entry implements Map.Entry<Integer, String> {
		int index;

		Entry(int index) {
			this.index = index;
		}

		public boolean equals(Object o) {
			return Integer.valueOf(index).equals(o);
		}

		public Integer getKey() {
			return index;
		}

		public String getValue() {
			return chars[index % chars.length]
					+ Integer.toString(index / chars.length);
		}

		public String setValue(String value) {
			throw new UnsupportedOperationException();
		}

		public int hashCode() {
			return Integer.valueOf(index).hashCode();
		}
	}

	public Set<Map.Entry<Integer, String>> entrySet() {
		// LinkedHashSet retains initialization order:
		Set<Map.Entry<Integer, String>> entries = new LinkedHashSet<Map.Entry<Integer, String>>();
 		for (int i = 0; i < size; i++)
			entries.add(new Entry(i));
		return entries;
	}

	public static void main(String[] args) {
		System.out.println(new CountingMapData(60));
	}
} /*
	 * Output: {0=A0, 1=B0, 2=C0, 3=D0, 4=E0, 5=F0, 6=G0, 7=H0, 8=I0, 9=J0,
	 * 10=K0, 11=L0, 12=M0, 13=N0, 14=O0, 15=P0, 16=Q0, 17=R0, 18=S0, 19=T0,
	 * 20=U0, 21=V0, 22=W0, 23=X0, 24=Y0, 25=Z0, 26=A1, 27=B1, 28=C1, 29=D1,
	 * 30=E1, 31=F1, 32=G1, 33=H1, 34=I1, 35=J1, 36=K1, 37=L1, 38=M1, 39=N1,
	 * 40=O1, 41=P1, 42=Q1, 43=R1, 44=S1, 45=T1, 46=U1, 47=V1, 48=W1, 49=X1,
	 * 50=Y1, 51=Z1, 52=A2, 53=B2, 54=C2, 55=D2, 56=E2, 57=F2, 58=G2, 59=H2}
	 */// :~

처음에 나 는 왜 이런 수치 가 이 저급한 문제 에 대해 출력 되 었 는 지 의 심 스 러 웠 고,어떤 방법 들 은 보기에 매우 많은 것 같 았 다.
나중에 야 이 를 계승 하 는 AbstractMap 류 에 toString()방법 이 있 는데 이 방법 을 통 해 출력 한 결과 입 니 다.
	public String toString() {
		StringBuffer buf = new StringBuffer();
		buf.append("{");

		Iterator i = entrySet().iterator();
		boolean hasNext = i.hasNext();
		while (hasNext) {
			Entry e = (Entry) (i.next());
			Object key = e.getKey();
			Object value = e.getValue();
			buf.append((key == this ? "(this Map)" : key) + "="
					+ (value == this ? "(this Map)" : value));

			hasNext = i.hasNext();
			if (hasNext)
				buf.append(", ");
		}

		buf.append("}");
		return buf.toString();
	}

toString 방법 에서 entry Set().iterator()를 볼 수 있 습 니 다.Entry e=(Entry)(i.next();두 단락 코드,
AbstractMap 클래스 에서 entry Set().추상 적 인 방법 입 니 다.
AbstractMap 클래스 에서 Entry 는 하나의 인터페이스 로 인터페이스 에서 getKey(),getValue(),setValue(Object value),equals(Object o),hashCode()라 는 몇 가지 방법 을 정의 합 니 다.
그래서 위의 예 에서 우 리 는 추상 적 인 인터페이스 와 추상 적 인 유형 을 실현 하 는 방법 이 필요 하 다.
 
이렇게 시 끄 러 운 코드 를 통 해 보기 만 해도 순조롭다 하하^ ^

좋은 웹페이지 즐겨찾기