欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費電子書(shū)等14項超值服

開(kāi)通VIP
csdn 文檔中心:利用jakarta commons lang簡(jiǎn)化java
利用Jakarta Commons Lang簡(jiǎn)化Java

摘要
  作為企業(yè)Java開(kāi)發(fā)人員,我們總是需要實(shí)現各種功能,如解析XML、使用HTTP、驗證輸入以及處理日期等。使用Jakarta Commons項目的目的在于創(chuàng )建負責處理所有此類(lèi)常用任務(wù)的組件,從而節約時(shí)間,讓您集中精力處理核心業(yè)務(wù)解決方案。在本文中,我們將對Jakarta Commons 項目作簡(jiǎn)單介紹,然后演示如何使用Jakarta Commons內的Lang組件來(lái)處理和簡(jiǎn)化日常Java任務(wù),比如字符串操作、使用日期和日歷、比較數據對象以及對象排序等。對于本文中的所有例子,我們都將使用最新的Lang版本(即2.1版本)。
  編者按:本文中的代碼是根據Commons Lang的 RC1版本 編寫(xiě)的。其最終版不久將發(fā)行。

Commons和Lang組件簡(jiǎn)介
  Jakarta Commons 項目旨在實(shí)現可重用的 Java 組件。此項目包含數十個(gè)組件,用以簡(jiǎn)化 Java 的開(kāi)發(fā),每個(gè)組件負責滿(mǎn)足一個(gè)特定需求。有大量的組件可用,且不僅限于在特定類(lèi)型的Java應用程序中使用。

項目分類(lèi)在兩個(gè)部件中:

  1. Commons Proper:Commons Proper中的項目已可以投入實(shí)際使用。
  2. Commons Sandbox:sandbox內的項目仍然處于實(shí)驗階段。

  目前Commons Proper中有33個(gè)項目,Commons Sandbox中有22個(gè)項目,故而,任何一類(lèi)Java項目都有其存在的意義。
  Lang組件是Jakarta Commons中較為流行的組件之一。Lang是要呈現在J2SE本身中的一組類(lèi)。
  在本文中,我們將了解Lang最有用的一些功能。要注意的是,也可以只使用基本Java類(lèi)來(lái)完成Lang的每個(gè)功能,但相對于自己學(xué)習、理解并編寫(xiě)代碼而言,使用Lang要簡(jiǎn)單得多。即使您能夠寫(xiě)出最好的代碼,使用經(jīng)過(guò)實(shí)驗和測試的Lang的功能會(huì )更快一些,能節省大量的檢查與測試時(shí)間。隨著(zhù)Lang一起提供了特有的JUnit測試用例,Lang的使用極其廣泛,已經(jīng)歷了其創(chuàng )建者和現實(shí)世界的種種考驗。
  Lang的一個(gè)重要特征是其簡(jiǎn)單性。通常來(lái)說(shuō),新的Java組件十分復雜,要了解若干種技術(shù)才能使用這些組件。要理解組件的用途通常都很難,更別說(shuō)實(shí)際使用該組件了。但對于大多數Commons組件而言,這就不是問(wèn)題了。Lang一類(lèi)組件使用方便,無(wú)論對Java初學(xué)者還是高級Java用戶(hù)都非常有用。
  如果在采用技術(shù)前需要有十足的保證,則請在保存您的Java軟件的目錄中搜索commons-lang*.jar。結果會(huì )讓您感到很意外。 Tomcat、Struts、Hibernate、SpringWebWork 等常見(jiàn)Java項目都使用Lang。
  首先讓我們看一看使用Lang進(jìn)行大多數開(kāi)發(fā)人員幾乎每天必須進(jìn)行的操作——字符串操作。

