百度查不到,谷歌查不到,具体的initialize方法自己能写出来又担心写出来的不对,于是上github找了作者的源码,不错,几乎是完全相同。
import org.apache.hadoop.io.IOUtils;
import java.io.*;
import java.util.HashMap;
import java.util.Map;
public class NcdcStationMetadata {
private Map<String, String> stationIdAndName = new HashMap<String, String>();//创建一个map来装键值对
//按行读取文件,并将其气象站的id和名字装到map中,
//其中的NcdcStationMetadataParser类在这里
//https://blog.csdn.net/wzyhahaha/article/details/86717888
public void initialize(File file) throws IOException {
BufferedReader in = null;
try {
in = new BufferedReader(new InputStreamReader(new FileInputStream(file)));
NcdcStationMetadataParser parser = new NcdcStationMetadataParser();
String line;
while ((line = in.readLine()) != null) {
if (parser.parse(line)) {
stationIdAndName.put(parser.getStationId(), parser.getStationName());
}
}
} finally {
IOUtils.closeStream(in);
}
}
public String getStationName(String stationId) {
String stationName = stationIdAndName.get(stationId);
if (stationName == null || stationName.equal("")) {
return "not available";
}
return stationName;
}
}
其实没给出来且知道查也是白查的情况下自己猜作者的意图然后写出来差不多也是蛮有趣的一件事。
书的作者的github地址是https://github.com/tomwhite/hadoop-book/
大数据扯淡交流群:808565587,没有培训机构,没有杂七杂八,纯粹的交流群,只有爱与同行交流的你。欢迎大家。