1. 被final修饰的类

public final class FinalClass {

	public void getJava() {
String str1 = "Java ";
String str2 = "final ";
for (int i = 0; i < 10000; i++) {
str1 += str2;
}
} public void getJava_Final() {
String str1 = "Java ";
String str2 = "final ";
for (int i = 0; i < 10000; i++) {
str1 += str2;
}
} }

2: 被final修饰的方法

public class FinalFunction {

	public void getJava() {
String str1 = "Java ";
String str2 = "final ";
for (int i = 0; i < 10000; i++) {
str1 += str2;
}
} public final void getJava_Final() {
String str1 = "Java ";
String str2 = "final ";
for (int i = 0; i < 10000; i++) {
str1 += str2;
}
}
}

3. 测试类:

public class TestFinal {

	@Test
public void test5() {
FinalClass finalClass = new FinalClass();
FinalFunction finalFunction = new FinalFunction();
long t1=0;
long t2=0;
long t3=0;
long t4=0;
long t5=0; long tim1 = 0;
long tim2 = 0;
long tim3 = 0;
long tim4 = 0;
long tim5 = 0;
for(int j=0; j<10;j++){
System.out.println("正常执行:========================");
long start = System.nanoTime();
String str1 = "Java ";
String str2 = "final ";
for (int i = 0; i < 10000; i++) {
str1 += str2;
} tim1 = (System.nanoTime() - start)/1000000;
System.out.println("正常的执行时间为:" + (tim1)
+ "毫秒时间");
t1 = t1 + tim1;
System.out.println("finalClass:=====================");
start = System.nanoTime();
finalClass.getJava();
tim2 = (System.nanoTime() - start)/1000000;
System.out.println("调用不带final修饰的方法执行时间为:"
+ tim2 + "毫秒时间");
t2 = t2 + tim2;
start = System.nanoTime();
finalClass.getJava_Final();
tim3 = (System.nanoTime() - start)/1000000;
System.out.println("调用final修饰的方法执行时间为:"
+ tim3 + "毫秒时间");
t3 = t3 + tim3;
System.out.println("finalFunction:=====================");
start = System.nanoTime();
finalFunction.getJava();
tim4 = (System.nanoTime() - start)/1000000;
System.out.println("调用不带final修饰的方法执行时间为:"
+ tim4 + "毫秒时间");
t4 = t4 + tim4;
start = System.nanoTime();
finalFunction.getJava_Final();
tim5 = (System.nanoTime() - start)/1000000;
System.out.println("调用final修饰的方法执行时间为:"
+ tim5 + "毫秒时间");
t5 = t5+ tim5;
}
System.out.println("正常执行:========================");
System.out.println("正常的执行10次平均时间为:" + t1/10 + "毫秒时间");
System.out.println("finalClass:=====================");
System.out.println("调用不带final修饰的方法执行10次平均时间为:"+ t2/10 + "毫秒时间");
System.out.println("调用final修饰的方法执行10次平均时间为:" + t3/10 + "毫秒时间");
System.out.println("finalFunction:=====================");
System.out.println("调用不带final修饰的方法执行10次平均时间为:" + t4/10 + "毫秒时间");
System.out.println("调用final修饰的方法执行10次平均时间为:"+ t5/10 + "毫秒时间");
}
}

4. 结果

