[英]How to override toString in Map…?
package A;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.Map;
import java.util.TreeMap;
class MapManager {
static Map<String, Double> readData(String str){
Map<String, Double> map = new TreeMap<String, Double>();
try {
BufferedReader br = new BufferedReader(new FileReader(str));
while(true) {
String line = br.readLine();
if(line == null) break;
String []sr = line.split(" ");
double num = Double.parseDouble(sr[1]);
map.put(sr[0], num);
}
br.close();
}catch(IOException e) {
e.printStackTrace();
}
return map;
}
}
public class A {
public static void main(String args[]) {
Map<String, Double> map = MapManager.readData("input.txt");
if(map == null) {
System.out.println("Input file not found.");
return;
}
System.out.println(map);
}
}
屏幕上的 output 是:
...但我想做:
...
我的教授說“你必須在 Class 地圖中覆蓋 toString”但是 Map 是接口那么如何覆蓋 Map 中的 tostring ..? 而且我不能修改 public class A。如果有一些想法可以產生我想要的結果,請告訴我:))
這是最簡單的方法:
TreeMap<String, Double> map = new TreeMap<String, Double>(){
@Override
public String toString() {
return "override here";
}
};
Map 是參考,而在您的情況下 Object 是TreeMap
。 所以你需要覆蓋TreeMap<K, V>
class 中的toString()
。 與當前代碼相比,使用CustomTreeMap
而不是TreeMap
。 如下:
public class CustomTreeMap<K, V> extends TreeMap<K, V> {
private static final long serialVersionUID = 1L;
public String toString() {
// Your implementation goes here
}
}
在AbstractMap
class 中,默認的toString()
實現如下。 您可以操作此代碼以獲得所需的 output。
public String toString() {
Iterator<Entry<K,V>> i = entrySet().iterator();
if (! i.hasNext())
return "{}";
StringBuilder sb = new StringBuilder();
sb.append('{');
for (;;) {
Entry<K,V> e = i.next();
K key = e.getKey();
V value = e.getValue();
sb.append(key == this ? "(this Map)" : key);
sb.append('=');
sb.append(value == this ? "(this Map)" : value);
if (! i.hasNext())
return sb.append('}').toString();
sb.append(',').append(' ');
}
}
在您的情況下,您還可以使用 Java 8,而不是直接使用迭代器。
這里的其他答案省略了重寫的toString
方法的實現。 他們來了:
// Java 8 way
@Override
public String toString() {
return entrySet().stream()
.map(e -> e.getKey() + " " + e.getValue())
.collect(Collectors.joining());
}
// general way (preferable for this use case IMHO)
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
forEach((key, value) -> sb.append(key).append(" ").append(value));
return sb.toString();
}
現在,您唯一需要決定是要擁有一個可重用的 class 並使用這種重寫的toString
方法還是只使用一次。
Class方式
public class PrintableTreeMap<K, V> extends TreeMap<K, V> {
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
forEach((key, value) -> sb.append(key).append(" ").append(value));
return sb.toString();
}
}
Map<String, Double> map = new PrintableTreeMap<>();
一次性使用方式
Map<String, Double> map = new TreeMap<>() {
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
forEach((key, value) -> sb.append(key).append(" ").append(value));
return sb.toString();
}
};
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.