对于System类而言,跟当前Java所运行的平台有关,诸如:Windows、Mac或Linux之类。通过System类我们可以进行许多操作。
- 获取所有的环境变量或某个环境变量
通过System类getEnv()和getEnv(String name)可以分别获取所有的环境变量或某个指定的环境变量,示例代码如下所示:
public class SystemTest { public static void main(String[] args) { // 获取所有的环境变量 Map envMap = System.getenv(); envMap.keySet().forEach(key -> { System.out.println(key); }); // 获取某个指定的环境变量 String envVariable = System.getenv("JAVA_HOME"); System.out.println("JAVA_HOME:" + envVariable); }}
执行结果如下图所示:
![ee2f3c43fa6baea5a21442b6e44f518c.png](https://i-blog.csdnimg.cn/blog_migrate/2a81ce780a64603d18b8b8a67be7f28e.jpeg)
- 获取所有系统属性值或某个属性值
通过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); }}
执行结果如下图所示:
![d35cd4394b5932677f2ea357b224205b.png](https://i-blog.csdnimg.cn/blog_migrate/e198960688d6769e1cc9dfa66bd53992.jpeg)
- 打印日志
先通过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, "测试日志"); }}
执行结果如下图所示:
![f188e9efc59b20eef4ed91530d2ee75b.png](https://i-blog.csdnimg.cn/blog_migrate/3ad65f07ec32c1ce5c85ac63b29a8cc1.jpeg)
- 获取当前系统时间
可以通过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"); }}
执行结果如下图所示:
![fd16e3d57e45b020099e4284fe0e6a01.png](https://i-blog.csdnimg.cn/blog_migrate/f32aadf46ffd466734e3c9ddb740cd4f.jpeg)
- 输入或输出
可以通过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("测试错误"); }}
执行结果如下图所示:
![cb69bcca629ac7142f6053b23db59749.png](https://i-blog.csdnimg.cn/blog_migrate/50046eecdd58e53c47a14f36f26ae860.jpeg)
- 获取对象的未重写的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)); }}
执行结果如下图所示:
![cf026642c8ddac26f575c895c294990a.png](https://i-blog.csdnimg.cn/blog_migrate/5f2919c943fb510d44e6ba7a780610ce.jpeg)