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()라 는 몇 가지 방법 을 정의 합 니 다.
그래서 위의 예 에서 우 리 는 추상 적 인 인터페이스 와 추상 적 인 유형 을 실현 하 는 방법 이 필요 하 다.
이렇게 시 끄 러 운 코드 를 통 해 보기 만 해도 순조롭다 하하^ ^
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Is Eclipse IDE dying?In 2014 the Eclipse IDE is the leading development environment for Java with a market share of approximately 65%. but ac...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.