處理字符串
  無(wú)論應用程序是基于Swing、J2EE或J2ME的,它都必須使用字符串。所以,盡管在Java中使用字符串相當簡(jiǎn)單,但是如果希望按照一定的條件修改和處理字符串,事情就不那么簡(jiǎn)單了。您不得不在各種與字符串相關(guān)的類(lèi)中尋找各種不常用的方法,然后想辦法使其協(xié)同工作,以獲得所需的結果。雖然有些Lang方法與J2SE中的某些方法重疊,但在大多數情況下,一個(gè)Lang方法就可提供各種類(lèi)中的多個(gè)J2SE方法的功能,從而幫助您獲得所需的輸出。
  Lang組件有許多專(zhuān)門(mén)用于字符串操作的類(lèi)?,F在我們將使用一個(gè)簡(jiǎn)單的Java應用程序來(lái)演示一些較為有用的類(lèi)和方法。
  當應用程序接受用戶(hù)輸入時(shí),由于用戶(hù)可能會(huì )存在輸入錯誤的情況,或用戶(hù)可能以各種格式輸入數據,而您希望只采用一種格式進(jìn)行處理和存儲,則通常會(huì )涉及到對字符串進(jìn)行操作。
  例如,您有一個(gè)帶輸入框的窗體,用戶(hù)在此輸入框內輸入許可證密鑰。您希望允許輸入1111-JAVA格式的密鑰。您必須進(jìn)行以下操作:

  1. 檢查是否為空字符串。
  2. 忽略空格。
  3. 密鑰區分大小寫(xiě)。
  4. 用“-”標記分隔密鑰字符串,然后檢查第一部分是否全部是數字,第二部分包含的字符是否只來(lái)自有效字符集“J”、“A”、“V”、“A”。
  5. 兩個(gè)部分均應有四個(gè)字符。
  6. 第一部分的第四個(gè)數字應該是“0”。

  只有當密鑰滿(mǎn)足所有這些條件時(shí),應用程序才會(huì )查詢(xún)數據庫,檢查該密鑰是否合法。
  如果不花大量的時(shí)間瀏覽String、StringTokenizer和其他類(lèi)的API文檔,您能完成以上的任務(wù)么?我不能,所以現在我將試著(zhù)用Lang組件來(lái)管理驗證。
清單1. checkLicenseKey()方法

