1.下载地址:http://www.ej-technologies.com/download/jprofiler/files

2.使用过程

1.点击此图的new Session

2.点击左边application settings,右边要点击

3.点击的Source Path ,点击+号的图标,点击add directory

4.点击你工程的文件到bin

5.左边是程序还没有运行的,右边是查询运行的

6.点击你的项目双击俩下,或者点open,之后点击OK就好了

7.点击CPU view,点击Call Tree,之后点击界面的一个按钮

8.这是一张CUP的图,图中显示个个方法的使用占的CPU

9.从中发现最大块的函数对其进行分解优化,以及减少代码块的重复率。

下面举个例子:查重模块中调用到了diaoyong的方法,diaoyong方法调用到addcopy的方法,这样就把200行左右的代码分成了7个方法,每个方法的代码不多于50行。

1.最大函数块

import java.util.ArrayList;
import java.util.List; /**
* 查重的总函数
* @author admin
*
*/
public class CongFu2 {
/**
* 查重
*/
public boolean chacong(List<String> timus,String yunsuan){
boolean flat=false;//获取是否重复的标记
boolean zhuzhifu=false;//在flat为true的时候,终止本次循环的标志
for(String s:timus){
if(!zhuzhifu){
List<String> str1=new ArrayList<String>();//获取已经存入在list中的题目
List<String> str2=new ArrayList<String>();//获取这次尝试的题目
for(int i=0;i<s.length();i++){
str1.add(s.charAt(i)+"");
str2.add(yunsuan.charAt(i)+"");
}
flat=false;
for(int i=0;i<str1.size();i++){
if(!str1.contains(str2.get(i))
||!str2.contains(str1.get(i))){
break;
}else{
if(i==str1.size()-1){
flat=true;
}
}
}
if(flat){
flat=false;
switch (str2.get(1)) {
case "+":
flat=false;
switch (str2.get(3)) {
case "+":
flat=true;
break;
case "-":
if(str2.get(4).equals(str1.get(4))
&&str2.get(3).equals(str1.get(3))
||str2.get(3).equals(str1.get(1))
&&str2.get(4).equals(str1.get(2))){
flat=true;
}
break;
case "/":
if(str2.get(2).equals(str1.get(2))
&&str2.get(3).equals(str1.get(3))
&&str2.get(4).equals(str1.get(4))
||str2.get(2).equals(str1.get(0))
&&str2.get(3).equals(str1.get(1))
&&str2.get(4).equals(str1.get(2))){
flat=true;
}
break;
default:
if(str2.get(0).equals(str1.get(0))
&&str2.get(1).equals(str1.get(1))
||str2.get(0).equals(str1.get(4))
&&str2.get(1).equals(str1.get(3))){
flat=true;
}
break;
}
break;
case "-":
flat=false;
switch (str2.get(3)) {
case "+":
if(str2.get(2).equals(str1.get(2))
&&str2.get(1).equals(str1.get(1))
||str2.get(1).equals(str1.get(3))
&&str2.get(2).equals(str1.get(4))){
flat=true;
}
break;
case "-":
if(str2.get(0).equals(str1.get(0))){
flat=true;
}
break;
case "/":
if(str2.get(0).equals(str1.get(0))
&&str2.get(2).equals(str1.get(2))
&&str2.get(1).equals(str1.get(1))){
flat=true;
}
break;
default:
if(str2.get(0).equals(str1.get(0))
&&str2.get(1).equals(str1.get(1))
||str2.get(0).equals(str1.get(4))
&&str2.get(1).equals(str1.get(3))){
flat=true;
}
break;
}
break;
case "/":
flat=false;
switch (str2.get(3)) {
case "*":
flat=true;
break;
case "/":
if(str2.get(4).equals(str1.get(4))
&&str2.get(3).equals(str1.get(3))
||str2.get(4).equals(str1.get(2))
&&str2.get(3).equals(str1.get(1))){
flat=true;
}
break;
case "+":
if(str2.get(4).equals(str1.get(4))
&&str2.get(3).equals(str1.get(3))
||str2.get(4).equals(str1.get(2))
&&str2.get(3).equals(str1.get(1))){
flat=true;
}
break;
default:
if(str2.get(3).equals(str1.get(3))
&&str2.get(4).equals(str1.get(4))){
flat=true;
}
break;
}
break;
default:
flat=false;
switch (str2.get(3)) {
case "*":
if(str2.get(2).equals(str1.get(2))
&&str2.get(1).equals(str1.get(1))
||str2.get(2).equals(str1.get(4))
&&str2.get(1).equals(str1.get(3))){
flat=true;
}
break;
case "/":
if(str2.get(0).equals(str1.get(0))){
flat=true;
}
break;
case "+":
if(str2.get(0).equals(str1.get(0))
&&str2.get(1).equals(str1.get(1))
&&str2.get(2).equals(str1.get(2))
||str2.get(0).equals(str1.get(2))
&&str2.get(1).equals(str1.get(3))
&&str2.get(2).equals(str1.get(4))){
flat=true;
}
break;
default:
if(str2.get(0).equals(str1.get(0))
&&str2.get(1).equals(str1.get(1))
&&str2.get(2).equals(str1.get(2))){
flat=true;
}
break;
}
break;
}
if(flat){
zhuzhifu=true;
}
}
}else{
break;
}
}
return flat;
}
}

