Java中如果两个字符串s1和s2的内容相同,那么它们用==操作符比较,也可能返回false,这是因为Java中变量未引用传递,两个相同内容的字符串可能隶属于不同的字符串对象,所以为了稳妥起见,比较字符串时要使用equals方法来比较两个字符串的内容:
import java.util.Iterator;
import java.util.Map.Entry;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.conf.Configured;
import org.apache.hadoop.util.Tool;
import org.apache.hadoop.util.ToolRunner;
public class GetKey extends Configured implements Tool {
/**
* @param args
* @throws Exception
*/
static{
Configuration.addDefaultResource("hdfs-default.xml");
Configuration.addDefaultResource("hdfs-site.xml");
Configuration.addDefaultResource("mapred-default.xml");
Configuration.addDefaultResource("mapred-site.xml");
}
public static void main(String[] args) throws Exception {
// TODO Auto-generated method stub
int exitCode = ToolRunner.run(new GetKey(), args);
System.exit(exitCode);
}
@Override
public int run(String[] args) throws Exception {
// TODO Auto-generated method stub
String key = args[0];
Configuration conf = getConf();
if(key.equals("all")){ // 如果是==操作符的话,就会是一个BUG
System.out.println("you entered all !!");
for(Entry<String, String> entry : conf){
System.out.printf("%s=%s\n", entry.getKey(), entry.getValue());
}
}else{
System.out.println("it is not all !!");
System.out.printf("%s=%s\n", key, conf.get(key));
}
return 0;
}
}