下别人的原来链接..... 支持效果不好要想格式化好需要解析语法树   7个积分我这里免费下      转自 https://download.csdn.net/download/jkl012789/10803755?utm_source=bbsseo

package com.yw.util;

import java.util.EmptyStackException;
import java.util.HashMap;
import java.util.Map;
import java.util.Stack;
import java.util.UUID;
import java.util.regex.Matcher;
import java.util.regex.Pattern; public class JavaForm { public static void main(String[] args) {
String str = "/*** @说明 : 可任意添加方法,类,引入包路径*/public class Test { /** * @说明 :输出结果 */ public static void main(String[] args) { System.out.println(\"hello world\"); }}";
str = formJava(str);
System.out.println(str);
} /**
* @说明 :格式化java代码
* @参数 :@param dataTmp
* @参数 :@return
* @返回 :String
* @作者 :WangXL
* @时间 :2018 11 22
**/
public static String formJava(String data) {
String dataTmp = replaceStrToUUid(data,"\"");
dataTmp = replaceStrToUUid(dataTmp,"'");
dataTmp = repalceHHF(dataTmp,"\n","");
dataTmp = repalceHHF(dataTmp,"{","{\n");
dataTmp = repalceHHF(dataTmp,"}","}\n");
dataTmp = repalceHHF(dataTmp,"/*","\n/*\n");
dataTmp = repalceHHF(dataTmp,"* @","\n* @");
dataTmp = repalceHHF(dataTmp,"*/","\n*/\n");
dataTmp = repalceHHF(dataTmp,";",";\n");
dataTmp = repalceHHF(dataTmp,"//","\n//");
dataTmp = repalceHHFX(dataTmp,"\n");
for(Map.Entry<String, String> r : mapZY.entrySet()){
dataTmp = dataTmp.replace(r.getKey(),r.getValue());
}
if(dataTmp==null)
return data;
return dataTmp;
} public static Map<String,String> mapZY = new HashMap<String,String>();
/**
* @说明 : 循环替换指定字符为随机uuid 并将uui存入全局map:mapZY
* @参数 :@param string 字符串
* @参数 :@param type 指定字符
* @作者 :WangXL
* @时间 :2018 11 23
**/
public static String replaceStrToUUid(String string,String type){
Matcher slashMatcher = Pattern.compile(type).matcher(string);
boolean bool = false;
StringBuilder sb = new StringBuilder();
int indexHome = -; //开始截取下标
while(slashMatcher.find()) {
int indexEnd = slashMatcher.start();
String tmp = string.substring(indexHome+,indexEnd); //获取"号前面的数据
if(indexHome == - ||bool == false){
sb.append(tmp);
bool = true;
indexHome = indexEnd;
}else{
if(bool){
String tem2 = "";
for( int i=indexEnd- ; i>- ; i-- ){
char c = string.charAt(i);
if(c == '\\'){
tem2 += c;
}else{
break;
}
}
int tem2Len = tem2.length();
if(tem2Len>-){
//结束符前有斜杠转义符 需要判断转义个数奇偶 奇数是转义了 偶数才算是结束符号
if(tem2Len % ==){
//奇数 非结束符
}else{
//偶数才算是结束符号
String uuid = UUID.randomUUID().toString().replace("-", "").toLowerCase();
uuid = type+uuid+type;
mapZY.put(uuid, type+tmp+type);
sb.append(uuid);
bool = false;
indexHome = indexEnd;
}
}
}
}
}
sb.append(string.substring(indexHome+,string.length()));
return sb.toString();
} //处理换行
public static String repalceHHF(String data,String a,String b){
try{
data = data.replace(a, "$<<yunwangA>>$<<yunwangB>>");
String arr[] = data.split("$<<yunwangA>>");
StringBuilder result = new StringBuilder();
if(arr != null){
for(int i=;i<arr.length;i++){
String t = arr[i];
result.append(t.trim());
if(t.indexOf("//")!=- && "\n".equals(a)){
result.append("\n");
}
}
}
String res = result.toString();
res = res.replace("$<<yunwangB>>", b);
res = res.replace("$<<yunwangA>>", "");
return res;
}catch(Exception e){
}
return null;
} //处理缩进
public static String repalceHHFX(String data,String a){
try{
String arr[] = data.split(a);
StringBuilder result = new StringBuilder();
if(arr != null){
String zbf = " ";
Stack<String> stack = new Stack<String>();
for(int i=;i<arr.length;i++){
String tem = arr[i].trim();
if(tem.indexOf("{")!=-){
String kg = getStack(stack,false);
if(kg == null){
result.append((tem+"\n"));
kg = "";
}else{
kg = kg + zbf;
result.append(kg+tem+"\n");
}
stack.push(kg);
}else if(tem.indexOf("}")!=-){
String kg = getStack(stack,true);
if(kg == null){
result.append(tem+"\n");
}else{
result.append(kg+tem+"\n");
}
}else{
String kg = getStack(stack,false);
if(kg == null){
result.append(tem+"\n");
}else{
result.append(kg+zbf+tem+"\n");
}
}
}
}
String res = result.toString();
return res;
}catch(Exception e){}
return null;
} /**
* @说明 : 获得栈数据
* @参数 :@param stack
* @参数 :@param bool true 弹出 false 获取
* @时间 :2018 11 22
**/
public static String getStack(Stack<String> stack,boolean bool){
String result = null;
try{
if(bool){
return stack.pop();
}
return stack.peek();
}catch(EmptyStackException e){
}
return result;
} }

