如何在Java中获取当前代码行行号
2010-05-29 06:44
585 查看
为了实现自定义的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}
这里指出需要注意的几个问题:
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中获取当前代码行行号和文件名(__FILE__, __LINE__)
- Java中获取当前运行代码的类名、方法名、行号
- java代码实现如何获取当前经纬度?(安卓的话可以用GPS取)
- Java中获取当前运行代码的类名、方法名、行号
- Java中获取当前运行代码的类名、方法名、行号
- Java编程实现获取当前代码行行号的方法示例
- Java中获取当前运行代码的类名、方法名、行号
- android开发之java代码中如何获取到当前时间。详情代码带注释。
- android开发之java代码中如何获取到当前时间。详情代码带注释。
- [置顶] android开发之java代码中如何获取到当前时间。详情代码带注释。
- JAVA中如何动态获取得当前的文件名/类名/方法名/行号
- java如何从一段html代码中获取图片的src路径
- 用java代码如何获取本机的IP地址和主机名
- 如何使用Java代码获取Android移动终端Mac地址
- iOS如何获取当前日期前后N天的时间示例代码
- 如何通过Java代码判断当前的环境是否支持JRE 9
- List<Map<String,Object>>如何使用Java代码遍历以获取String,Object的值
- Java获取项目当前路径代码
- 如何使用java代码获取RSS中信息