简单的代码替换常用的System.out

本文介绍了一种在Java中利用StackTraceElement获取当前执行类名、方法名及代码行号的方法,并通过不同重载方法实现多样化的日志信息输出。

直接上源码,打出当前执行的类名,方法名以及代码所在行。

package org.apache.log4j.test;

public class TestUtil {

	public static void LogUtil(Class clazz, Object message) {
		// String clzz =
		// Thread.currentThread().getStackTrace()[1].getClassName();
		// System.out.println(clazz.getSimpleName());
		// String method =
		// Thread.currentThread().getStackTrace()[1].getMethodName();
		// String clazz1 = clazz.getClass().getName();
		// System.out.println(clazz.getMethods()[0]);

		StringBuffer sb = new StringBuffer();
		StackTraceElement[] stacks = new Throwable().getStackTrace();
		int stacksLen = stacks.length;

		sb.append("当前执行的类是【" + stacks[1].getClassName()).append("+】在第")
				.append("【").append(stacks[1].getLineNumber()).append("】")
				.append("】方法名【" + stacks[1].getMethodName());
	}
	
	public static void LogUtil() {

		StringBuffer sb = new StringBuffer();
		StackTraceElement[] stacks = new Throwable().getStackTrace();
		int stacksLen = stacks.length;

		sb.append("当前执行的类是:" + stacks[1].getClassName()).append(";在第")
				.append("【").append(stacks[1].getLineNumber()).append("】")
				.append(";方法名:" + stacks[1].getMethodName());
		
		System.out.println(sb.toString());
	}
	
	public static void LogUtil(Object message) {

		StringBuffer sb = new StringBuffer();
		StackTraceElement[] stacks = new Throwable().getStackTrace();
		int stacksLen = stacks.length;

		sb.append("提示信息:[class:" + stacks[1].getClassName()).append("]")
				.append("【lineNumber:").append(stacks[1].getLineNumber()).append("】")
				.append("[methodName:" + stacks[1].getMethodName()).append("]【message:").append(message).append("】");
		
		System.out.println(sb.toString());
	}
	
	
}

 

public class TesttStringMethod { public static void main(String[] args) { System.out.println("将字符串与数值进行连接"); String str = "fifty five is " + 5 + 5; System.out.println(str); System.out.println("连接数值与字符串"); String str1 = 5 + 5 + " is ten"; System.out.println(str1); System.out.println("将数值转换为字符串"); double a = 3.14; String str2 = " "+ a; System.out.println(str2); System.out.println("将数值型字符串转换为数字"); String str3 = "3.14"; double d = 【代码2】; System.out.println(d); System.out.println("求字符串的长度"); String str4 = "hello\nworld"; String str5 = "你好,中国"; System.out.println("字符串str4的长度是:"+【代码3】); System.out.println("字符串str5的长度是:"+【代码4】); System.out.println("截取子串"); String str6 = "I like java programming"; //获取第一个字符‘j’的位置 int position1 = 【代码5】; //从第一个‘j’字符处截取后面所有的子串 String s1 = 【代码6】; //获取第一个"java"字符串的位置 int position2 = 【代码7】; //截取"java"子串 String s2 = 【代码8】 //获取最后一个字符‘p’的位置 int position3 = 【代码9】 //从最后一个‘p’字符处截取后面所有的子串 String s3 = 【代码10】 System.out.println("s1=" + s1); System.out.println("s2=" + s2); System.out.println("s3=" + s3); System.out.println("替换字符串"); String path = "c:\\myfile\\2016\\result.txt"; int index = path.lastIndexOf("\\"); //获得文件名 String fileName = 【代码11】 //将".txt"替换为".java" String newName = 【代码12】 System.out.println(path); System.out.println(fileName); System.out.println(newName); System.out.println("分隔字符串"); String answer = "A;CD;ABC;D;B"; //将字符串以";"进行分隔 String[] s4 = 【代码13】 for(String s:s4) { System.out.print(s+"\t"); } System.out.println("\n字符串包含"); String name = "Tom.Jack.Rose"; System.out.println("name是否以Tom开头:"+【代码14】); System.out.println("name是否以Jack结尾:"+【代码15】); System.out.println("name是包含Rose:"+【代码16】); System.out.println("用户名验证"); String uname = " Tom "; System.out.println(uname); //去掉字符串的收尾空格 String s5 = 【代码17】 System.out.println(s5); //将字符串转化为小写 String s6 = 【代码18】; System.out.println(s6); System.out.println("判断s6字符串与tom是否相等:"+【代码19】); } } 补全代码
最新发布
06-05
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

DevBug

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值