Java系统类System相关介绍

对于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));

    }
}

执行结果如下图所示:

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值