Oracle 版本:Oracle Database 10g Release 2 (10.2.0.1)
下載地址:
http://www.oracle.com/technology/software/products/database/oracle10g/htdocs/10201winsoft.html
安裝設(shè)置:
1)這里的全局?jǐn)?shù)據(jù)庫(kù)名即為你創(chuàng)建的數(shù)據(jù)庫(kù)名,以后在訪問數(shù)據(jù),創(chuàng)建“本地Net服務(wù)名”時(shí)用到;
2)數(shù)據(jù)庫(kù)口令在登錄和創(chuàng)建“本地Net服務(wù)名”等地方會(huì)用到。
默認(rèn)的用戶名/密碼錯(cuò)誤:
更改登錄,輸入正確的用戶名/密碼:
測(cè)試成功:
輸入正確的用戶名/口令:
成功登陸:
打開sqlplus工具:
連接數(shù)據(jù)庫(kù):
創(chuàng)建表空間:
輸入新用戶的“用戶名/口令”:
新用戶“testcamds”成功登陸:
命令語(yǔ)法:
命令實(shí)例:
導(dǎo)入結(jié)果:
命令語(yǔ)法:
命令實(shí)例:
導(dǎo)入結(jié)果:
下載地址為:
A:普通版:
http://downloads.myeclipseide.com/downloads/products/eworkbench/7.0/myeclipse-7.1-win32.exe
B:Blue版
http://downloads4.myeclipseide.com/downloads/products/eworkbench/7.0-Blue/myeclipse-blue-7.1-win32.exe
其中普通版可以直接用迅雷下載,但是blue卻連不上。
嘗試了多種方式,終于找到了下載方法,不過速度很慢,而且很不穩(wěn)定:
使用的軟件
1、OperaTor-2.5
這是一個(gè)附帶代理的瀏覽器軟件;
2、eMule V1.1.3
常用的電驢軟件;
下面我們來看看如何下載:
【步驟1】:打開OperaTor,程序打開后,會(huì)發(fā)現(xiàn)托盤區(qū)有一個(gè)藍(lán)色圖標(biāo),上面有一個(gè)字母“P";
【步驟2】:將鼠標(biāo)移到該圖標(biāo),點(diǎn)擊右鍵,依次選擇【Edit】-》【Main configuration】
【步驟3】:在打開的config.txt文件中,我們可以看到,本地代理的端口為:9050,
【步驟4】:設(shè)置電驢的代理服務(wù)器,這里的服務(wù)器類型選”Socks 4a“:
【步驟5】:最后,點(diǎn)擊電驢的”新建“按鈕,將”blue版“的地址拷貝過來就可以下載了:
不過通過代理方式下載的速度很慢,有時(shí)候還會(huì)斷線,這時(shí)候只需要重新打開上面軟件就可以了。
一、Comparator
強(qiáng)行對(duì)某個(gè)對(duì)象collection進(jìn)行整體排序的比較函數(shù),可以將Comparator傳遞給Collections.sort或Arrays.sort。
接口方法:
二、Comparable
強(qiáng)行對(duì)實(shí)現(xiàn)它的每個(gè)類的對(duì)象進(jìn)行整體排序,實(shí)現(xiàn)此接口的對(duì)象列表(和數(shù)組)可以通過Collections.sort或Arrays.sort進(jìn)行自動(dòng)排序。
接口方法:
想必很多人都對(duì)正則表達(dá)式都頭疼。今天,我以我的認(rèn)識(shí),加上網(wǎng)上一些文章,希望用常人都可以理解的表達(dá)方式來和大家分享學(xué)習(xí)經(jīng)驗(yàn)。
開篇,還是得說說 ^ 和 $ 他們是分別用來匹配字符串的開始和結(jié)束,以下分別舉例說明:
"^The": 開頭一定要有"The"字符串;
"of despair$": 結(jié)尾一定要有"of despair" 的字符串;
那么,
"^abc$": 就是要求以abc開頭和以abc結(jié)尾的字符串,實(shí)際上是只有abc匹配。
"notice": 匹配包含notice的字符串。
你可以看見如果你沒有用我們提到的兩個(gè)字符(最后一個(gè)例子),就是說 模式(正則表達(dá)式) 可以出現(xiàn)在被檢驗(yàn)字符串的任何地方,你沒有把他鎖定到兩邊。
接著,說說 '*', '+',和 '?',
他們用來表示一個(gè)字符可以出現(xiàn)的次數(shù)或者順序。 他們分別表示:
"zero or more"相當(dāng)于{0,},
"one or more"相當(dāng)于{1,},
"zero or one."相當(dāng)于{0,1}, 這里是一些例子:
"ab*": 和ab{0,}同義,匹配以a開頭,后面可以接0個(gè)或者N個(gè)b組成的字符串("a", "ab", "abbb", 等);
"ab+": 和ab{1,}同義,同上條一樣,但最少要有一個(gè)b存在 ("ab", "abbb", 等。);
"ab?":和ab{0,1}同義,可以沒有或者只有一個(gè)b;
"a?b+$": 匹配以一個(gè)或者0個(gè)a再加上一個(gè)以上的b結(jié)尾的字符串。
要點(diǎn), '*', '+',和 '?'只管它前面那個(gè)字符。
你也可以在大括號(hào)里面限制字符出現(xiàn)的個(gè)數(shù),比如
"ab{2}": 要求a后面一定要跟兩個(gè)b(一個(gè)也不能少)("abb");
"ab{2,}": 要求a后面一定要有兩個(gè)或者兩個(gè)以上b(如"abb", "abbbb", 等。);
"ab{3,5}": 要求a后面可以有2-5個(gè)b("abbb", "abbbb", or "abbbbb")。
現(xiàn)在我們把一定幾個(gè)字符放到小括號(hào)里,比如:
"a(bc)*": 匹配 a 后面跟0個(gè)或者一個(gè)"bc";
"a(bc){1,5}": 一個(gè)到5個(gè) "bc."
還有一個(gè)字符 '│', 相當(dāng)于OR 操作:
"hi│hello": 匹配含有"hi" 或者 "hello" 的 字符串;
"(b│cd)ef": 匹配含有 "bef" 或者 "cdef"的字符串;
"(a│b)*c": 匹配含有這樣多個(gè)(包括0個(gè))a或b,后面跟一個(gè)c的字符串;
一個(gè)點(diǎn)('.')可以代表所有的單一字符,不包括"\n"
如果,要匹配包括"\n"在內(nèi)的所有單個(gè)字符,怎么辦?
對(duì)了,用'[\n.]'這種模式。
"a.[0-9]": 一個(gè)a加一個(gè)字符再加一個(gè)0到9的數(shù)字
"^.{3}$": 三個(gè)任意字符結(jié)尾 .
中括號(hào)括住的內(nèi)容只匹配一個(gè)單一的字符
"[ab]": 匹配單個(gè)的 a 或者 b ( 和 "a│b" 一樣);
"[a-d]": 匹配'a' 到'd'的單個(gè)字符 (和"a│b│c│d" 還有 "[abcd]"效果一樣); 一般我們都用[a-zA-Z]來指定字符為一個(gè)大小寫英文
"^[a-zA-Z]": 匹配以大小寫字母開頭的字符串
"[0-9]%": 匹配含有 形如 x% 的字符串
",[a-zA-Z0-9]$": 匹配以逗號(hào)再加一個(gè)數(shù)字或字母結(jié)尾的字符串
你也可以把你不想要得字符列在中括號(hào)里,你只需要在總括號(hào)里面使用'^' 作為開頭 "%[^a-zA-Z]%" 匹配含有兩個(gè)百分號(hào)里面有一個(gè)非字母的字符串。
要點(diǎn):^用在中括號(hào)開頭的時(shí)候,就表示排除括號(hào)里的字符。為了PHP能夠解釋,你必須在這些字符面前后加'',并且將一些字符轉(zhuǎn)義。
不要忘記在中括號(hào)里面的字符是這條規(guī)路的例外?在中括號(hào)里面, 所有的特殊字符,包括(''), 都將失去他們的特殊性質(zhì) "[*\+?{}.]"匹配含有這些字符的字符串。
還有,正如regx的手冊(cè)告訴我們: "如果列表里含有 ']', 最好把它作為列表里的第一個(gè)字符(可能跟在'^'后面)。 如果含有'-', 最好把它放在最前面或者最后面, or 或者一個(gè)范圍的第二個(gè)結(jié)束點(diǎn)[a-d-0-9]中間的‘-’將有效。
看了上面的例子,你對(duì){n,m}應(yīng)該理解了吧。要注意的是,n和m都不能為負(fù)整數(shù),而且n總是小于m. 這樣,才能 最少匹配n次且最多匹配m次。 如"p{1,5}"將匹配 "pvpppppp"中的前五個(gè)p.
下面說說以\開頭的
\b 書上說他是用來匹配一個(gè)單詞邊界,就是……比如've\b',可以匹配love里的ve而不匹配very里有ve
\B 正好和上面的\b相反。例子我就不舉了
……突然想起來……可以到http://www.phpv.net/article.php/251 看看其它用\ 開頭的語(yǔ)法
好,我們來做個(gè)應(yīng)用:
如何構(gòu)建一個(gè)模式來匹配 貨幣數(shù)量 的輸入
構(gòu)建一個(gè)匹配模式去檢查輸入的信息是否為一個(gè)表示money的數(shù)字。我們認(rèn)為一個(gè)表示money的數(shù)量有四種方式: "10000.00" 和 "10,000.00",或者沒有小數(shù)部分, "10000" and "10,000". 現(xiàn)在讓我們開始構(gòu)建這個(gè)匹配模式:
^[1-9][0-9]*$
這是所變量必須以非0的數(shù)字開頭。但這也意味著 單一的 "0" 也不能通過測(cè)試。 以下是解決的方法:
^(0│[1-9][0-9]*)$
"只有0和不以0開頭的數(shù)字與之匹配",我們也可以允許一個(gè)負(fù)號(hào)在數(shù)字之前:
^(0│-?[1-9][0-9]*)$
這就是: "0 或者 一個(gè)以0開頭 且可能 有一個(gè)負(fù)號(hào)在前面的數(shù)字。" 好了,現(xiàn)在讓我們別那么嚴(yán)謹(jǐn),允許以0開頭?,F(xiàn)在讓我們放棄 負(fù)號(hào) , 因?yàn)槲覀冊(cè)诒硎惧X幣的時(shí)候并不需要用到。 我們現(xiàn)在指定 模式 用來匹配小數(shù)部分:
^[0-9]+(\.[0-9]+)?$
這暗示匹配的字符串必須最少以一個(gè)阿拉伯?dāng)?shù)字開頭。 但是注意,在上面模式中 "10." 是不匹配的, 只有 "10" 和 "10.2" 才可以。 (你知道為什么嗎)
^[0-9]+(\.[0-9]{2})?$
我們上面指定小數(shù)點(diǎn)后面必須有兩位小數(shù)。如果你認(rèn)為這樣太苛刻,你可以改成:
^[0-9]+(\.[0-9]{1,2})?$
這將允許小數(shù)點(diǎn)后面有一到兩個(gè)字符。 現(xiàn)在我們加上用來增加可讀性的逗號(hào)(每隔三位), 我們可以這樣表示:
^[0-9]{1,3}(,[0-9]{3})*(\.[0-9]{1,2})?$
不要忘記 '+' 可以被 '*' 替代 如果你想允許空白字符串被輸入話 (為什么?)。 也不要忘記反斜桿 ‘\’ 在php字符串中可能會(huì)出現(xiàn)錯(cuò)誤 (很普遍的錯(cuò)誤)。
現(xiàn)在,我們已經(jīng)可以確認(rèn)字符串了, 我們現(xiàn)在把所有逗號(hào)都去掉 str_replace(",", "", $money) 然后在把類型看成 double然后我們就可以通過他做數(shù)學(xué)計(jì)算了。
再來一個(gè):
構(gòu)造檢查email的正則表達(dá)式
在一個(gè)完整的email地址中有三個(gè)部分:
1. 用戶名 (在 '@' 左邊的一切),
2.'@',
3. 服務(wù)器名(就是剩下那部分)。
用戶名可以含有大小寫字母阿拉伯?dāng)?shù)字,句號(hào) ('.'), 減號(hào)('-'), and 下劃線 ('_')。 服務(wù)器名字也是符合這個(gè)規(guī)則,當(dāng)然下劃線除外。
現(xiàn)在, 用戶名的開始和結(jié)束都不能是句點(diǎn)。 服務(wù)器也是這樣。 還有你不能有兩個(gè)連續(xù)的句點(diǎn)他們之間至少存在一個(gè)字符,好現(xiàn)在我們來看一下怎么為用戶名寫一個(gè)匹配模式:
^[_a-zA-Z0-9-]+$
現(xiàn)在還不能允許句號(hào)的存在。 我們把它加上:
^[_a-zA-Z0-9-]+(\.[_a-zA-Z0-9-]+)*$
上面的意思就是說: "以至少一個(gè)規(guī)范字符(除了。)開頭,后面跟著0個(gè)或者多個(gè)以點(diǎn)開始的字符串。"
簡(jiǎn)單化一點(diǎn), 我們可以用 eregi()取代 ereg()。eregi()對(duì)大小寫不敏感, 我們就不需要指定兩個(gè)范圍 "a-z" 和 "A-Z" ? 只需要指定一個(gè)就可以了:
^[_a-z0-9-]+(\.[_a-z0-9-]+)*$
后面的服務(wù)器名字也是一樣,但要去掉下劃線:
^[a-z0-9-]+(\.[a-z0-9-]+)*$
好。 現(xiàn)在只需要用“@”把兩部分連接:
^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*$
這就是完整的email認(rèn)證匹配模式了,只需要調(diào)用
eregi(‘^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*$ ’,$eamil)
就可以得到是否為email了。
正則表達(dá)式的其他用法
提取字符串
ereg() and eregi() 有一個(gè)特性是允許用戶通過正則表達(dá)式去提取字符串的一部分(具體用法你可以閱讀手冊(cè))。 比如說,我們想從 path/URL 提取文件名 ? 下面的代碼就是你需要:
ereg("([^\\/]*)$", $pathOrUrl, $regs);
echo $regs[1];
高級(jí)的代換
ereg_replace() 和 eregi_replace()也是非常有用的: 假如我們想把所有的間隔負(fù)號(hào)都替換成逗號(hào):
ereg_replace("[ \n\r\t]+", ",", trim($str));
最后,我把另一串檢查EMAIL的正則表達(dá)式讓看文章的你來分析一下。
"^[-!#$%&\'*+\\./0-9=?A-Z^_`a-z{|}~]+'.'@'.'[-!#$%&\'*+\\/0-9=?A-Z^_`a-z{|}~]+\.'.'[-!#$%&\'*+\\./0-9=?A-Z^_`a-z{|}~]+$"
如果能方便的讀懂,那這篇文章的目的就達(dá)到了。
原文地址:http://java.chinaitlab.com/base/732793.html
許多語(yǔ)言,包括Perl、PHP、Python、JavaScript和JScript,都支持用正則表達(dá)式處理文本,一些文本編輯器用正則表達(dá)式實(shí)現(xiàn)高級(jí)“搜索-替換”功能。那么Java又怎樣呢?本文寫作時(shí),一個(gè)包含了用正則表達(dá)式進(jìn)行文本處理的Java規(guī)范需求(Specification Request)已經(jīng)得到認(rèn)可,你可以期待在JDK的下一版本中看到它。
然而,如果現(xiàn)在就需要使用正則表達(dá)式,又該怎么辦呢?你可以從Apache.org下載源代碼開放的Jakarta-ORO庫(kù)。本文接下來的內(nèi)容先簡(jiǎn)要地介紹正則表達(dá)式的入門知識(shí),然后以Jakarta-ORO API為例介紹如何使用正則表達(dá)式。
一、正則表達(dá)式基礎(chǔ)知識(shí)
我們先從簡(jiǎn)單的開始。假設(shè)你要搜索一個(gè)包含字符“cat”的字符串,搜索用的正則表達(dá)式就是“cat”。如果搜索對(duì)大小寫不敏感,單詞“catalog”、“Catherine”、“sophisticated”都可以匹配。也就是說:
1.1 句點(diǎn)符號(hào)
假設(shè)你在玩英文拼字游戲,想要找出三個(gè)字母的單詞,而且這些單詞必須以“t”字母開頭,以“n”字母結(jié)束。另外,假設(shè)有一本英文字典,你可以用正則表達(dá)式搜索它的全部?jī)?nèi)容。要構(gòu)造出這個(gè)正則表達(dá)式,你可以使用一個(gè)通配符——句點(diǎn)符號(hào)“.”。這樣,完整的表達(dá)式就是“t.n”,它匹配“tan”、“ten”、“tin”和“ton”,還匹配“t#n”、“tpn”甚至“t n”,還有其他許多無意義的組合。這是因?yàn)榫潼c(diǎn)符號(hào)匹配所有字符,包括空格、Tab字符甚至換行符:
1.2 方括號(hào)符號(hào)
為了解決句點(diǎn)符號(hào)匹配范圍過于廣泛這一問題,你可以在方括號(hào)(“[]”)里面指定看來有意義的字符。此時(shí),只有方括號(hào)里面指定的字符才參與匹配。也就是說,正則表達(dá)式“t[aeio]n”只匹配“tan”、“Ten”、“tin”和“ton”。但“Toon”不匹配,因?yàn)樵诜嚼ㄌ?hào)之內(nèi)你只能匹配單個(gè)字符:
1.3 “或”符號(hào)
如果除了上面匹配的所有單詞之外,你還想要匹配“toon”,那么,你可以使用“|”操作符。“|”操作符的基本意義就是“或”運(yùn)算。要匹配“toon”,使用“t(a|e|i|o|oo)n”正則表達(dá)式。這里不能使用方擴(kuò)號(hào),因?yàn)榉嚼ㄌ?hào)只允許匹配單個(gè)字符;這里必須使用圓括號(hào)“()”。圓括號(hào)還可以用來分組,具體請(qǐng)參見后面介紹。
1.4 表示匹配次數(shù)的符號(hào)
表一顯示了表示匹配次數(shù)的符號(hào),這些符號(hào)用來確定緊靠該符號(hào)左邊的符號(hào)出現(xiàn)的次數(shù):
假設(shè)我們要在文本文件中搜索美國(guó)的社會(huì)安全號(hào)碼。這個(gè)號(hào)碼的格式是999-99-9999。用來匹配它的正則表達(dá)式如圖一所示。在正則表達(dá)式中,連字符(“-”)有著特殊的意義,它表示一個(gè)范圍,比如從0到9。因此,匹配社會(huì)安全號(hào)碼中的連字符號(hào)時(shí),它的前面要加上一個(gè)轉(zhuǎn)義字符“\”。
圖一:匹配所有123-12-1234形式的社會(huì)安全號(hào)碼
假設(shè)進(jìn)行搜索的時(shí)候,你希望連字符號(hào)可以出現(xiàn),也可以不出現(xiàn)——即,999-99-9999和999999999都屬于正確的格式。這時(shí),你可以在連字符號(hào)后面加上“?”數(shù)量限定符號(hào),如圖二所示:
圖二:匹配所有123-12-1234和123121234形式的社會(huì)安全號(hào)碼
下面我們?cè)賮砜戳硗庖粋€(gè)例子。美國(guó)汽車牌照的一種格式是四個(gè)數(shù)字加上二個(gè)字母。它的正則表達(dá)式前面是數(shù)字部分“[0-9]{4}”,再加上字母部分“[A-Z]{2}”。圖三顯示了完整的正則表達(dá)式。
圖三:匹配典型的美國(guó)汽車牌照號(hào)碼,如8836KV
1.5 “否”符號(hào)
“^”符號(hào)稱為“否”符號(hào)。如果用在方括號(hào)內(nèi),“^”表示不想要匹配的字符。例如,圖四的正則表達(dá)式匹配所有單詞,但以“X”字母開頭的單詞除外。
圖四:匹配所有單詞,但“X”開頭的除外
1.6 圓括號(hào)和空白符號(hào)
假設(shè)要從格式為“June 26, 1951”的生日日期中提取出月份部分,用來匹配該日期的正則表達(dá)式可以如圖五所示:
圖五:匹配所有Moth DD,YYYY格式的日期
新出現(xiàn)的“\s”符號(hào)是空白符號(hào),匹配所有的空白字符,包括Tab字符。如果字符串正確匹配,接下來如何提取出月份部分呢?只需在月份周圍加上一個(gè)圓括號(hào)創(chuàng)建一個(gè)組,然后用ORO API(本文后面詳細(xì)討論)提取出它的值。修改后的正則表達(dá)式如圖六所示:
圖六:匹配所有Month DD,YYYY格式的日期,定義月份值為第一個(gè)組
1.7 其它符號(hào)
為簡(jiǎn)便起見,你可以使用一些為常見正則表達(dá)式創(chuàng)建的快捷符號(hào)。如表二所示:
表二:常用符號(hào)
例如,在前面社會(huì)安全號(hào)碼的例子中,所有出現(xiàn)“[0-9]”的地方我們都可以使用“\d”。修改后的正則表達(dá)式如圖七所示:
圖七:匹配所有123-12-1234格式的社會(huì)安全號(hào)碼
二、Jakarta-ORO庫(kù)
有許多源代碼開放的正則表達(dá)式庫(kù)可供Java程序員使用,而且它們中的許多支持Perl 5兼容的正則表達(dá)式語(yǔ)法。我在這里選用的是Jakarta-ORO正則表達(dá)式庫(kù),它是最全面的正則表達(dá)式API之一,而且它與Perl 5正則表達(dá)式完全兼容。另外,它也是優(yōu)化得最好的API之一。
Jakarta-ORO庫(kù)以前叫做OROMatcher,Daniel Savarese大方地把它贈(zèng)送給了Jakarta Project。你可以按照本文最后參考資源的說明下載它。
我首先將簡(jiǎn)要介紹使用Jakarta-ORO庫(kù)時(shí)你必須創(chuàng)建和訪問的對(duì)象,然后介紹如何使用Jakarta-ORO API。
▲ PatternCompiler對(duì)象
首先,創(chuàng)建一個(gè)Perl5Compiler類的實(shí)例,并把它賦值給PatternCompiler接口對(duì)象。Perl5Compiler是PatternCompiler接口的一個(gè)實(shí)現(xiàn),允許你把正則表達(dá)式編譯成用來匹配的Pattern對(duì)象。
▲ Pattern對(duì)象
要把正則表達(dá)式編譯成Pattern對(duì)象,調(diào)用compiler對(duì)象的compile()方法,并在調(diào)用參數(shù)中指定正則表達(dá)式。例如,你可以按照下面這種方式編譯正則表達(dá)式“t[aeio]n”:
默認(rèn)情況下,編譯器創(chuàng)建一個(gè)大小寫敏感的模式(pattern)。因此,上面代碼編譯得到的模式只匹配“tin”、“tan”、 “ten”和“ton”,但不匹配“Tin”和“taN”。要?jiǎng)?chuàng)建一個(gè)大小寫不敏感的模式,你應(yīng)該在調(diào)用編譯器的時(shí)候指定一個(gè)額外的參數(shù):
創(chuàng)建好Pattern對(duì)象之后,你就可以通過PatternMatcher類用該P(yáng)attern對(duì)象進(jìn)行模式匹配。
▲ PatternMatcher對(duì)象
PatternMatcher對(duì)象根據(jù)Pattern對(duì)象和字符串進(jìn)行匹配檢查。你要實(shí)例化一個(gè)Perl5Matcher類并把結(jié)果賦值給PatternMatcher接口。Perl5Matcher類是PatternMatcher接口的一個(gè)實(shí)現(xiàn),它根據(jù)Perl 5正則表達(dá)式語(yǔ)法進(jìn)行模式匹配:
使用PatternMatcher對(duì)象,你可以用多個(gè)方法進(jìn)行匹配操作,這些方法的第一個(gè)參數(shù)都是需要根據(jù)正則表達(dá)式進(jìn)行匹配的字符串:
· boolean matches(String input, Pattern pattern):當(dāng)輸入字符串和正則表達(dá)式要精確匹配時(shí)使用。換句話說,正則表達(dá)式必須完整地描述輸入字符串。
· boolean matchesPrefix(String input, Pattern pattern):當(dāng)正則表達(dá)式匹配輸入字符串起始部分時(shí)使用。
· boolean contains(String input, Pattern pattern):當(dāng)正則表達(dá)式要匹配輸入字符串的一部分時(shí)使用(即,它必須是一個(gè)子串)。
另外,在上面三個(gè)方法調(diào)用中,你還可以用PatternMatcherInput對(duì)象作為參數(shù)替代String對(duì)象;這時(shí),你可以從字符串中最后一次匹配的位置開始繼續(xù)進(jìn)行匹配。當(dāng)字符串可能有多個(gè)子串匹配給定的正則表達(dá)式時(shí),用PatternMatcherInput對(duì)象作為參數(shù)就很有用了。用PatternMatcherInput對(duì)象作為參數(shù)替代String時(shí),上述三個(gè)方法的語(yǔ)法如下:
· boolean matches(PatternMatcherInput input, Pattern pattern)
· boolean matchesPrefix(PatternMatcherInput input, Pattern pattern)
· boolean contains(PatternMatcherInput input, Pattern pattern)
三、應(yīng)用實(shí)例
下面我們來看看Jakarta-ORO庫(kù)的一些應(yīng)用實(shí)例。
3.1 日志文件處理
任務(wù):分析一個(gè)Web服務(wù)器日志文件,確定每一個(gè)用戶花在網(wǎng)站上的時(shí)間。在典型的BEA WebLogic日志文件中,日志記錄的格式如下:
分析這個(gè)日志記錄,可以發(fā)現(xiàn),要從這個(gè)日志文件提取的內(nèi)容有兩項(xiàng):IP地址和頁(yè)面訪問時(shí)間。你可以用分組符號(hào)(圓括號(hào))從日志記錄提取出IP地址和時(shí)間標(biāo)記。
首先我們來看看IP地址。IP地址有4個(gè)字節(jié)構(gòu)成,每一個(gè)字節(jié)的值在0到255之間,各個(gè)字節(jié)通過一個(gè)句點(diǎn)分隔。因此,IP地址中的每一個(gè)字節(jié)有至少一個(gè)、最多三個(gè)數(shù)字。圖八顯示了為IP地址編寫的正則表達(dá)式:
圖八:匹配IP地址
IP地址中的句點(diǎn)字符必須進(jìn)行轉(zhuǎn)義處理(前面加上“\”),因?yàn)镮P地址中的句點(diǎn)具有它本來的含義,而不是采用正則表達(dá)式語(yǔ)法中的特殊含義。句點(diǎn)在正則表達(dá)式中的特殊含義本文前面已經(jīng)介紹。
日志記錄的時(shí)間部分由一對(duì)方括號(hào)包圍。你可以按照如下思路提取出方括號(hào)里面的所有內(nèi)容:首先搜索起始方括號(hào)字符(“[”),提取出所有不超過結(jié)束方括號(hào)字符(“]”)的內(nèi)容,向前尋找直至找到結(jié)束方括號(hào)字符。圖九顯示了這部分的正則表達(dá)式。
圖九:匹配至少一個(gè)字符,直至找到“]”
現(xiàn)在,把上述兩個(gè)正則表達(dá)式加上分組符號(hào)(圓括號(hào))后合并成單個(gè)表達(dá)式,這樣就可以從日志記錄提取出IP地址和時(shí)間。注意,為了匹配“- -”(但不提取它),正則表達(dá)式中間加入了“\s-\s-\s”。完整的正則表達(dá)式如圖十所示。
圖十:匹配IP地址和時(shí)間標(biāo)記
現(xiàn)在正則表達(dá)式已經(jīng)編寫完畢,接下來可以編寫使用正則表達(dá)式庫(kù)的Java代碼了。
為使用Jakarta-ORO庫(kù),首先創(chuàng)建正則表達(dá)式字符串和待分析的日志記錄字符串:
這里使用的正則表達(dá)式與圖十的正則表達(dá)式差不多完全相同,但有一點(diǎn)例外:在Java中,你必須對(duì)每一個(gè)向前的斜杠(“\”)進(jìn)行轉(zhuǎn)義處理。圖十不是Java的表示形式,所以我們要在每個(gè)“\”前面加上一個(gè)“\”以免出現(xiàn)編譯錯(cuò)誤。遺憾的是,轉(zhuǎn)義處理過程很容易出現(xiàn)錯(cuò)誤,所以應(yīng)該小心謹(jǐn)慎。你可以首先輸入未經(jīng)轉(zhuǎn)義處理的正則表達(dá)式,然后從左到右依次把每一個(gè)“\”替換成“\\”。如果要復(fù)檢,你可以試著把它輸出到屏幕上。
初始化字符串之后,實(shí)例化PatternCompiler對(duì)象,用PatternCompiler編譯正則表達(dá)式創(chuàng)建一個(gè)Pattern對(duì)象:
現(xiàn)在,創(chuàng)建PatternMatcher對(duì)象,調(diào)用PatternMatcher接口的contain()方法檢查匹配情況:
接下來,利用PatternMatcher接口返回的MatchResult對(duì)象,輸出匹配的組。由于logEntry字符串包含匹配的內(nèi)容,你可以看到類如下面的輸出:
3.2 HTML處理實(shí)例一
下面一個(gè)任務(wù)是分析HTML頁(yè)面內(nèi)FONT標(biāo)記的所有屬性。HTML頁(yè)面內(nèi)典型的FONT標(biāo)記如下所示:
程序?qū)凑杖缦滦问?,輸出每一個(gè)FONT標(biāo)記的屬性:
在這種情況下,我建議你使用兩個(gè)正則表達(dá)式。第一個(gè)如圖十一所示,它從字體標(biāo)記提取出“"face="Arial, Serif" size="+2" color="red"”。
圖十一:匹配FONT標(biāo)記的所有屬性
第二個(gè)正則表達(dá)式如圖十二所示,它把各個(gè)屬性分割成名字-值對(duì)。
圖十二:匹配單個(gè)屬性,并把它分割成名字-值對(duì)
分割結(jié)果為:
現(xiàn)在我們來看看完成這個(gè)任務(wù)的Java代碼。首先創(chuàng)建兩個(gè)正則表達(dá)式字符串,用Perl5Compiler把它們編譯成Pattern對(duì)象。編譯正則表達(dá)式的時(shí)候,指定Perl5Compiler.CASE_INSENSITIVE_MASK選項(xiàng),使得匹配操作不區(qū)分大小寫。
接下來,創(chuàng)建一個(gè)執(zhí)行匹配操作的Perl5Matcher對(duì)象。
假設(shè)有一個(gè)String類型的變量html,它代表了HTML文件中的一行內(nèi)容。如果html字符串包含F(xiàn)ONT標(biāo)記,匹配器將返回true。此時(shí),你可以用匹配器對(duì)象返回的MatchResult對(duì)象獲得第一個(gè)組,它包含了FONT的所有屬性:
接下來創(chuàng)建一個(gè)PatternMatcherInput對(duì)象。這個(gè)對(duì)象允許你從最后一次匹配的位置開始繼續(xù)進(jìn)行匹配操作,因此,它很適合于提取FONT標(biāo)記內(nèi)屬性的名字-值對(duì)。創(chuàng)建PatternMatcherInput對(duì)象,以參數(shù)形式傳入待匹配的字符串。然后,用匹配器實(shí)例提取出每一個(gè)FONT的屬性。這通過指定PatternMatcherInput對(duì)象(而不是字符串對(duì)象)為參數(shù),反復(fù)地調(diào)用PatternMatcher對(duì)象的contains()方法完成。PatternMatcherInput對(duì)象之中的每一次迭代將把它內(nèi)部的指針向前移動(dòng),下一次檢測(cè)將從前一次匹配位置的后面開始。
本例的輸出結(jié)果如下:
3.3 HTML處理實(shí)例二
下面我們來看看另一個(gè)處理HTML的例子。這一次,我們假定Web服務(wù)器從widgets.acme.com移到了newserver.acme.com。現(xiàn)在你要修改一些頁(yè)面中的鏈接:
執(zhí)行這個(gè)搜索的正則表達(dá)式如圖十三所示:
圖十三:匹配修改前的鏈接
如果能夠匹配這個(gè)正則表達(dá)式,你可以用下面的內(nèi)容替換圖十三的鏈接:
注意#字符的后面加上了$1。Perl正則表達(dá)式語(yǔ)法用$1、$2等表示已經(jīng)匹配且提取出來的組。圖十三的表達(dá)式把所有作為一個(gè)組匹配和提取出來的內(nèi)容附加到鏈接的后面。
現(xiàn)在,返回Java。就象前面我們所做的那樣,你必須創(chuàng)建測(cè)試字符串,創(chuàng)建把正則表達(dá)式編譯到Pattern對(duì)象所必需的對(duì)象,以及創(chuàng)建一個(gè)PatternMatcher對(duì)象:
接下來,用com.oroinc.text.regex包Util類的substitute()靜態(tài)方法進(jìn)行替換,輸出結(jié)果字符串:
Util.substitute()方法的語(yǔ)法如下:
這個(gè)調(diào)用的前兩個(gè)參數(shù)是以前創(chuàng)建的PatternMatcher和Pattern對(duì)象。第三個(gè)參數(shù)是一個(gè)Substiution對(duì)象,它決定了替換操作如何進(jìn)行。本例使用的是Perl5Substitution對(duì)象,它能夠進(jìn)行Perl5風(fēng)格的替換。第四個(gè)參數(shù)是想要進(jìn)行替換操作的字符串,最后一個(gè)參數(shù)允許指定是否替換模式的所有匹配子串(Util.SUBSTITUTE_ALL),或只替換指定的次數(shù)。
【結(jié)束語(yǔ)】在這篇文章中,我為你介紹了正則表達(dá)式的強(qiáng)大功能。只要正確運(yùn)用,正則表達(dá)式能夠在字符串提取和文本修改中起到很大的作用。另外,我還介紹了如何在Java程序中通過Jakarta-ORO庫(kù)利用正則表達(dá)式。至于最終采用老式的字符串處理方式(使用StringTokenizer,charAt,和substring),還是采用正則表達(dá)式,這就有待你自己決定了
入門簡(jiǎn)介
簡(jiǎn)單的說,正則表達(dá)式是一種可以用于模式匹配和替換的強(qiáng)有力的工具。我們可以在幾乎所有的基于UNIX系統(tǒng)的工具中找到正則表達(dá)式的身影,例如,vi編輯器,Perl或PHP腳本語(yǔ)言,以及awk或sed shell程序等。此外,象JavaScript這種客戶端的腳本語(yǔ)言也提供了對(duì)正則表達(dá)式的支持。由此可見,正則表達(dá)式已經(jīng)超出了某種語(yǔ)言或某個(gè)系統(tǒng)的局限,成為人們廣為接受的概念和功能。
正則表達(dá)式可以讓用戶通過使用一系列的特殊字符構(gòu)建匹配模式,然后把匹配模式與數(shù)據(jù)文件、程序輸入以及WEB頁(yè)面的表單輸入等目標(biāo)對(duì)象進(jìn)行比較,根據(jù)比較對(duì)象中是否包含匹配模式,執(zhí)行相應(yīng)的程序。
舉例來說,正則表達(dá)式的一個(gè)最為普遍的應(yīng)用就是用于驗(yàn)證用戶在線輸入的郵件地址的格式是否正確。如果通過正則表達(dá)式驗(yàn)證用戶郵件地址的格式正確,用戶所填寫的表單信息將會(huì)被正常處理;反之,如果用戶輸入的郵件地址與正則表達(dá)的模式不匹配,將會(huì)彈出提示信息,要求用戶重新輸入正確的郵件地址。由此可見正則表達(dá)式在WEB應(yīng)用的邏輯判斷中具有舉足輕重的作用。
基本語(yǔ)法
在對(duì)正則表達(dá)式的功能和作用有了初步的了解之后,我們就來具體看一下正則表達(dá)式的語(yǔ)法格式。
正則表達(dá)式的形式一般如下:
/love/
其中位于“/”定界符之間的部分就是將要在目標(biāo)對(duì)象中進(jìn)行匹配的模式。用戶只要把希望查找匹配對(duì)象的模式內(nèi)容放入“/”定界符之間即可。為了能夠使用戶更加靈活的定制模式內(nèi)容,正則表達(dá)式提供了專門的“元字符”。所謂元字符就是指那些在正則表達(dá)式中具有特殊意義的專用字符,可以用來規(guī)定其前導(dǎo)字符(即位于元字符前面的字符)在目標(biāo)對(duì)象中的出現(xiàn)模式。
較為常用的元字符包括: “+”, “*”,以及 “?”。其中,“+”元字符規(guī)定其前導(dǎo)字符必須在目標(biāo)對(duì)象? 續(xù)出現(xiàn)一次或多次,“*”元字符規(guī)定其前導(dǎo)字符必須在目標(biāo)對(duì)象中出現(xiàn)零次或連續(xù)多次,而“?”元字符規(guī)定其前導(dǎo)對(duì)象必須在目標(biāo)對(duì)象中連續(xù)出現(xiàn)零次或一次。
下面,就讓我們來看一下正則表達(dá)式元字符的具體應(yīng)用。
/fo+/
因?yàn)樯鲜稣齽t表達(dá)式中包含“+”元字符,表示可以與目標(biāo)對(duì)象中的 “fool”, “fo”, 或者 “football”等在字母f后面連續(xù)出現(xiàn)一個(gè)或多個(gè)字母o的字符串相匹配。
/eg*/
因?yàn)樯鲜稣齽t表達(dá)式中包含“*”元字符,表示可以與目標(biāo)對(duì)象中的 “easy”, “ego”, 或者 “egg”等在字母e后面連續(xù)出現(xiàn)零個(gè)或多個(gè)字母g的字符串相匹配。
/Wil?/
因?yàn)樯鲜稣齽t表達(dá)式中包含“?”元字符,表示可以與目標(biāo)對(duì)象中的 “Win”, 或者 “Wilson”,等在字母i后面連續(xù)出現(xiàn)零個(gè)或一個(gè)字母l的字符串相匹配。
除了元字符之外,用戶還可以精確指定模式在匹配對(duì)象中出現(xiàn)的頻率。例如,
/jim{2,6}/
上述正則表達(dá)式規(guī)定字符m可以在匹配對(duì)象中連續(xù)出現(xiàn)2-6次,因此,上述正則表達(dá)式可以同jimmy或jimmmmmy等字符串相匹配。
在對(duì)如何使用正則表達(dá)式有了初步了解之后,我們來看一下其它幾個(gè)重要的元字符的使用方式。
\s:用于匹配單個(gè)空格符,包括tab鍵和換行符;
\S:用于匹配除單個(gè)空格符之外的所有字符;
\d:用于匹配從0到9的數(shù)字;
\w:用于匹配字母,數(shù)字或下劃線字符;
\W:用于匹配所有與\w不匹配的字符;
. :用于匹配除換行符之外的所有字符。
?。ㄕf明:我們可以把\s和\S以及\w和\W看作互為逆運(yùn)算)
下面,我們就通過實(shí)例看一下如何在正則表達(dá)式中使用上述元字符。
/\s+/
上述正則表達(dá)式可以用于匹配目標(biāo)對(duì)象中的一個(gè)或多個(gè)空格字符。
/\d000/
如果我們手中有一份復(fù)雜的財(cái)務(wù)報(bào)表,那么我們可以通過上述正則表達(dá)式輕而易舉的查找到所有總額達(dá)千元的款項(xiàng)。
除了我們以上所介紹的元字符之外,正則表達(dá)式中還具有另外一種較為獨(dú)特的專用字符,即定位符。定位符用于規(guī)定匹配模式在目標(biāo)對(duì)象中的出現(xiàn)位置。
較為常用的定位符包括: “^”, “$”, “\b” 以及 “\B”。其中,“^”定位符規(guī)定匹配模式必須出現(xiàn)在目標(biāo)字符串的開頭,“$”定位符規(guī)定匹配模式必須出現(xiàn)在目標(biāo)對(duì)象的結(jié)尾,\b定位符規(guī)定匹配模式必須出現(xiàn)在目標(biāo)字符串的開頭或結(jié)尾的兩個(gè)邊界之一,而“\B”定位符則規(guī)定匹配對(duì)象必須位于目標(biāo)字符串的開頭和結(jié)尾兩個(gè)邊界之內(nèi),即匹配對(duì)象既不能作為目標(biāo)字符串的開頭,也不能作為目標(biāo)字符串的結(jié)尾。同樣,我們也可以把“^”和“$”以及“\b”和“\B”看作是互為逆運(yùn)算的兩組定位符。舉例來說:
/^hell/
因?yàn)樯鲜稣齽t表達(dá)式中包含“^”定位符,所以可以與目標(biāo)對(duì)象中以 “hell”, “hello”或 “hellhound”開頭的字符串相匹配。
/ar$/
因?yàn)樯鲜稣齽t表達(dá)式中包含“$”定位符,所以可以與目標(biāo)對(duì)象中以 “car”, “bar”或 “ar” 結(jié)尾的字符串相匹配。
/\bbom/
因?yàn)樯鲜稣齽t表達(dá)式模式以“\b”定位符開頭,所以可以與目標(biāo)對(duì)象中以 “bomb”, 或 “bom”開頭的字符串相匹配。
/man\b/
因?yàn)樯鲜稣齽t表達(dá)式模式以“\b”定位符結(jié)尾,所以可以與目標(biāo)對(duì)象中以 “human”, “woman”或 “man”結(jié)尾的字符串相匹配。
為了能夠方便用戶更加靈活的設(shè)定匹配模式,正則表達(dá)式允許使用者在匹配模式中指定某一個(gè)范圍而不局限于具體的字符。例如:
/[A-Z]/
上述正則表達(dá)式將會(huì)與從A到Z范圍內(nèi)任何一個(gè)大寫字母相匹配。
/[a-z]/
上述正則表達(dá)式將會(huì)與從a到z范圍內(nèi)任何一個(gè)小寫字母相匹配。
/[0-9]/
上述正則表達(dá)式將會(huì)與從0到9范圍內(nèi)任何一個(gè)數(shù)字相匹配。
/([a-z][A-Z][0-9])+/
上述正則表達(dá)式將會(huì)與任何由字母和數(shù)字組成的字符串,如 “aB0” 等相匹配。這里需要提醒用戶注意的一點(diǎn)就是可以在正則表達(dá)式中使用 “()” 把字符串組合在一起。“()”符號(hào)包含的內(nèi)容必須同時(shí)出現(xiàn)在目標(biāo)對(duì)象中。因此,上述正則表達(dá)式將無法與諸如 “abc”等的字符串匹配,因?yàn)?#8220;abc”中的最后一個(gè)字符為字母而非數(shù)字。
如果我們希望在正則表達(dá)式中實(shí)現(xiàn)類似編程邏輯中的“或”運(yùn)算,在多個(gè)不同的模式中任選一個(gè)進(jìn)行匹配的話,可以使用管道符 “|”。例如:
/to|too|2/
上述正則表達(dá)式將會(huì)與目標(biāo)對(duì)象中的 “to”, “too”, 或 “2” 相匹配。
正則表達(dá)式中還有一個(gè)較為常用的運(yùn)算符,即否定符 “[^]”。與我們前文所介紹的定位符 “^” 不同,否定符 “[^]”規(guī)定目標(biāo)對(duì)象中不能存在模式中所規(guī)定的字符串。例如:
/[^A-C]/
上述字符串將會(huì)與目標(biāo)對(duì)象中除A,B,和C之外的任何字符相匹配。一般來說,當(dāng)“^”出現(xiàn)在 “[]”內(nèi)時(shí)就被視做否定運(yùn)算符;而當(dāng)“^”位于“[]”之外,或沒有“[]”時(shí),則應(yīng)當(dāng)被視做定位符。
最后,當(dāng)用戶需要在正則表達(dá)式的模式中加入元字符,并查找其匹配對(duì)象時(shí),可以使用轉(zhuǎn)義符“\”。例如:
/Th\*/
上述正則表達(dá)式將會(huì)與目標(biāo)對(duì)象中的“Th*”而非“The”等相匹配。
public String[] split(String regex)
該方法的作用就像是使用給定的表達(dá)式和限制參數(shù) 0 來調(diào)用兩參數(shù) split
方法。因此,結(jié)果數(shù)組中不包括結(jié)尾空字符串。
例如,字符串 "boo:and:foo" 產(chǎn)生帶有下面這些表達(dá)式的結(jié)果:
Regex 結(jié)果 : { "boo", "and", "foo" } o { "b", "", ":and:f" }
regex
- 定界正則表達(dá)式
PatternSyntaxException
- 如果正則表達(dá)式的語(yǔ)法無效public String[] split(String regex, int limit)
此方法返回的數(shù)組包含此字符串的每個(gè)子字符串,這些子字符串由另一個(gè)匹配給定的表達(dá)式的子字符串終止或由字符串結(jié)束來終止。數(shù)組中的子字符串按它們?cè)诖俗址械捻樞蚺帕小H绻磉_(dá)式不匹配輸入的任何部分,則結(jié)果數(shù)組只具有一個(gè)元素,即此字符串。
limit 參數(shù)控制模式應(yīng)用的次數(shù),因此影響結(jié)果數(shù)組的長(zhǎng)度。如果該限制 n 大于 0,則模式將被最多應(yīng)用 n - 1 次,數(shù)組的長(zhǎng)度將不會(huì)大于 n,而且數(shù)組的最后項(xiàng)將包含超出最后匹配的定界符的所有輸入。如果 n 為非正,則模式將被應(yīng)用盡可能多的次數(shù),而且數(shù)組可以是任意長(zhǎng)度。如果 n 為零,則模式將被應(yīng)用盡可能多的次數(shù),數(shù)組可有任何長(zhǎng)度,并且結(jié)尾空字符串將被丟棄。
例如,字符串 "boo:and:foo" 使用這些參數(shù)可生成下列結(jié)果:
Regex Limit 結(jié)果 : 2 { "boo", "and:foo" } : 5 { "boo", "and", "foo" } : -2 { "boo", "and", "foo" } o 5 { "b", "", ":and:f", "", "" } o -2 { "b", "", ":and:f", "", "" } o 0 { "b", "", ":and:f" }
這種形式的方法調(diào)用 str.split(regex, n) 產(chǎn)生與以下表達(dá)式完全相同的結(jié)果:
Pattern
.compile
(regex).split
(str, n)
參數(shù): regex
- 定界正則表達(dá)式 ;limit
- 結(jié)果閾值,如上所述
public String replaceAll(String regex, String replacement)
此方法調(diào)用的 str.replaceAll(regex, repl) 形式產(chǎn)生與以下表達(dá)式完全相同的結(jié)果:
Pattern
.compile
(regex).matcher
(str).replaceAll
(repl)
參數(shù): regex
- 用來匹配此字符串的正則表達(dá)式
public String replaceFirst(String regex, String replacement)
此方法調(diào)用的 str.replaceFirst(regex, repl) 形式產(chǎn)生與以下表達(dá)式完全相同的結(jié)果:
Pattern
.compile
(regex).matcher
(str).replaceFirst
(repl)
參數(shù):regex
- 用來匹配此字符串的正則表達(dá)式
這四個(gè)方法中都有一個(gè)參數(shù)為正則表達(dá)式(Regular Expression),而不是普通的字符串。
特殊字符 |
描述 |
. | 表示任意一個(gè)字符 |
[abc] | 表示a、b或c中的任意一個(gè)字符 |
[^abc] | 除a、b和c以外的任意一個(gè)字符 |
[a-zA-z] | 介于a到z,或A到Z中的任意一個(gè)字符 |
\s | 空白符(空格、tab、換行、換頁(yè)、回車) |
\S | 非空白符 |
\d | 任意一個(gè)數(shù)字[0-9] |
\D | 任意一個(gè)非數(shù)字[^0-9] |
\w | 詞字符[a-zA-Z_0-9] |
\W | 非詞字符 |
表示次數(shù)的符號(hào) |
描述 |
* | 0 次或者多次 |
+ | 1 次或者多次 |
? | 0 次或者 1 次 |
{n} | 恰好 n 次 |
{n, m} | 至少 n 次,不多于 m 次 |
public interface MatchResult
匹配操作的結(jié)果。
此接口包含用于確定與正則表達(dá)式匹配結(jié)果的查詢方法。通過 MatchResult
可以查看匹配邊界、組和組邊界,但是不能修改
public final class Matcher
通過解釋 Pattern
對(duì) 字符序列
執(zhí)行匹配操作的引擎。
通過調(diào)用模式的 matcher
方法從模式創(chuàng)建匹配器。創(chuàng)建匹配器后,可以使用它執(zhí)行三種不同的匹配操作:
每個(gè)方法都返回一個(gè)表示成功或失敗的布爾值。通過查詢匹配器的狀態(tài)可以獲取關(guān)于成功匹配的更多信息。
public final class Pattern
正則表達(dá)式的編譯表示形式。
指定為字符串的正則表達(dá)式必須首先被編譯為此類的實(shí)例。然后,可將得到的模式用于創(chuàng)建 Matcher
對(duì)象,依照正則表達(dá)式,該對(duì)象可以與任意字符序列
匹配。執(zhí)行匹配所涉及的所有狀態(tài)都駐留在匹配器中,所以多個(gè)匹配器可以共享同一模式。
因此,典型的調(diào)用順序是
Pattern p = Pattern.matches
();
在僅使用一次正則表達(dá)式時(shí),可以方便地通過此類定義 matches
方法。此方法編譯表達(dá)式并在單個(gè)調(diào)用中將輸入序列與其匹配。語(yǔ)句
boolean b = Pattern.matches("a*b", "aaaaab");
等效于上面的三個(gè)語(yǔ)句,盡管對(duì)于重復(fù)的匹配而言它效率不高,因?yàn)樗辉试S重用已編譯的模式。
此類的實(shí)例是不可變的,可供多個(gè)并發(fā)線程安全使用。Matcher
類的實(shí)例用于此目的則不安全。
測(cè)試代碼:
Java 關(guān)鍵字 final 用來表示常量數(shù)據(jù)。例如:
這段代碼聲明了一個(gè) static 類變量,命名為 someInt,并設(shè)其初值為10。
任何試圖修改 someInt 的代碼都將無法通過編譯。例如:
關(guān)鍵字 final 可防止 classes 內(nèi)的 instance 數(shù)據(jù)遭到無意間的修改。如果我們想要一個(gè)常量對(duì)象,又該如何呢?例如:
這段代碼的輸出是:
在上述第一個(gè)示例中,我們企圖改變final 數(shù)據(jù)值時(shí),編譯器會(huì)偵測(cè)出錯(cuò)誤。
在第二個(gè)示例中,雖然代碼改變了 instance變量wheel的值,編譯器還是讓它通過了。我們已經(jīng)明確聲明wheel為final,它怎么還能被改變呢?
不,我們確實(shí)沒有改變 wheel 的值,我們改變的是wheel 所指對(duì)象的值。wheel 并無變化,仍然指向(代表)同一個(gè)對(duì)象。變量wheel是一個(gè) object reference,它指向?qū)ο笏诘膆eap位置。有鑒如此,下面的代碼會(huì)怎樣?
編譯代碼,// 1 處出錯(cuò)。由于我們企圖改變 final 型變量 wheel 的值,所以這個(gè)示例將產(chǎn)生編譯錯(cuò)誤。換言之,代碼企圖令wheel指向其他對(duì)象。變量wheel是final,因此也是不可變的。它必須永遠(yuǎn)指向同一個(gè)對(duì)象。然而wheel所指向的對(duì)象并不受關(guān)鍵字final的影響,因此是可變的。
關(guān)鍵字 final 只能防止變量值的改變。如果被聲明為 final 的變量是個(gè) object reference,那么該reference不能被改變,必須永遠(yuǎn)指向同一個(gè)對(duì)象,但被指的那個(gè)對(duì)象可以隨意改變內(nèi)部的屬性值。
array和Vector的比較
|
支持基本類型 |
支持對(duì)象 |
自動(dòng)改變大小 |
速度快 |
array |
Yes |
Yes |
No |
Yes |
Vector |
No(1.5以上支持) |
Yes |
Yes |
No |
代碼1:instanceof方式