下别人的原来链接..... 支持效果不好要想格式化好需要解析语法树   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. Java源码-集合-ArrayList

    基于JDK1.8.0_191 介绍   在Java中,对于数据的保存和使用有多种方式,主要的目的是以更少的资源消耗解决更多的问题,数组就是其中的一种,它的特点是所有的数据都保存在内存的一段连续空间中, ...

  2. 02-08Android学习进度报告八

    今天主要学习了昨天还没有学习完的Date & Time组件的知识. 首先是DatePicker(日期选择器) android:calendarTextColor : 日历列表的文本的颜色 an ...

  3. 各种STL的基本用法

    目录 STL及一些常用函数的基本用法 1.vector(向量)的基本用法 2.queue(队列)的基本用法 3.stack(栈)的基本操作 4.set(集合)的基本用法 5.map(映射)的基本用法 ...

  4. 139、Java内部类之使用this访问外部类属性

    01.代码如下: package TIANPAN; class Outer { // 外部类 private String msg = "Hello World !"; class ...

  5. VUe for循环if 的使用和函数的使用 (笔记)

    结果如图: 代码html <!DOCTYPE html> <html lang="en"> <head> <meta charset=&q ...

  6. 解决请求中的post、get乱码问题以及响应的乱码问题

    post: get: response:

  7. hdu 1599 find the mincost route floyd求无向图最小环

    find the mincost route Time Limit: 1000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/O ...

  8. Ubuntu的妥协将支持精选的32位应用

    据外媒Tom's hardware,Ubuntu开发人员Canonical在早先的时候宣布Ubuntu 19.10将不再更新32位软件包和应用程序,引来了诸多应用开发者的不满.现在,Ubuntu方面宣 ...

  9. 第1节 kafka消息队列:5、javaAPI操作

    8.kafka的API 详见代码   第一步:导入kafka的开发jar包 Kafka生产者 Kafka消费者

  10. ABC154 E - Almost Everywhere Zero

    数位DP模板,记忆化+限制即可 #include<bits/stdc++.h> using namespace std; #define lowbit(x) ((x)&(-x)) ...