這篇文章將為大家詳細(xì)講解有關(guān)Java如何實現(xiàn)StackTraceElement,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
成都創(chuàng)新互聯(lián)專注骨干網(wǎng)絡(luò)服務(wù)器租用10多年,服務(wù)更有保障!服務(wù)器租用,四川移動機(jī)房托管 成都服務(wù)器租用,成都服務(wù)器托管,骨干網(wǎng)絡(luò)帶寬,享受低延遲,高速訪問。靈活、實現(xiàn)低成本的共享或公網(wǎng)數(shù)據(jù)中心高速帶寬的專屬高性能服務(wù)器。具體介紹如下。
StackTrace用棧的形式保存了方法的調(diào)用信息。
可用Thread.currentThread().getStackTrace()方法得到當(dāng)前線程的StackTrace信息,該方法返回的是一個StackTraceElement數(shù)組。
線程中methodA調(diào)用了methodB,那么methodA先入棧methodB再入棧。數(shù)組的第一個元素保存的是棧頂元素,最后一個元素保存的棧底元素。正好與調(diào)用棧的順序相反。
在StackTraceElement數(shù)組下標(biāo)為2的元素中保存了當(dāng)前方法的所屬文件名,當(dāng)前方法所屬的類名,以及該方法的名字,除此以外還可以獲取方法調(diào)用的行數(shù)。該特性可以用來設(shè)計日志模塊。
package com.demo.test; public class StackTraceDemo { public static void testA() { testB(); } public static void testB() { StackTraceElement[] stackTraceElements = Thread.currentThread().getStackTrace(); System.out.println("-------> StackTraceElement[]"); for (int i = 0; i < stackTraceElements.length; i++) { System.out.println("-------> " + i); System.out.println(stackTraceElements[i]); System.out.println("StackTraceElement.getClassName() => " + stackTraceElements[i].getClassName()); System.out.println("StackTraceElement.getFileName() => " + stackTraceElements[i].getFileName()); System.out.println("StackTraceElement.getLineNumber() => " + stackTraceElements[i].getLineNumber()); System.out.println("StackTraceElement.getMethodName() => " + stackTraceElements[i].getMethodName()); System.out.println("StackTraceElement.isNativeMethod() => " + stackTraceElements[i].isNativeMethod()); } } public static String getMethodName() { StackTraceElement[] stackTraceElements = Thread.currentThread().getStackTrace(); if(stackTraceElements.length > 2) { return stackTraceElements[2].getMethodName(); } return null; } public static void main(String[] args) { testA(); System.out.println("\nthis's method name is " + getMethodName()); } }輸出:
-------> StackTraceElement[]
-------> 0
java.lang.Thread.getStackTrace(Unknown Source)
StackTraceElement.getClassName() => java.lang.Thread
StackTraceElement.getFileName() => null
StackTraceElement.getLineNumber() => -1
StackTraceElement.getMethodName() => getStackTrace
StackTraceElement.isNativeMethod() => false
-------> 1
com.demo.test.StackTraceDemo.testB(StackTraceDemo.java:10)
StackTraceElement.getClassName() => com.demo.test.StackTraceDemo
StackTraceElement.getFileName() => StackTraceDemo.java
StackTraceElement.getLineNumber() => 10
StackTraceElement.getMethodName() => testB
StackTraceElement.isNativeMethod() => false
-------> 2
com.demo.test.StackTraceDemo.testA(StackTraceDemo.java:6)
StackTraceElement.getClassName() => com.demo.test.StackTraceDemo
StackTraceElement.getFileName() => StackTraceDemo.java
StackTraceElement.getLineNumber() => 6
StackTraceElement.getMethodName() => testA
StackTraceElement.isNativeMethod() => false
-------> 3
com.demo.test.StackTraceDemo.main(StackTraceDemo.java:32)
StackTraceElement.getClassName() => com.demo.test.StackTraceDemo
StackTraceElement.getFileName() => StackTraceDemo.java
StackTraceElement.getLineNumber() => 32
StackTraceElement.getMethodName() => main
StackTraceElement.isNativeMethod() => falsethis's method name is main
關(guān)于“Java如何實現(xiàn)StackTraceElement”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。