/*
* Copyright [2013-2014] PayPal Software Foundation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package ml.shifu.guagua.util;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintStream;
import java.lang.management.ManagementFactory;
import java.nio.charset.Charset;
import java.util.Date;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Helper to run jmap and print the output. Copy from Apache Giraph.
*/
public class JMap {
private static final Logger LOG = LoggerFactory.getLogger(JMap.class);
/** The command to run */
public static final String CMD = "jmap ";
/** Arguments to pass in to command */
public static final String ARGS = " -histo ";
/** Do not construct */
protected JMap() {
}
/**
* Get the process ID of the current running process
*
* @return Integer process ID
*/
public static int getProcessId() {
String processId = ManagementFactory.getRuntimeMXBean().getName();
if(processId.contains("@")) {
processId = processId.substring(0, processId.indexOf("@"));
}
return Integer.parseInt(processId);
}
/**
* Run jmap, print numLines of output from it to stderr.
*
* @param numLines
* Number of lines to print
*/
public static void heapHistogramDump(int numLines) {
heapHistogramDump(numLines, System.err);
}
/**
* Run jmap, print numLines of output from it to stream passed in.
*
* @param numLines
* Number of lines to print
* @param printStream
* Stream to print to
*/
public static void heapHistogramDump(int numLines, PrintStream printStream) {
BufferedReader in = null;
try {
Process p = Runtime.getRuntime().exec(CMD + ARGS + getProcessId());
in = new BufferedReader(new InputStreamReader(p.getInputStream(), Charset.defaultCharset()));
printStream.println("JMap histo dump at " + new Date());
String line = in.readLine();
for(int i = 0; i < numLines && line != null; ++i) {
printStream.println("--\t" + line);
line = in.readLine();
}
} catch (IOException e) {
LOG.error("IOException in dump heap", e);
} finally {
if(in != null) {
try {
in.close();
} catch (IOException e) {
LOG.error("Error in closing input stream", e);
}
}
}
}
public static void main(String[] args) {
Map<String, String> map = new HashMap<String, String>();
map.put(null, "123");
System.out.println(map.get(null));
map.put("123", null);
System.out.println(map.get("123"));
System.out.println(map.containsKey("123"));
System.out.println("-----------------------------------------");
map = new LinkedHashMap<String, String>();
map.put(null, "123");
System.out.println(map.get(null));
map.put("123", null);
System.out.println(map.get("123"));
System.out.println(map.containsKey("123"));
}
}