java格式化代码(java格式化代码工具类)的更多相关文章

  1. java代码行数统计工具类

    package com.syl.demo.test; import java.io.*; /** * java代码行数统计工具类 * Created by 孙义朗 on 2017/11/17 0017 ...

  2. Java判断不为空的工具类总结

    1.Java判断是否为空的工具类,可以直接使用.包含,String字符串,数组,集合等等. package com.bie.util; import java.util.Collection; imp ...

  3. Java字符串转16 进制工具类Hex.java

    Java字符串转16 进制工具类Hex.java 学习了:https://blog.csdn.net/jia635/article/details/56678086 package com.strin ...

  4. Java中的AES加解密工具类:AESUtils

    本人手写已测试,大家可以参考使用 package com.mirana.frame.utils.encrypt; import com.mirana.frame.constants.SysConsta ...

  5. java里poi操作excel的工具类(兼容各版本)

    转: java里poi操作excel的工具类(兼容各版本) 下面是文件内具体内容,文件下载: import java.io.FileNotFoundException; import java.io. ...

  6. java.util.Arrays----操作数组的工具类

    java.util.Arrays操作数组的工具类,里面定义了很多操作数组的方法 1.boolean equals(int[] a,int[] b):判断两个数组是否相等. 2.String toStr ...

  7. 黑马程序员——【Java基础】——泛型、Utilities工具类、其他对象API

    ---------- android培训.java培训.期待与您交流! ---------- 一.泛型 (一)泛型概述 1.泛型:JDK1.5版本以后出现的新特性,用于解决安全问题,是一个类型安全机制 ...

  8. Java数组操作利器:Arrays工具类

    java.util.Arrays提供大量的工具方法来操作数组,这些方法全是静态方法. 1 便捷创建List public static <T> List<T> asList(T ...

  9. Java核心知识点学习----线程同步工具类,CyclicBarrier学习

    线程同步工具类,CyclicBarrier日常开发较少涉及,这里只举一个例子,以做备注.N个人一块出去玩,相约去两个地方,CyclicBarrier的主要作用是等待所有人都汇合了,才往下一站出发. 1 ...

  10. java中使用反射做一个工具类,来为指定类中的成员变量进行赋值操作,使用与多个类对象的成员变量的赋值。

    //------------------------------------------------我是代码的分割线 // 首选是一个工具类,在该工具类里面,定义了一个方法,public void s ...

随机推荐

  1. mybatis+spring boot+vue

    参考https://www.cnblogs.com/wlovet/p/8317282.html

  2. 【PAT甲级】1009 Product of Polynomials (25 分)

    题意: 给出两个多项式,计算两个多项式的积,并以指数从大到小输出多项式的指数个数,指数和系数. trick: 这道题数据未知,导致测试的时候发现不了问题所在. 用set统计非零项时,通过set.siz ...

  3. lib文件和dll文件

    一. 简介 1.1 C++两种库文件 lib包含了函数所在的dll文件和文件中函数位置的信息(入口),代码由运行时加载在进程空间中的dll提供,称为动态链接库dynamic link library. ...

  4. 「CQOI2011」动态逆序对

    「CQOI2011」动态逆序对 传送门 树套树. 删除一个位置的元素带来的减损数等于他前面大于它的和后面小于它的,然后这个直接树状数组套主席树维护一下就好了. 参考代码: #include <c ...

  5. CSS - 定位(position),难点

    元素的定位属性主要包括定位模式和边偏移两部分. 1. 边偏移 边偏移属性 描述 top 顶端偏移量,定义元素相对于其父元素上边线的距离 bottom 底部偏移量,定义元素相对于其父元素下边线的距离 l ...

  6. Melodic 使用URDF创建简单的机器人模型

    本人Linux版本:Ubuntu 18.04LTS ROS版本:Melodic URDF代码 <?xml version="1.0" ?> <robot name ...

  7. 《React后台管理系统实战 零》:基础笔记

    day01 1. 项目开发准备 1). 描述项目 2). 技术选型 3). API接口/接口文档/测试接口 2. 启动项目开发 1). 使用react脚手架创建项目 2). 开发环境运行: npm s ...

  8. 远程服务器使用tensorboard

    1 .由于服务器上tensorboard使用的端口是6006,因此,连接ssh时,将服务器的6006端口重定向到自己机器上的16006端口: ssh -L 16006:127.0.0.1:6006 u ...

  9. Linux centosVMware shell脚本介绍、shell脚本结构和执行、date命令用法、shell脚本中的变量

    一. shell脚本介绍 shell是一种脚本语言 aming_linux blog.lishiming.net 可以使用逻辑判断.循环等语法 可以自定义函数 shell是系统命令的集合 shell脚 ...

  10. 「AMPPZ2014」The Prices

    传送门 Luogu团队题链接 解题思路 看到 \(m\) 这么小,马上想到状压 \(\text{DP}\). 设 \(dp[i][j]\) 表示在前 \(i\) 家商店中已买商品的状态为 \(j\) ...