@Retention(RetentionPolicy.RUNTIME) // 注解會在class字節(jié)碼文件中存在,在運行時可以通過反射獲取到

成都創(chuàng)新互聯(lián)從2013年創(chuàng)立,先為金平等服務(wù)建站,金平等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為金平企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
@Target({ElementType.FIELD,ElementType.METHOD})//定義注解的作用目標(biāo)**作用范圍字段、枚舉的常量/方法
@Documented//說明該注解將被包含在javadoc中
public @interface FieldMeta {
/**
* 是否為序列號
* @return
*/
boolean id() default false;
/**
* 字段名稱
* @return
*/
String name() default "";
/**
* 是否可編輯
* @return
*/
boolean editable() default true;
/**
樓上2位,我就郁悶?zāi)銈儍闪耍?/p>
雖然我不知道調(diào)用什么方法來實現(xiàn),但是最起碼也知道問題的意思!
人家是要把注釋的內(nèi)容打印出來!
正則的效率非常低,有很多不用正則的好方法:
一,示例 某java程序
比如說一個Test2.java,將其保存在C盤根目錄下,代碼內(nèi)容如下
/**
* @author xxx
*
*/
public class Test2 {
/* main method */
public static void main(String[] args) {
//a
int a =5;
//b
int b =5;
//a+b
System.out.println(a+b);
}
}
二,提取注釋程序,將所有注釋放到一個List里面,最后打印輸出:
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.List;
public class Test {
private static final String javaFilePath = "C:/Test2.java";
public static void main(String[] args) throws IOException {
ListString comments = new ArrayListString();
BufferedReader bfr = new BufferedReader(new InputStreamReader(new FileInputStream(javaFilePath)));
String line=null;
while((line=bfr.readLine())!=null){
line = line.trim();
if(line.startsWith("http://")){
comments.add(line);
}
else if(line.startsWith("/*")line.endsWith("*/")){
comments.add(line);
}else if(line.startsWith("/*")!line.endsWith("*/")){
StringBuffer multilineComment = new StringBuffer(line);
while((line=bfr.readLine())!=null){
line = line.trim();
multilineComment.append("\n").append(line);
if(line.endsWith("*/")){
comments.add(multilineComment.toString());
break;
}
}
}
}
bfr.close();
for(int i=0;icomments.size();i++){
System.out.println("第"+(i+1)+"處注釋: ");
System.out.println(comments.get(i));
}
}
}
三,輸出結(jié)果:
第1處注釋:
/**
* @author xxx
*
*/
第2處注釋:
/* main method */
第3處注釋:
//a
第4處注釋:
//b
第5處注釋:
//a+b
你說的應(yīng)該是注解吧,注釋本身就是一種說明性的作用,JAVA文件在被編譯到CLASS文件后是不存在注釋的,注解不一樣,可以通過反射獲取,但是JAVA文件被編譯后,注解也不一定存在,這個取決于你所定義注解的生命周期。
屬于重點,在系統(tǒng)中用到注解權(quán)限時非常有用,可以精確控制權(quán)限的粒度
注意:要想使用反射去讀取注解,必須將Retention的值選為Runtime Java代碼import?java.lang.annotation.Annotation;import?java.lang.reflect.Method;//讀取注解信息public?class?ReadAnnotationInfoTest?{????public?static?void?main(String[]?args)?throws?Exception?{????????//?測試AnnotationTest類,得到此類的類對象????????Class?c?=?Class.forName(com.iwtxokhtd.annotation.AnnotationTest);????????//?獲取該類所有聲明的方法????????Method[]?methods?=?c.getDeclaredMethods();????????//?聲明注解集合????????Annotation[]?annotations;????????//?遍歷所有的方法得到各方法上面的注解信息????????for?(Method?method?:?methods)?{????????????//?獲取每個方法上面所聲明的所有注解信息????????????annotations?=?method.getDeclaredAnnotations();????????????//?再遍歷所有的注解,打印其基本信息????????????System.out.println(method.getName());????????????for?(Annotation?an?:?annotations)?{????????????????System.out.println(方法名為:?+?method.getName()?+?其上面的注解為:?+?an.annotationType().getSimpleName());????????????????Method[]?meths?=?an.annotationType().getDeclaredMethods();????????????????//?遍歷每個注解的所有變量????????????????for?(Method?meth?:?meths)?{????????????????????System.out.println(注解的變量名為:?+?meth.getName());????????????????}????????????}????????}????}}
ArrayList,LinkedList,Vestor這三個類都實現(xiàn)了java.util.List接口,但它們有各自不同的特性,主要如下:
一、同步性
ArrayList,LinkedList是不同步的,而Vestor是的。所以如果要求線程安全的話,可以使用ArrayList或LinkedList,可以節(jié)省為同步而耗費開銷。但在多線程的情況下,有時候就不得不使用Vector了。當(dāng)然,也可以通過一些辦法包裝ArrayList,LinkedList,使他們也達(dá)到同步,但效率可能會有所降低。
二、數(shù)據(jù)增長
從內(nèi)部實現(xiàn)機(jī)制來講ArrayList和Vector都是使用Objec的數(shù)組形式來存儲的。當(dāng)你向這兩種類型中增加元素的時候,如果元素的數(shù)目超出了內(nèi)部數(shù)組目前的長度它們都需要擴(kuò)展內(nèi)部數(shù)組的長度,Vector缺省情況下自動增長原來一倍的數(shù)組長度,ArrayList是原來的50%,所以最后你獲得的這個集合所占的空間總是比你實際需要的要大。所以如果你要在集合中保存大量的數(shù)據(jù)那么使用Vector有一些優(yōu)勢,因為你可以通過設(shè)置集合的初始化大小來避免不必要的資源開銷。
三、檢索、插入、刪除對象的效率
ArrayList和Vector中,從指定的位置(用index)檢索一個對象,或在集合的末尾插入、刪除一個對象的時間是一樣的,可表示為O(1)。但是,如果在集合的其他位置增加或移除元素那么花費的時間會呈線形增長:O(n-i),其中n代表集合中元素的個數(shù),i代表元素增加或移除元素的索引位置。為什么會這樣呢?以為在進(jìn)行上述操作的時候集合中第i和第i個元素之后的所有元素都要執(zhí)行(n-i)個對象的位移操作。
LinkedList中,在插入、刪除集合中任何位置的元素所花費的時間都是一樣的—O(1),但它在索引一個元素的時候比較慢,為O(i),其中i是索引的位置。
所以,如果只是查找特定位置的元素或只在集合的末端增加、移除元素,那么使用Vector或ArrayList都可以。如果是對其它指定位置的插入、刪除操作,最好選擇LinkedList
參考文章:
當(dāng)前名稱:java獲取代碼注釋信息,java獲取方法上的注解
當(dāng)前網(wǎng)址:http://chinadenli.net/article14/dsipode.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、虛擬主機(jī)、網(wǎng)站導(dǎo)航、響應(yīng)式網(wǎng)站、商城網(wǎng)站、網(wǎng)站策劃
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)