/** * Check if the key is valid * @param key license key value * @return true if key is valid, false otherwise. */public static boolean checkLicenseKey(String key){    //checks if empty or null    if(StringUtils.isBlank(key)){        return false;    }    //delete all white space    key= StringUtils.deleteWhitespace(key);    //Split String using the - separator    String[] keySplit = StringUtils.split(key, "-");    //check lengths of whole and parts    if(keySplit.length != 2        || keySplit[0].length() != 4        || keySplit[1].length() != 4) {        return false;    }    //Check if first part is numeric    if(!StringUtils.isNumeric(keySplit[0])){        return false;    }    //Check if second part contains only    //the four characters ‘J‘, ‘A‘, ‘V‘ and ‘A‘    if(! StringUtils.containsOnly(keySplit[1]            ,new char[]{‘J‘, ‘A‘, ‘V‘, ‘A‘})){        return false;    }    //Check if the fourth character	  //in the first part is a ‘0‘    if(StringUtils.indexOf(keySplit[0], ‘0‘) != 3){        return false;    }    //If all conditions are fulfilled, key is valid.    return true;}
  在清單1中,我們使用了org.apache.commons.lang.StringUtils類(lèi)中提供的各種方法,根據我們先前定義的所有規則對字符串進(jìn)行驗證。isBlank()方法檢查字符串是否為空。deleteWhitespace()方法確保字符串不包含空格。然后我們使用split()方法對字符串進(jìn)行分隔,并使用isNumeric()、containsOnly()和indexOf()方法對密鑰的兩部分進(jìn)行驗證。
  請注意,盡管在J2SE中已經(jīng)有了indexOf()方法,最好使用StringUtils中的indexOf()。與J2SE indexOf()方法不同,使用StringUtils indexOf()時(shí)無(wú)需擔心空指針的問(wèn)題。觸發(fā)NullPointerException被認為是Java程序員最常犯的錯誤。Lang可以確保您不會(huì )犯同樣的錯誤。即使向indexOf()或其他此類(lèi)方法傳遞一個(gè)null,都不會(huì )引發(fā)NullPointerException。indexOf()將直接返回-1。
  這樣,只需幾行簡(jiǎn)單代碼,就可以實(shí)現相應的功能,而采用其他方法需要編寫(xiě)很多行代碼,而且十分麻煩。如果使用清單2中所示的主方法執行checkLicenseKey()方法,所得到的結果如清單3所示。

清單2. main()方法
public static void main(String[] args) {    String []key= {"1210-JVAJ","1211-JVAJ", "210-JVAJ", "1210-ZVAJ"};    for (int i=0; i < key.length; i++){        if(checkLicenseKey(key[i])){            System.out.println(key[i]+ " >> Is Valid");        }        else{            System.out.println(key[i]+ " >> Is InValid");        }    }}
清單3. 輸出
1210-JVAJ >> Is Valid1211-JVAJ >> Is InValid210-JVAJ >> Is InValid1210-ZVAJ >> Is InValid
  大部分用于進(jìn)行字符串操作的方法都隸屬于org.apache.commons.lang.StringUtils,但也有其他的類(lèi)可以使用。CharUtils和CharSetUtils分別提供使用字符和字符集的實(shí)用方法。WordUtils是在2.0版中首次出現的類(lèi),用于承載專(zhuān)門(mén)用于處理字的實(shí)用方法。不過(guò),由于字符串和字的處理上有大量的重疊操作,使得此類(lèi)似乎有點(diǎn)沒(méi)有存在的必要了。RandomStringUtils類(lèi)可以根據各種規則生成隨機字符串。
  現在,讓我們了解一下Lang的另一個(gè)有用的方面:處理日期和時(shí)間的能力。

時(shí)間技術(shù)
  在Java中處理日期和時(shí)間是一件相當棘手的事。如果要使用java.text.SimpleDateFormat、java.util.Calendar、java.util.Date等類(lèi),需要一定時(shí)間來(lái)適應,還需要對每一個(gè)涉及到的類(lèi)和接口非常了解,才能順利地處理日期和時(shí)間。
  Lang組件徹底地簡(jiǎn)化了日期的處理,并可對其進(jìn)行格式化。您可以輕松地格式化日期以進(jìn)行顯示、比較日期、舍入或截斷日期,甚至能獲取特定范圍內的所有日期。

清單4. 處理日期和時(shí)間
public static void main(String[] args) throws InterruptedException, ParseException {    //date1 created    Date date1= new Date();    //Print the date and time at this instant    System.out.println("The time right now is >>"+date1);    //Thread sleep for 1000 ms    Thread.currentThread().sleep(DateUtils.MILLIS_IN_SECOND);    //date2 created.    Date date2= new Date();    //Check if date1 and date2 have the same day    System.out.println("Is Same Day >> "        + DateUtils.isSameDay(date1, date2));    //Check if date1 and date2 have the same instance    System.out.println("Is Same Instant >> "        +DateUtils.isSameInstant(date1, date2));    //Round the hour    System.out.println("Date after rounding >>"        +DateUtils.round(date1, Calendar.HOUR));    //Truncate the hour    System.out.println("Date after truncation >>"        +DateUtils.truncate(date1, Calendar.HOUR));    //Three dates in three different formats    String [] dates={"2005.03.24 11:03:26", "2005-03-24 11:03", "2005/03/24"};    //Iterate over dates and parse strings to java.util.Date objects    for(int i=0; i < dates.length; i++){        Date parsedDate= DateUtils.parseDate(dates[i],        new String []{"yyyy/MM/dd", "yyyy.MM.dd HH:mm:ss", "yyyy-MM-dd HH:mm"});        System.out.println("Parsed Date is >>"+parsedDate);    }    //Display date in HH:mm:ss format    System.out.println("Now >>"        +DateFormatUtils.ISO_TIME_NO_T_FORMAT.format(System.currentTimeMillis()));}
  清單4演示了org.apache.commons.lang.DateUtils和org.apache.commons.lang.DateFormatStringUtils類(lèi)的部分功能。還有其他許多方法可以進(jìn)行同樣的操作,但輸入格式不同。故而,如果萬(wàn)一您必須分析和格式化一個(gè)日期值,只需要借助提供的方法之一,利用一行代碼就可以實(shí)現了。
  執行清單4中代碼后的輸入如清單5所示。

清單5. 輸出
The time right now is >>Sat Apr 09 14:40:41 GMT+05:30 2005Is Same Day >> trueIs Same Instant >> falseDate after rounding >>Sat Apr 09 15:00:00 GMT+05:30 2005Date after truncation >>Sat Apr 09 14:00:00 GMT+05:30 2005Parsed Date is >>Thu Mar 24 11:03:26 GMT+05:30 2005Parsed Date is >>Thu Mar 24 11:03:00 GMT+05:30 2005Parsed Date is >>Thu Mar 24 00:00:00 GMT+05:30 2005Now >>14:40:43
  在清單4中,我們創(chuàng )建了兩個(gè)日期,這兩個(gè)日期僅有一秒的差別。然后使用isSameInstant()和isSameDay()方法檢查這兩個(gè)日期是否相同。接下來(lái)將日期進(jìn)行舍入和截斷,然后使用在數組中指定的各種格式對特殊日期用例進(jìn)行解析。
  將您的應用程序集成到第三方應用程序時(shí),經(jīng)常不能完全確定輸入的格式。我曾經(jīng)做過(guò)一個(gè)對舊版應用程序的集成,對于每個(gè)問(wèn)題,該應用程序似乎總是有三個(gè)答案。所以,如果必須對此類(lèi)應用程序提供的日期進(jìn)行解析,您需要提供三個(gè)和四個(gè)不同的日期格式。清單4中使用parseDate()方法就是為了完成這項任務(wù)。這樣,即使輸入有變化,仍然能更對日期進(jìn)行解析。還要注意,數組內模式的順序與輸入的順序并不相同,但該方法仍然找到了適當的模式,并據此進(jìn)行解析。
  最后,我們按照ISO_TIME_NO_T_FORMAT格式(HH:mm:ss)對日期進(jìn)行格式化并打印輸入?,F在我們將了解使用Lang生成常用方法toString()。

生成toString()方法
  經(jīng)常要用到equals()、toString()和hashCode()方法。不過(guò),談到實(shí)際編寫(xiě)這些方法的實(shí)現時(shí),不僅我們大多數人不愿意這樣做,而且我們也不能確定如何準確簡(jiǎn)單地編寫(xiě)這些方法。生成器程序包提供了一些實(shí)用類(lèi),可以幫助您方便地創(chuàng )建這些方法的實(shí)現。大多數情況下,只需要一行代碼即可。下面我們將了解Lang的toString功能。

toString()方法
  您可能沒(méi)有注意到,在清單4中,即使我們向System.out.println()傳遞一個(gè)java.util.Date對象,所獲得的輸出仍然是正確的日期和時(shí)間顯示。傳遞對象引用時(shí),將自動(dòng)調用toString()方法,所以可以實(shí)現這一點(diǎn)。那么,在我們的示例中實(shí)際上調用了java.util.Date類(lèi)的toString()方法,我們能夠得到正確的輸出是因為有人重寫(xiě)了java.util.Date類(lèi)中的java.lang.Object類(lèi)的toString()方法。
  如果沒(méi)有重寫(xiě)toString()方法,則獲得的輸出只是類(lèi)名稱(chēng)和hashcode的名稱(chēng)。將不會(huì )顯示類(lèi)中的任何數據。所以,如果編寫(xiě)了一個(gè)新類(lèi),且希望能得到正確的打印輸出,則需要重寫(xiě)該類(lèi)中的toString()方法。

清單6. toString()方法
public class Computer {    String processor;    String color;    int cost;    /** Creates a new instance of Computer */    public Computer(String processor, String color, int cost) {        this.processor=processor;        this.color=color;        this.cost=cost;    }    public static void main(String[] args) {        Computer myComp=new Computer("Pentium","black",1000);        System.out.println(myComp);    }        public String toString(){        return ToStringBuilder.reflectionToString(this);        /*        return ToStringBuilder.reflectionToString(this            , ToStringStyle.SHORT_PREFIX_STYLE);        return ToStringBuilder.reflectionToString(this            , ToStringStyle.MULTI_LINE_STYLE);        return new ToStringBuilder(this)            .append("processor", processor).toString();         */    }}
  清單6演示了具有三個(gè)字段的Computer類(lèi)。其中值得關(guān)注的是toString()方法。調用reflectionToString()方法可以判斷哪些是類(lèi)中的字段,然后打印其名稱(chēng)和值。main()方法中,我們只創(chuàng )建了該類(lèi)的一個(gè)實(shí)例,然后將其打印出來(lái)。該類(lèi)的輸出為dev2dev.Computer@f6a746[processor=Pentium,color=black,cost=1000]。
  因而,如果不希望花太多精力,但又需要您的類(lèi)有toString()實(shí)現,最簡(jiǎn)單的方法莫過(guò)于將這兩行代碼復制并粘貼到您的所有類(lèi)中。如果希望更好地控制生成的結果,請參見(jiàn)注釋中提到的選項。通過(guò)創(chuàng )建ToStringBuilder的新實(shí)例,可以對輸出應用各種樣式,甚至生成全部輸出。如果按照列出的順序執行了全部四個(gè)返回語(yǔ)句,則輸出如清單7所示。

清單7. 基于ToStringBuilder方法的四個(gè)可能輸出
1) dev2dev.Computer@f6a746[processor=Pentium,color=black,cost=1000]2) Computer[processor=Pentium,color=black,cost=1000]3) dev2dev.Computer@f6a746[   processor=Pentium   color=black   cost=1000   ]4) dev2dev.Computer@192d342[processor=Pentium]
對象比較與排序
  經(jīng)常需要對數據對象進(jìn)行比較,并據此進(jìn)行排序。那么我們如何對清單6中所給出的Computer類(lèi)的對象進(jìn)行比較和排序呢?
  您猜猜!讓我們使用Lang根據計算機的成本對Computer對象進(jìn)行排序。若要比較對象,需要實(shí)現java.lang.Comparable接口。此接口具有惟一的方法compareTo(Object)。此方法實(shí)現將當前對象和傳遞給此方法的對象進(jìn)行比較。如果此對象小于、等于或大于指定的對象,此方法將分別返回負數、零或正數。
  為了對Computer對象進(jìn)行比較,在Computer類(lèi)中實(shí)現compareTo() 方法,如清單8所示。