正常执行:========================
正常的执行时间为:1573毫秒时间
finalClass:=====================
调用不带final修饰的方法执行时间为:1410毫秒时间
调用final修饰的方法执行时间为:1402毫秒时间
finalFunction:=====================
调用不带final修饰的方法执行时间为:1285毫秒时间
调用final修饰的方法执行时间为:1339毫秒时间
正常执行:========================
正常的执行时间为:1523毫秒时间
finalClass:=====================
调用不带final修饰的方法执行时间为:1444毫秒时间
调用final修饰的方法执行时间为:1457毫秒时间
finalFunction:=====================
调用不带final修饰的方法执行时间为:1446毫秒时间
调用final修饰的方法执行时间为:1480毫秒时间
正常执行:========================
正常的执行时间为:1355毫秒时间
finalClass:=====================
调用不带final修饰的方法执行时间为:1321毫秒时间
调用final修饰的方法执行时间为:1330毫秒时间
finalFunction:=====================
调用不带final修饰的方法执行时间为:1435毫秒时间
调用final修饰的方法执行时间为:1328毫秒时间
正常执行:========================
正常的执行时间为:1277毫秒时间
finalClass:=====================
调用不带final修饰的方法执行时间为:1350毫秒时间
调用final修饰的方法执行时间为:1390毫秒时间
finalFunction:=====================
调用不带final修饰的方法执行时间为:1323毫秒时间
调用final修饰的方法执行时间为:1271毫秒时间
正常执行:========================
正常的执行时间为:1406毫秒时间
finalClass:=====================
调用不带final修饰的方法执行时间为:1352毫秒时间
调用final修饰的方法执行时间为:1336毫秒时间
finalFunction:=====================
调用不带final修饰的方法执行时间为:1267毫秒时间
调用final修饰的方法执行时间为:1436毫秒时间
正常执行:========================
正常的执行时间为:1322毫秒时间
finalClass:=====================
调用不带final修饰的方法执行时间为:1308毫秒时间
调用final修饰的方法执行时间为:1270毫秒时间
finalFunction:=====================
调用不带final修饰的方法执行时间为:1431毫秒时间
调用final修饰的方法执行时间为:1315毫秒时间
正常执行:========================
正常的执行时间为:1273毫秒时间
finalClass:=====================
调用不带final修饰的方法执行时间为:1300毫秒时间
调用final修饰的方法执行时间为:1368毫秒时间
finalFunction:=====================
调用不带final修饰的方法执行时间为:1090毫秒时间
调用final修饰的方法执行时间为:1099毫秒时间
正常执行:========================
正常的执行时间为:1081毫秒时间
finalClass:=====================
调用不带final修饰的方法执行时间为:1133毫秒时间
调用final修饰的方法执行时间为:1079毫秒时间
finalFunction:=====================
调用不带final修饰的方法执行时间为:1089毫秒时间
调用final修饰的方法执行时间为:1068毫秒时间
正常执行:========================
正常的执行时间为:1111毫秒时间
finalClass:=====================
调用不带final修饰的方法执行时间为:1098毫秒时间
调用final修饰的方法执行时间为:1086毫秒时间
finalFunction:=====================
调用不带final修饰的方法执行时间为:1113毫秒时间
调用final修饰的方法执行时间为:1046毫秒时间
正常执行:========================
正常的执行时间为:1144毫秒时间
finalClass:=====================
调用不带final修饰的方法执行时间为:1057毫秒时间
调用final修饰的方法执行时间为:1114毫秒时间
finalFunction:=====================
调用不带final修饰的方法执行时间为:1094毫秒时间
调用final修饰的方法执行时间为:1064毫秒时间
正常执行:========================
正常的执行10次平均时间为:1306毫秒时间
finalClass:=====================
调用不带final修饰的方法执行10次平均时间为:1277毫秒时间
调用final修饰的方法执行10次平均时间为:1283毫秒时间
finalFunction:=====================
调用不带final修饰的方法执行10次平均时间为:1257毫秒时间
调用final修饰的方法执行10次平均时间为:1244毫秒时间

5. 总结

基本上带final的效率比不加稍微快点,但也不是很明显。同样这个测试跑了多次,有时带final的效率比不带final的低,个人觉得final在效率的提升上不是很明显。

final的用途主要是它修饰在类,方法,变量上体现的一些特性上。