2.优化后的  

package com.jm.sizeyunsuan;

import java.util.ArrayList;
import java.util.List; /**
* 查重的总函数
* @author admin
*
*/
public class CongFu {
/**
* 查重
*/
public boolean chacong(List<String> timus,String yunsuan){
boolean flat=false;//获取是否重复的标记
boolean zhuzhifu=false;//在flat为true的时候,终止本次循环的标志
for(String s:timus){
if(!zhuzhifu){
List<String> str=new ArrayList<String>();//获取已经存入在list中的题目
List<String> str2=new ArrayList<String>();//获取这次尝试的题目
for(int i=0;i<s.length();i++){
str.add(s.charAt(i)+"");
str2.add(yunsuan.charAt(i)+"");
}
flat= same(str, str2);//查看符号数字是不是一样
if(flat){
flat=diaoYong(str,str2);//判断查重
if(flat){
zhuzhifu=true;
}
}
}else{
break;
}
}
return flat;
} /**
* 为了减少代码块的过多抽取调用的方法
* @param str list中的题目
* @param str2 现在产生的题目
* @return
*/
public boolean diaoYong(List<String> str,List<String> str2 ){
CongFuAddAndJian aj=new CongFuAddAndJian();
CongFuChengAndChu cc=new CongFuChengAndChu();
boolean flat=false;
switch (str2.get(1)) {
case "+":
flat=aj.addcopy(str,str2);
break;
case "-":
flat=aj.jiancopy(str,str2);
break;
case "/":
flat=cc.chucopy(str,str2);
break;
default:
flat=cc.chengcopy(str,str2);
break;
}
return flat;
} /**
* 符号数字一样
* str1是题目
* str2是本次产生的题目
*/
public boolean same(List<String> str1,List<String> str2 ){
boolean flat=false;
for(int i=0;i<str1.size();i++){
if(!str1.contains(str2.get(i))
||!str2.contains(str1.get(i))){
break;
}else{
if(i==str1.size()-1){
flat=true;
}
}
}
return flat;
}
}

  

package com.jm.sizeyunsuan;

import java.util.List;

