如何覆盖 Map 中的 toString ...?
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);
}
}
屏幕上的输出是:
...
但我想做 :
...
我的教授说“你必须覆盖 Class Map 中的 toString”
但是 Map 是接口那么如何覆盖 Map 中的 tostring ..?
而且我不能修改public class A。
如果有什么想法可以做出我想要的结果,请告诉我:))
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()
实现如下。您可以操纵此代码以获得所需的输出。
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,而不是直接使用迭代器。
这是最简单的方法:
TreeMap<String, Double> map = new TreeMap<String, Double>(){
@Override
public String toString() {
return "override here";
}
};
这里的其他答案省略了覆盖 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();
}
现在,您唯一需要决定的是要使用这种覆盖的 toString
方法的可重用 class 还是仅供一次性使用。
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();
}
};
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);
}
}
屏幕上的输出是:
... 但我想做 :
...
我的教授说“你必须覆盖 Class Map 中的 toString” 但是 Map 是接口那么如何覆盖 Map 中的 tostring ..? 而且我不能修改public class A。 如果有什么想法可以做出我想要的结果,请告诉我:))
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()
实现如下。您可以操纵此代码以获得所需的输出。
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,而不是直接使用迭代器。
这是最简单的方法:
TreeMap<String, Double> map = new TreeMap<String, Double>(){
@Override
public String toString() {
return "override here";
}
};
这里的其他答案省略了覆盖 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();
}
现在,您唯一需要决定的是要使用这种覆盖的 toString
方法的可重用 class 还是仅供一次性使用。
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();
}
};