final效率分析的更多相关文章

  1. in和exists的区别与SQL执行效率分析

    可总结为:当子查询表比主查询表大时,用Exists:当子查询表比主查询表小时,用in SQL中in可以分为三类: 1.形如select * from t1 where f1 in ('a','b'), ...

  2. mssql分页原理及效率分析

    下面是常用的分页,及其分页效率分析. 1.分页方案一:(利用Not In和SELECT TOP分页) 语句形式: SELECT TOP 10 * FROM TestTable WHERE (ID NO ...

  3. 团队工作效率分析工具gitstats

    如果你是团队领导,关心团队的开发效率和工作激情:如果你是开源软件开发者,维护者某个repo:又或者,你关心某个开源软件的开发进度,那么你可以试一试gitstats. gitstats 是一个git仓库 ...

  4. 声笔飞码GB2312单字效率分析

    -----------------------声笔飞码强字方式单字效率分析-------------------------- 2   keys: 567       items, 381900209 ...

  5. Flash和js交互的效率分析

    Flash和js交互的效率分析   AS代码: var time:int = getTimer(); for (var i:int = 0; i < 50000; i++) { External ...

  6. [GIt] 团队工作效率分析工具gitstats

    copy : http://www.cnblogs.com/ToDoToTry/p/4311637.html 如果你是团队领导,关心团队的开发效率和工作激情:如果你是开源软件开发者,维护者某个repo ...

  7. 回溯和DFS效率分析

    回溯和DFS效率分析 一.心得 多组数据记得初始化 两组样例,找圆点点的个数 6 9 ....#. .....# ...... ...... ...... ...... ...... #@...# . ...

  8. Project Euler 第一题效率分析

    Project Euler: 欧拉计划是一系列挑战数学或者计算机编程问题,解决这些问题需要的不仅仅是数学功底. 启动这一项目的目的在于,为乐于探索的人提供一个钻研其他领域并且学习新知识的平台,将这一平 ...

  9. group by与distinct效率分析及优化措施

    如何使用group by进行去重 因为mysql的distinct在结果集中,全部不同,才可以去重.所以,当我们进行去重处理的时候,需要单独对某列进行去重,可以使用group by子句进行分组去重se ...

随机推荐

  1. Boost.Build 简明教程

    Boost.Build 简明教程 目录1. 介绍2. 构建过程3. 基本任务4. 项目管理5. 最佳实践6. 规则参考7. 特征参考 介绍 编译器和平台无关编译系统Boost.Build是一个高级编译 ...

  2. C#winform程序安装时自动卸载新版本覆盖旧版本

    vs2005为winform程序做的安装包.在以有程序旧版本的机子上用新版本的安装包安装软件时提示  “以经安装该产品的另一个版本.无法继续安装此版本........” 在安装部署项目中设“Remov ...

  3. 黑马程序员-------.net基础知识二

    变量 变量代表着一块内存空间,我们可以通过变量名称想内存存/取数据,有变量就不需要我们记忆复杂的内存地址. 向内存中申请一块内存空间的语法:   数据类型 变量名; 变量类型 变量类型 存储位置 自动 ...

  4. 【资料目录收藏】.NET开发必看资料53个 经典源码77个

    简单描述:为大家整理了下载中心.net资料,都是比较热的,好评率比较高的,做了一个可收藏的下载目录,希望大家喜欢~ 基于.net构架的留言板项目大全源码 http://down.51cto.com/z ...

  5. 记录一次配置unix网络编程环境的过程和遇到的问题

    记录一次搭建unix网络编程环境过程中遇到的问题和总结 计算机环境虚拟机 linuxmint-18-xfce-64bit 1.打开unix网络编程.iso 把目录下的文件复制到某一目录,修改权限,可命 ...

  6. python面向对象高级编程

    正常情况下,当我们定义了一个class,创建了一个class的实例后,我们可以给该实例绑定任何属性和方法,这就是动态语言的灵活性.先定义class: >>> class Studen ...

  7. bzoj 3242: [Noi2013]快餐店 章鱼图

    3242: [Noi2013]快餐店 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 266  Solved: 140[Submit][Status] ...

  8. 【原创】Matlab中plot函数全功能解析

    [原创]Matlab中plot函数全功能解析 该帖由Matlab技术论(http://www.matlabsky.com)坛原创,更多精彩内容参见http://www.matlabsky.com 功能 ...

  9. 在openshift上自定义node.js的版本

    https://github.com/ramr/nodejs-custom-version-openshift 由于是线上服务器,一步一步来: 先把上面的工程拉下来,覆盖到初始化的工程里,提交,让服务 ...

  10. Ubuntu 14.04安装Chromium浏览器并添加Flash插件Pepper Flas

    转自Ubuntu 14.04安装Chromium浏览器并添加Flash插件Pepper Flash Player Chromium谷歌的开源浏览器将不再支持Netscape浏览器插件API,Adobe ...