zoukankan      html  css  js  c++  java
  • 20180914-Java实例03


    Java 实例 – 字符串性能比较测试


    以下实例演示了通过两种方式创建字符串,并测试其性能:


    // StringComparePerformance.java 文件

    public class StringComparePerformance{
    public static void main(String[] args){
    long startTime = System.currentTimeMillis();
    for(int i=0;i<50000;i++){
    String s1 = "hello";
    String s2 = "hello";
    }

    long endTime = System.currentTimeMillis();

    System.out.prinln("通过String 关键字创建字符串"
    +":" +(endTime - startTime) + "毫秒");

    long startTime1 = System.currentTimeMillis();
    for(int i=0;i<50000;i++){
    String s3 = new String("hello");
    String s4 = new String("hello");
    }

    long endTimel = System.currentTimeMillis();
    System.out.println("通过 String 对象创建字符串"
    +":" +(endTimel - startTimel) + "毫秒"
    );

    }

    }

    以上代码实例输出结果为:

    通过 String 关键词创建字符串 : 6 毫秒
    通过 String 对象创建字符串 : 14 毫秒


    Java 实例 – 字符串优化

    以下实例演示了通过 String.intern() 方法来优化字符串:


    // StringOptimization.java 文件


    public class StringOptimization{
    public static void main(String[] args){
    String variables[] = new String[50000];
    for(int i=0;i<50000;i++){
    variables[i] = "s" + i;
    }
    long startTime() = System.currentTimeMillis();

    for(int i=0;i<50000;i++){
    variables[i] = "hello";
    }

    long endTime() = System.currentTimeMillis();
    System.out.println("Creation time"
    + " of String literals : "+ (endTime0 - startTime0)
    + " ms")

    long startTimel = System.crrentTimeMillis();
    for(int i=0;i<50000;i++){
    variables[i] = new String("hello");
    }

    long endTimel = System.currentTimeMillis();
    System.out.println("Creation time of"
    + " String objects with 'new' key word : "
    + (endTime1 - startTime1)
    + " ms");

    long startTime2 = System.currentTimeMillis();
    for(int i=0;i<50000;i++){
    variables[i] = new String("hello");
    variables[i] = variables[i].intern();
    }

    long endTime2 = System.currentTimeMillis();
    System.out.println("Creation time of"
    + " String objects with intern(): "
    + (endTime2 - startTime2)
    + " ms");
    }
    }

    以上代码实例输出结果为:


    Creation time of String literals : 0 ms
    Creation time of String objects with 'new' key word : 31 ms
    Creation time of String objects with intern(): 16 ms

  • 相关阅读:
    小甲鱼系列→第一章.基础知识
    FusionCharts-堆栈图、xml格式、刷新数据、添加事件link、传参
    FireBug提示:本页面不包含 JavaScript,明明是包含js的。
    Angular-Chart.js 初接触;;;
    错误 Metadata file 'C:CommoninDebugCommon.dll' could not be found
    UML--PowerDesigner使用小结
    java8入门 错误:找不到或者无法加载主类
    “基础提供程序在Open上失败”
    设计模式--目录开篇
    020医疗项目-模块二:药品目录的导入导出-介绍药品表
  • 原文地址:https://www.cnblogs.com/Alanf/p/9648466.html
Copyright © 2011-2022 走看看