为了实现自定义的log类,能够输出具体的代码行行号,我通过使用StackTraceElement对象实现了。
这里指出需要注意的几个问题:
1. 程序中返回的代码行行号,是新建StackTrackElement对象的那一行。
2. 可以通过传参的方法实现输出特定行行号。具体实现见代码。
1/**
2 *
3 */
4package leo.demo.training;
5
6/**
7 * Get current java file name and current code line number
8 * @author Leo Xie
9 */
10public class CurrentLine {
11 /** *//** http://www.mscto.com
12 * @param args
13 */
14 public static void main(String[] args) {
15 StackTraceElement ste1 = null;
16
17 // get current thread and its related stack trace
18 StackTraceElement[] steArray = Thread.currentThread().getStackTrace();
19 int steArrayLength = steArray.length;
20
21 String s = null;
22
23 // output all related info of the existing stack traces
24 if(steArrayLength==0) {
软件开发网
25 System.err.println("No Stack Trace.");
26 } else {
27 for (int i=0; i<steArrayLength; i++) {
28 System.out.println("Stack Trace-" + i);
29 ste1 = steArray[i];
30 s = ste1.getFileName() + ": Line " + ste1.getLineNumber();
31 System.out.println(s);
32 }
33 }
34 // the following code segment will output the line number of the "new " clause
35 // that's to say the line number of "StackTraceElement ste2 = new Throwable().getStackTrace()[0];"
36 StackTraceElement ste2 = new Throwable().getStackTrace()[0]; http://www.mscto.com
37 System.out.println(ste2.getFileName() + ": Line " + ste2.getLineNumber());
38 // the following clause will output the line number in the external method "getLineInfo()"
39 System.out.println(getLineInfo());
40 // the following clause will output its current line number
41 System.out.println(getLineInfo(new Throwable().getStackTrace()[0]));
42 }
43
44 /** *//**
45 * return current java file name and code line number
46 * @return String
47 */
48 public static String getLineInfo() {
49 StackTraceElement ste3 = new Throwable().getStackTrace()[0];
50 return (ste3.getFileName() + ": Line " + ste3.getLineNumber()); http://www.mscto.com
51 }
52
53 /** *//** http://www.mscto.com
54 * return current java file name and code line name
55 * @return String
56 */
57 public static String getLineInfo(StackTraceElement ste4) {
58 return (ste4.getFileName() + ": Line " + (ste4.getLineNumber()));
59 }
60}
分享到:
相关推荐
主要介绍了Java编程实现获取当前代码行行号的方法,结合实例形式分析了java基于StackTraceElement对象实现获取代码行号的相关操作技巧,需要的朋友可以参考下
JAVA_连连看_源代码行行注释
统计指定目录C/C++/JAVA源代码的代码行,注释行和空白行行数。可以用通配符(*和?)指定要统计的文件的类型,可以指定多个文件类型
Java代码文件上传功能,拿上去直接可用,可学习,行行都有注释,针对小白详细讲解,一定要注意项目中要先创建两个文件夹temp和upload,具体可以对比这个小项目的代码
行行重行行读后感.doc
包含各个银行的联行号,即开户行行号,用于部分银行接口。
VC 6.0枚举获取所有进程并进行管理-模拟一个进程管理器的写法,枚举Windows中所有正在运行的进程,本示例将演示如何获取进程路径,打开进程句柄,获取进程优先级,终止进程主函数,创建状态栏,获取当前行行号,...
在文件每行行首与行尾添加东西拼接SQL 有用
主要介绍了jQuery实现获取table中鼠标click点击位置行号与列号的方法,涉及jQuery事件响应及针对table表格元素相关操作技巧,需要的朋友可以参考下
CO-SLAM代码注释 是一个neural RGB-D SLAM。 在场景表达用到了NeRF的思想:通过每一帧的采样像素点的5D坐标$(x,y,z,\theta,\phi)$经由encoding-...一种基于学习的的视觉里程计VO方法,可以在动态环境中实现运动分隔
aes加密算法实现行移位的verilog代码
行行重行行
利用BigDecimal 大数据类 来保证精度 例如Double 2-1.1=0.89999,在大数据类就无异常 例如 9+(-9)=0 9--6=15 9*(-9--3)= -54 3 + (-2) -1 = 0 -9*(9--2)*-3 = 297 实现了键位绑定 本计算器回退功能是直接...
这是java RMI 详解,通过例子加原理的解说,分步骤,通过简单的代码行行解释,看完想不会都难
详解讲解VC++对Excel的操作方式及代码,可以直接copy使用
在文本文件每行行首添加字符!
2022年10月人民银行最新联行号信息,共计155551条
行行 .vbs.vbs
人行联行号约14万条数据,...机构内标、ibpsCode、联行号、外标类型、备注、法人行号、银行名称、人行机构类型编码、直参行行号、上级机构列表、承接行行号、管辖行行号、CCPC节点编号、城市代码、系统标识、行别代码。
今天小编就为大家分享一篇Java实现OJ多组测试数据的输入方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