/**
* 判断重复的第一个符号为加减的
* @author
*
*/
public class CongFuAddAndJian { /**
* 第一个为加号判断重复
* ||之前为符号位置的一致,||之后的为符号位置不同
*/
public boolean addcopy(List<String> str1,List<String> str2){
boolean flat=false;
switch (str2.get(3)) {
case "+":
flat=true;
break;
case "-":
if(str2.get(4).equals(str1.get(4))
&&str2.get(3).equals(str1.get(3))
||str2.get(3).equals(str1.get(1))
&&str2.get(4).equals(str1.get(2))){
flat=true;
}
break;
case "/":
if(str2.get(2).equals(str1.get(2))
&&str2.get(3).equals(str1.get(3))
&&str2.get(4).equals(str1.get(4))
||str2.get(2).equals(str1.get(0))
&&str2.get(3).equals(str1.get(1))
&&str2.get(4).equals(str1.get(2))){
flat=true;
}
break;
default:
if(str2.get(0).equals(str1.get(0))
&&str2.get(1).equals(str1.get(1))
||str2.get(0).equals(str1.get(4))
&&str2.get(1).equals(str1.get(3))){
flat=true;
}
break;
}
return flat;
} /**
* 第一个为减号判断重复
* ||之前为符号位置的一致,||之后的为符号位置不同
*/
public boolean jiancopy(List<String> str1,List<String> str2){
boolean flat=false;
switch (str2.get(3)) {
case "+":
if(str2.get(2).equals(str1.get(2))
&&str2.get(1).equals(str1.get(1))
||str2.get(1).equals(str1.get(3))
&&str2.get(2).equals(str1.get(4))){
flat=true;
}
break;
case "-":
if(str2.get(0).equals(str1.get(0))){
flat=true;
}
break;
case "/":
if(str2.get(0).equals(str1.get(0))
&&str2.get(2).equals(str1.get(2))
&&str2.get(1).equals(str1.get(1))){
flat=true;
}
break;
default:
if(str2.get(0).equals(str1.get(0))
&&str2.get(1).equals(str1.get(1))
||str2.get(0).equals(str1.get(4))
&&str2.get(1).equals(str1.get(3))){
flat=true;
}
break;
}
return flat;
} }

  

package com.jm.sizeyunsuan;

import java.util.List;

/**
* 判断重复的第一个符号为乘除的
* @author
*
*/
public class CongFuChengAndChu {
/**
* 第一个为乘法判断重复
* ||之前为符号位置的一致,||之后的为符号位置不同
*/
public boolean chengcopy(List<String> str1,List<String> str2){
boolean flat=false;
switch (str2.get(3)) {
case "*":
flat=true;
break;
case "/":
if(str2.get(4).equals(str1.get(4))
&&str2.get(3).equals(str1.get(3))
||str2.get(4).equals(str1.get(2))
&&str2.get(3).equals(str1.get(1))){
flat=true;
}
break;
case "+":
if(str2.get(4).equals(str1.get(4))
&&str2.get(3).equals(str1.get(3))
||str2.get(4).equals(str1.get(2))
&&str2.get(3).equals(str1.get(1))){
flat=true;
}
break;
default:
if(str2.get(3).equals(str1.get(3))
&&str2.get(4).equals(str1.get(4))){
flat=true;
}
break;
}
return flat;
} /**
* 第一个为除法判断重复
* ||之前为符号位置的一致,||之后的为符号位置不同
*/
public boolean chucopy(List<String> str1,List<String> str2){
boolean flat=false;
switch (str2.get(3)) {
case "*":
if(str2.get(2).equals(str1.get(2))
&&str2.get(1).equals(str1.get(1))
||str2.get(2).equals(str1.get(4))
&&str2.get(1).equals(str1.get(3))){
flat=true;
}
break;
case "/":
if(str2.get(0).equals(str1.get(0))){
flat=true;
}
break;
case "+":
if(str2.get(0).equals(str1.get(0))
&&str2.get(1).equals(str1.get(1))
&&str2.get(2).equals(str1.get(2))
||str2.get(0).equals(str1.get(2))
&&str2.get(1).equals(str1.get(3))
&&str2.get(2).equals(str1.get(4))){
flat=true;
}
break;
default:
if(str2.get(0).equals(str1.get(0))
&&str2.get(1).equals(str1.get(1))
&&str2.get(2).equals(str1.get(2))){
flat=true;
}
break;
}
return flat;
} }

  

