对于System类而言,跟当前Java所运行的平台有关,诸如:Windows、Mac或Linux之类。通过System类我们可以进行许多操作。
- 获取所有的环境变量或某个环境变量
通过System类getEnv()和getEnv(String name)可以分别获取所有的环境变量或某个指定的环境变量,示例代码如下所示:
public class SystemTest {
public static void main(String[] args) {
// 获取所有的环境变量
Map<String, String> envMap = System.getenv();
envMap.keySet().forEach(key -> {
System.out.println(key);
});
// 获取某个指定的环境变量
String envVariable = System.getenv("JAVA_HOME");
System.out.println("JAVA_HOME:" + envVariable);
}
}
执行结果如下图所示:
- 获取所有系统属性值或某个属性值
通过System类的getProperties()和 getProperty(String key)可以获取所有的系统属性值或某个属性值。示例代码如下所示:
public class SystemTest {
public static void main(String[] args) {
// 获取所有的系统属性值
Properties properties = System.getProperties();
properties.forEach((k, v) -> {
System.out.println(k + ":" + v);
});
// 获取某个指定的系统属性值
String osName = System.getProperty("os.name");
System.out.println("os.name:" + osName);
// 获取某个指定的系统属性值,若存在返回指定的系统属性值,若不存在,返回指定的值
String defaultName = System.getProperty("os", "Linux");
System.out.println(defaultName);
}
}
执行结果如下图所示:
- 打印日志
先通过System类的getLogger(String name)或getLogger(String name, ResourceBundle bundle)获取日志对象,然后进行日志打印。
首先需要说明的是,对于日志打印来说,分为以下几个级别:ALL、TRACE、DEBUG、INFO、WARNING、ERROR、OFF等。
日志的示例代码如下所示:
public class SystemTest {
public static void main(String[] args) {
System.Logger log = System.getLogger("myLogger");
log.log(System.Logger.Level.INFO, "测试日志");
}
}
执行结果如下图所示:
- 获取当前系统时间
可以通过System类的currentTimeMilis()或nanoTime()来获取系统时间。两者返回得都是距1970年1月1日经过的时间,只不过currentTimeMillis()的单位是毫秒,而nanoTime()的单位是纳秒。
示例代码如下所示:
public class SystemTest {
public static void main(String[] args) {
System.out.println("当前距时间原点经过:" + System.currentTimeMillis() + "ms");
System.out.println("当前距时间原点经过:" + System.nanoTime() + "ns");
}
}
执行结果如下图所示:
- 输入或输出
可以通过System类的in、out、err来进行输入或输出
示例代码如下所示:
public class SystemTest {
public static void main(String[] args) throws IOException {
// 使用System.out进行输出
System.out.println("hello world");
// 使用System.in读取键盘输入
Scanner scan = new Scanner(System.in);
scan.useDelimiter("\\b");
if (scan.hasNext()) {
System.out.println(scan.next());
}
// 使用System.err来输出
System.err.println("测试错误");
}
}
执行结果如下图所示:
- 获取对象的未重写的hashCode值,也就是根据对象的真实地址计算得出的hashcode值。
通过System类的identityHashCode(Object x)来获取。
示例代码如下所示:
public class SystemTest {
public static void main(String[] args) throws IOException {
/*
str1和str2是两个不同的对象,由于String重写了hashcode方法,因此当两个字符串字符序列相同时,
其计算得出的hashCode值也相同。但是System.identityHashCode却不一样,它是根据对象的地址进行计算的,
因此可以用判断两个对象是否为同一个对象。
*/
String str1 = new String("hello world");
String str2 = new String("hello world");
System.out.println(str1.hashCode() + "----" + str2.hashCode());
System.out.println(System.identityHashCode(str1) + "----" + System.identityHashCode(str2));
System.out.println("=======================================");
String str3 = "Java";
String str4 = "Java";
System.out.println(str3.hashCode() + "----" + str4.hashCode());
System.out.println(System.identityHashCode(str3) + "----" + System.identityHashCode(str4));
}
}
执行结果如下图所示: