Java 如何覆盖映射中的toString。。。?

Java 如何覆盖映射中的toString。。。?,java,overriding,tostring,Java,Overriding,Tostring,屏幕上的输出为: 。。。 但我想说: 我的教授说你必须在课堂地图上覆盖toString 但映射是接口,那么如何覆盖映射中的tostring。。? 我不能修改公共的A类。 如果有什么想法可以产生我想要的结果,请让我知道:Map是reference,而在您的例子中,对象是TreeMap。所以您需要在TreeMap类中重写toString。与当前代码相比,使用CustomTreeMap而不是TreeMap。详情如下: package A; import java.io.BufferedReader

屏幕上的输出为:

。。。 但我想说:

我的教授说你必须在课堂地图上覆盖toString 但映射是接口,那么如何覆盖映射中的tostring。。? 我不能修改公共的A类。
如果有什么想法可以产生我想要的结果,请让我知道:

Map是reference,而在您的例子中,对象是TreeMap。所以您需要在TreeMap类中重写toString。与当前代码相比,使用CustomTreeMap而不是TreeMap。详情如下:

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);
    }
}

在本例中,您还可以使用Java 8,而不是直接使用迭代器。

Map是reference,而在本例中,对象是TreeMap。所以您需要在TreeMap类中重写toString。与当前代码相比,使用CustomTreeMap而不是TreeMap。详情如下:

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);
    }
}

在本例中,您还可以使用Java 8,而不是直接使用迭代器。

这是最简单的方法:

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(' ');
        }
    }

这是最简单的方法:

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(' ');
        }
    }

这里的其他答案省略了重写的toString方法的实现。这是:

TreeMap<String, Double> map = new TreeMap<String, Double>(){
    @Override
    public String toString() {
        return "override here";
    }
};
现在,您需要决定的唯一一件事是使用这种重写的toString方法创建一个可重用类,还是一次性使用

阶级道路

一次性使用方式


这里的其他答案省略了重写的toString方法的实现。这是:

TreeMap<String, Double> map = new TreeMap<String, Double>(){
    @Override
    public String toString() {
        return "override here";
    }
};
现在,您需要决定的唯一一件事是使用这种重写的toString方法创建一个可重用类,还是一次性使用

阶级道路

一次性使用方式


请注意,虽然这在一次性代码(如家庭作业)中很有用,但在生产代码中可能会很麻烦。尽管如此,一个称职的工程师可以在出现问题时将其重构成更易于维护的东西。请注意,虽然这在一次性代码(如家庭作业)中很有用,但在生产代码中可能会很麻烦。尽管如此,一位称职的工程师仍然可以利用这一点,并在出现问题时重构成更易于维护的东西。非常感谢你我知道如何覆盖toString感谢你uu:非常感谢你我知道如何覆盖toString感谢你uu:
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();
    }
};