JProfiler的使用的更多相关文章

  1. 部署JProfiler监控tomcat

    下载JProfiler包 wget http://download-keycdn.ej-technologies.com/jprofiler/jprofiler_linux_9_2.rpm 安装JPr ...

  2. Java监控工具介绍,VisualVm ,JProfiler,Perfino,Yourkit,Perf4J,JProbe,Java微基准测试

    本文是本人前一段时间做一个简单Java监控工具调研总结,主要包括VisualVm ,JProfiler,Perfino,Yourkit,Perf4J,JProbe,以及对Java微基准测试的简单介绍, ...

  3. 转载:JProfiler远程监控LINUX上的Tomcat过程细讲

    来源于xuwanbest的博客   所谓"工欲善其事,必先利其器",好的工具确能起到事半工倍的作用.我用到的最多的就两个JConsole 和JProfiler .JConsole监 ...

  4. JProfiler 8下载地址和注册码

    JProfiler---- 一个很好的java性能监控工具,现在附上下载地址和注册码,此破解版仅供学习交流使用, 其他用途请购买正版授权!!!windows x64 zip下载地址:http://do ...

  5. JProfiler

    1  前言 回答之前先让我们来看看什么是jProfiler:JProfiler是一个商业授权的Java剖析工具,由EJ技术有限公司,针对Java EE和Java SE应用程序开发的.它允许两个内存剖面 ...

  6. JProfiler学习笔记

    JProfiler学习笔记   一.安装JProfiler        从http://www.ej-technologies.com/下载5.1.2并申请试用序列号   二.主要功能简介 1.内存 ...

  7. jprofiler安装图解

    环境: 1.sun jdk1.6.0 2.jprofiler_windows_6_0_2.exe 安装 1. jdk, 安装略... 2. jprofiler安装 一路next 到Enter lice ...

  8. 循序渐进 Jprofiler

    一 Jprofiler 1 什么是Jprofiler JProfiler是一个全功能的Java剖析工具(profiler),专用于分析J2SE和J2EE应用程式.它把CPU.线程和内存的剖析组合在一个 ...

  9. JProfiler使用入门(一)——准备工作

      JProfiler是一个全功能的Java剖析工具(profiler),主要用于检查和跟踪系统(限于Java开发的)的性能. JProfiler可以通过时时的监控系统的内存使用情况,随时监视垃圾回收 ...

  10. JProfiler使用详细教程学习笔记

    JProfiler学习笔记    推荐文章:JProfiler 入门教程 一.安装JProfiler        从http://www.ej-technologies.com/下载5.1.2并申请 ...

随机推荐

  1. hadoop系列 第一坑: hdfs JournalNode Sync Status

    今天早上来公司发现cloudera manager出现了hdfs的警告,如下图: 解决的思路是: 1.首先解决简单的问题,查看警告提示的设置的阀值时多少,这样就可以快速定位到问题在哪了,果然Journ ...

  2. 从头学Android之RelativeLayout相对布局

    http://blog.csdn.net/worker90/article/details/6893246 相对布局对于做Web开发来说再熟悉不过了,我们在用CSS+DIV的时候经常会用到这些类似的相 ...

  3. exec dbms_stats.gather_schema_stats 手动优化统计

    Oracle10g或以上版本.exec dbms_stats.gather_schema_stats(ownname => 'DFMS', options => 'GATHER AUTO' ...

  4. [Noi2002]Savage(欧几里得拓展)

    题意:在一个岛上,有n个野人.这些人开始住在c号洞穴,每一年走p个洞,而且他的生命有L年.问如果岛上的洞穴为一个圈,那么这个圈至少有多少个,才能使他们每年都不在同一个洞穴里. 分析:先假设一种简单的情 ...

  5. [ASP.NET]ScriptManager控件使用

    目录 概述 局部刷新 错误处理 类型系统扩展 注册定制脚本 注册 Web 服务 在客户端脚本中使用认证和个性化服务 ScriptManagerProxy 类 添加 ScriptManager 控件 客 ...

  6. jenkins执行远程脚本注意的问题

    1构建任务 ->新建任务 2.填写任务名称    第二次构建可以复制第一次的配置 3.选择任务名称上面右键  选择配置 4.如下图所示 附录脚本内容 test.sh#!/bin/bash JAR ...

  7. Django ORM相关

    1. ORM 外键关联查询和多对多关系正反向查询 Class Classes(): name = CF class Student(): name = CF class = FK(to="C ...

  8. Twemproxy Redis 介绍与使用

    Twemproxy是一种代理分片机制,由Twitter开源.Twemproxy作为代理,可接受来自多个程序的访问,按照路由规则,转发给后台的各个Redis服务器,再原路返回.该方案很好的解决了单个Re ...

  9. java 变量及数据类型、原码、反码、补码

    Java基础——变量及数据类型 变量的概念 内存中的一个存储区域 变量名+数据类型 可在同一类型范围内不断变化 为什么定义变量: 用于不断的存放同一类型的常量,并可以重复使用 使用变量注意: 变量的作 ...

  10. C#以管理员用户打开某个程序

    static void Main(string[] args) { string path = @"C:\Windows\AppPatch\AppLoc.exe"; Process ...