清單8. compareTo()方法
public int compareTo(Object obj) {    Computer anotherComputer = (Computer)obj;    //return new CompareToBuilder().reflectionCompare(this, anotherComputer);    return new CompareToBuilder().			append(this.cost, anotherComputer.cost).toComparison();}
  然后,為了實(shí)際進(jìn)行比較,我們編寫(xiě)一個(gè)名為ComputerSor的簡(jiǎn)單類(lèi),如清單9中所示。我們只向ArrayList添加三個(gè)對象,然后進(jìn)行排序。

清單9. ComputerSort類(lèi)
public class ComputerSort  {    public static void main(String[] args) {        ArrayList computerList = new ArrayList();        computerList.add(new Computer("Pentium","black", 1000));        computerList.add(new Computer("Pentium","chocolate", 334));        computerList.add(new Computer("Pentium","darkgray", 2234));        Collections.sort(computerList);        System.out.println(computerList);    }}
  執行ComputerSort時(shí),將看到對象根據cost字段的值進(jìn)行了排序。CompareToBuilder與ToStringBuilder類(lèi)似,也有一個(gè)基于反射的用法選項。我們已對清單8中的compareTo()方法中的位元進(jìn)行了注釋?zhuān)驗?,在此種情況下,反射選項將比較所有字段,最終獲得不正確的結果。如果既不希望比較當前類(lèi)中的字段,也不希望比較其超類(lèi)中的字段,CompareToBuilder也提供了可以用于此用途的方法。執行ComputerSort類(lèi)的輸出如清單10中所示。

清單10. 排序后的Computer對象
[dev2dev.Computer@cf2c80[processor=Pentium,color=chocolate,cost=334], dev2dev.Computer@12dacd1[processor=Pentium,color=black,cost=1000], dev2dev.Computer@1ad086a[processor=Pentium,color=darkgray,cost=2234]]

結束語(yǔ)
  本文中,我們了解了Jakarta Commons Lang組件的一些主要功能??偟恼f(shuō)來(lái),Commons項目是非常有用的項目,但并沒(méi)有得到充分利用。雖然開(kāi)源項目使用了許多Commons組件,但其在開(kāi)源世界之外的應用并不十分廣泛?,F在您已經(jīng)對Lang的功能有所了解,應該考慮立即將其應用到您的應用程序中。另外,還可以在Commons項目中尋找各種有用的組件,從而簡(jiǎn)化XML解析、使應用程序進(jìn)行HTTP會(huì )話(huà)、實(shí)現系統化驗證以及執行很多其他功能。

下載
  下載本文中用到的代碼:examples.zip (3KB)

參考資料

  Harshad Oak是Java J2EE門(mén)戶(hù)網(wǎng)站IndicThreads.com的創(chuàng )始人。他編寫(xiě)了Pro Jakarta Commons和Oracle JDeveloper 10g:Empowering J2EE Development,并與人合著(zhù)了Java 2 Enterprise Edition 1.4 Bible。他還是Rightrix Solutions的創(chuàng )始人。

原文出處
http://dev2dev.bea.com/pub/a/2005/04/commons_lang.html

本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請點(diǎn)擊舉報。
打開(kāi)APP,閱讀全文并永久保存 查看更多類(lèi)似文章
猜你喜歡
類(lèi)似文章
看例子練apache commons之lang篇
妙用Commons良藥
java使用apache-commons-lang3生成隨機字符串(可自定義規則)
iBatis 奇怪的錯,大家謹 ToStringBuilder.reflectionToString(this, ToStringStyle.MULTI_LINE_STYLE)
commons-lang
ToStringBuilder+ToStringStyle的用法
更多類(lèi)似文章 >>
生活服務(wù)
分享 收藏 導長(cháng)圖 關(guān)注 下載文章
綁定賬號成功
后續可登錄賬號暢享VIP特權!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服

欧美性猛交XXXX免费看蜜桃,成人网18免费韩国,亚洲国产成人精品区综合,欧美日韩一区二区三区高清不卡,亚洲综合一区二区精品久久