WEB开发网      婵犵數濮烽弫鍛婃叏閻戣棄鏋侀柛娑橈攻閸欏繘鏌i幋锝嗩棄闁哄绶氶弻娑樷槈濮楀牊鏁鹃梺鍛婄懃缁绘﹢寮婚敐澶婄闁挎繂妫Λ鍕⒑閸濆嫷鍎庣紒鑸靛哺瀵鈽夊Ο閿嬵潔濠殿喗顨呴悧鍡樻叏濞戞氨纾藉ù锝呮惈閳诲牏绱掗悩宕囧⒌鐎殿喛顕ч濂稿醇椤愶綆鈧洭姊绘担鍛婂暈闁规瓕顕ч~婵嬪Ω閳轰胶顔夐梺闈涚箳婵厼危閸喓绠鹃柛鈩兠慨鍥ㄣ亜鎼淬垺宕屾慨濠冩そ瀹曘劍绻濋崒姘兼綋闁诲孩顔栭崰鏍偉婵傚摜宓侀柡宥庡幖缁犳稒銇勯弮鍌氫壕闁挎稑绻樺娲川婵犲啫鐦烽梺鍛婃处閸嬪懘鎮鹃鍕拻濞达絽鎽滈弸鍐┿亜椤愩埄妯€鐎规洖缍婂畷绋课旈埀顒傜不閺嶎厽鐓冮柛婵嗗閺嗗﹪鏌涚€n偅宕岀€规洜鍏橀、姗€鎮欓幇鈺佺仾闁靛洤瀚版俊鐑芥晜閸撗呮澖婵犳鍠栭敃銈夊箹椤愶絾娅忛梻浣规偠閸庢粓鍩€椤掑嫬纾婚柟鐐窞閺冨牆宸濇い鎾跺缁遍亶姊绘担绛嬫綈鐎规洘锕㈤、姘愁槼妞ゃ垹锕缁樻媴閸涘﹤鏆堝┑鐐额嚋缁犳挸鐣疯ぐ鎺戠妞ゆ柨褰炵粭澶娾攽閻愭潙鐏熼柛銊︽そ閹繝寮撮悢缈犵盎闂佽婢樻晶搴g矙閼姐倗纾奸柍褜鍓熷畷姗€鍩炴径鍝ョ泿闂佺澹堥幓顏嗘閺囩喐娅忓┑鐘愁問閸犳牠鏁冮妸銉㈡瀺闁挎繂娲ら崹婵囩箾閸℃绠氶柡瀣叄閺岀喖顢涢崱妤€鏆欐い銉﹀姍濮婂宕掑▎鎴М闂佺濮ょ划宥夊箞閵娾晜鍋ㄧ紒瀣硶椤︻喖鈹戦悙鍙夘棡闁告梹甯為幑銏ゅ幢濞戞瑧鍘介梺闈涚箚閹虫岸宕烽鐘电劶闁诲函缍嗛崑浣圭濠婂牊鐓涚€广儱鍟慨鈧繝銏n潐閿曘垽寮诲☉銏″€锋い蹇撳椤洤鈹戦纭锋敾婵$偠妫勮灋闁告劦鐓佽ぐ鎺懳ч柛鈩冪憿婵洭姊洪悷鏉挎Щ闁硅櫕锕㈤悰顕€骞樼拠鑼唺閻庡箍鍎遍幏瀣涘⿰鍫熲拻闁稿本鐟чˇ锔界節閳ь剟鏌嗗鍛紵闂侀潧鐗嗛ˇ顓㈠焵椤掆偓閸熸潙鐣烽崡鐐╂婵☆垳鍘ч獮鍫ユ⒒娴e憡璐¢柛搴涘€濋妴鍐幢濞戞瑥浜楅梺鍝勬储閸ㄦ椽鎮″☉銏$厱闁靛绲介崝姘攽閿涘嫬甯堕棁澶嬬節婵犲倸顏柣顓烆儔閺屾洟宕惰椤忣剛绱掗悩宕囨创闁轰焦鍔欏畷銊╊敇閻樺灚缍侀梻鍌氬€风粈渚€骞栭锝呯窞闁搞儺鍓欓悞鍨亜閹哄棗浜剧紒鍓ц檸閸欏啫顕i幎钘夊耿婵炴垶鐟ラ埀顒傛暬閺屻劌鈹戦崱娑扁偓妤€顭胯閸楁娊寮婚敓鐘插耿婵炲棗绻嗛弸鍛存⒑閸濆嫮娼ら柛鏇ㄥ亽閸ゃ倕鈹戦悙鍙夘棡闁搞劎鏁诲畷鍝勭暆閸曨兘鎷洪梻鍌氱墛缁嬫帡藟閻愮儤鍋ㄦい鏍ㄧ☉濞搭噣鏌ㄥ┑鍫濅粶闁宠鍨归埀顒婄秵閸嬪嫭绂嶅Δ鍛厵闁煎湱澧楄ぐ褏绱掗幓鎺嬪仮闁诡喕绮欓幊锟犲Χ閸モ晪绱冲┑鐐舵彧缂嶁偓妞ゆ洘鐗曢埢鎾诲即閵忥紕鍘遍梺闈浨归崕铏閵徛颁簻妞ゆ劑鍨荤粻宕囩磼鏉堛劌绗掗摶锝夋偣閸パ勨枙闁逞屽墯閹稿墽妲愰幘瀛樺闁革富鍘稿Σ鍫濐渻閵堝棗鐏ラ柟鍐查叄閸┿垽骞樺ú缁樻櫍闂佺粯鍔忛弲婊堝棘閳ь剚淇婇悙顏勨偓鏍ь潖瑜版帒鍑犲┑鐘宠壘缁€鍌涖亜閹烘垵鈧崵澹曟總鍛婄厽婵☆垱瀵ч悵顏嗏偓瑙勬礀閻倿寮婚弴銏犲耿闁哄洨濯Σ顔碱渻閵堝骸浜濈紒璇茬墦閻涱噣宕堕妸锕€顎撻梺绋跨箰椤︿即鎮楅崨濠勭瘈闁汇垽娼у暩闂佽桨绀侀幉锟犲箞閵娾晩鏁囬柕蹇曞Х閿涙盯姊虹憴鍕缂佸鍠涢妵鎰板箳閹惧瓨鐝抽梻浣规偠閸庮噣寮崒鐐茬劦妞ゆ巻鍋撻柨鏇ㄤ邯瀵鏁撻悩鑼姦濡炪倖甯婇懗鍫曘€呴悜鑺ュ€甸柨婵嗛娴滅偤鏌涘Ο鎸庮棄闁宠鍨块崺銉╁幢濡ゅ啩鐢绘俊鐐€栭崹鍫曟偡閳轰胶鏆﹂柣銏㈩暯閸嬫捇鏁愭惔鈥冲箣闂佺ǹ顑嗛幐楣冨箟閹绢喖绀嬫い鎺嗗亾濞寸姭鏅犲铏圭矙閹稿骸鏀紓渚囧櫍缁犳牠骞冨鈧畷姗€顢欑憴锝嗗缂傚倸鍊烽悞锕傚煟閵堝鏁傞柛鏇㈡涧濞堛劑姊洪崜鎻掍簼婵炲弶鐗犻幃鍧楊敋閳ь剟寮婚敐澶婄疀妞ゆ棁濮ゅВ鍕磼閻愵剙鍔ら柕鍫熸倐瀵鈽夊顐e媰闂佺粯鍔﹂崜娑樷枔閵堝鐓涘ù锝呮憸婢э箓鏌熼绛嬫畼闁瑰弶鎸冲畷鐔碱敆閸屻倖袨缂傚倸鍊风欢锟犲窗閺嶎偅宕叉俊顖涘椤ャ倝姊虹拠鏌ュ弰婵炰匠鍥х婵犲﹤鍚樺☉銏╂晬闁绘劕顕崢闈涱渻閵堝棛澧俊顐f⒒缁牊鎷呴崷顓ф祫濡炪倖娲嶉崑鎾绘煙椤旂瓔娈旈柍缁樻崌瀹曞綊顢欓悾灞奸偗闂傚倷鑳剁划顖炴偋濠婂牆鍌ㄧ憸鏃堝箖妤e啯鍊婚柤鎭掑劚娴滄鏌熼悡搴f憼閽冭鲸銇勯銏⑿㈤柍瑙勫灴閸┿儵宕卞Δ鍐ф埛闂佽崵濮崑鎾绘煥閺囩偛鈧綊宕愰悽纰樺亾鐟欏嫭绀€婵炲眰鍔庢竟鏇熺鐎n偆鍘遍柣蹇曞仜婢т粙骞婇崨瀛樼厱闁哄倽娉曟牎闂侀潧娲ょ€氱増淇婇幖浣肝ㄩ柨鏃傜帛椤ワ綁姊绘担椋庝覆缂佹彃澧介幑銏ゅ醇閵壯冪ウ闂佸搫绉查崝宥嗗垔鐎涙ɑ鍙忔繝闈涙濠€浼存煙闊厼宓嗘慨濠勭帛閹峰懘鎼归悷鎵偧婵犵妲呴崑鍕疮绾惧锛傞梻浣筋潐瀹曟﹢顢氳鏁堥柡灞诲劜閸婄敻鏌ㄥ┑鍡涱€楅柡瀣枛閺岋綁骞樼捄鐑樼€炬繛锝呮搐閿曨亝淇婇崼鏇炵<婵﹩鍋勯ˉ姘舵⒒閸屾瑨鍏岀紒顕呭灦閵嗗啴宕ㄩ鍥ㄧ☉铻栭柛娑卞幘閸樻椽姊洪崷顓炰壕缂佸墎鍋ゅ顕€宕煎┑鍡欑崺婵$偑鍊栧Λ渚€锝炴径灞稿亾濮橆兙鍋㈡慨濠冩そ閹筹繝濡堕崨鍛灪缁绘盯鎳犻鈧埢鍫ユ煕閳规儳浜炬俊鐐€栫敮鎺楀疮椤栫偞鍋熸い蹇撶墛閻撶喖鐓崶褝宸ュù婊堢畺濮婂宕掑顑藉亾妞嬪海鐭嗗〒姘e亾妤犵偞鐗犻、鏇㈡晝閳ь剛绮婚悩缁樼厵闂侇叏绠戦獮妤呮煕濞嗗繒绠婚柡宀€鍠撶槐鎺楀閻樺磭浜堕梻浣呵归鍌炲疾閻樿钃熼柨婵嗩槸鍥撮柟鑹版彧缁辨洘绂掑⿰鍕閻庢稒岣块惌濠勭磽瀹ュ拑韬€殿喖顭烽幃銏ゅ礂閻撳簶鍋撶紒妯圭箚妞ゆ牗绻傛禍褰掓煟閿濆棙銇濇慨濠冩そ瀹曨偊宕熼鈧▍銈囩磽娴g瓔鍤欓柣妤€妫濋敐鐐剁疀閹句焦妞介、鏃堝椽娴h妫冨┑鐘垫暩閸嬬偤宕归崼鏇熷殞濡わ絽鍟ㄩ埀顒€鍊垮畷顐﹀礋閵婏附鏉搁梻浣哥枃濡嫬螞濡や胶顩叉繝闈涱儐閻撶喖鏌i弬鍨骇婵炲懎锕弻鏇㈠幢閺囩媭妲梺瀹狀嚙闁帮綁鐛幒妤€绫嶉柛灞剧⊕缁额偊姊婚崒娆戭槮闁圭⒈鍋婂畷顖烆敃閿曗偓绾剧懓鈹戦悩宕囶暡闁稿骸锕弻娑㈩敃閻樻彃濮曢梺鎶芥敱閸ㄥ爼骞堥妸鈺傚仭闁绘鐗婇幃娆撴⒑鐠囪尙绠扮€殿喖澧庨幑銏犫槈濞嗘劕顎撻梺鍛婂姈瑜板啴顢旈锝冧簻闁冲搫鍟崢鎾煛鐏炶濮傜€殿喗鎸抽幃娆徝圭€n亙澹曢悷婊呭鐢宕戦崒鐐寸厸闁搞儯鍎遍悘顏堟煟閹惧磭绠伴柍瑙勫灴閹瑩鎳犻鑳闂備礁鎲¢弻锝夊磹濠靛钃熸繛鎴欏灩閻撴盯鎮楅敐搴″閽冭鲸淇婇悙顏勨偓鎴﹀礉婵犲洤纾块柣銏⑶圭粻鏍ㄧ箾閸℃ɑ灏紒鐙欏洦鐓欓悗娑欋缚缁犮儲绻涢崗鑲╊暡濞e洤锕俊鍫曞炊椤喓鍎甸弻娑氣偓锝庡墮娴犻亶鏌℃担绋挎殻濠殿喒鍋撻梺闈涚墕閸熺娀宕戦幘瀛樺缂侇垱娲橀悗濠氭⒑閸︻厼浜炬繛鍏肩懃閳绘捇骞囬悧鍫氭嫼闂佸憡鍔曞鍫曞箚閸喆浜滈柟瀛樼箖閸犳﹢鏌e☉鍗炴珝濠殿喒鍋撻梺闈涚墕濡矂骞忔繝姘拺缂佸瀵у﹢浼存煟閻曞倸顩紒顔硷躬閹囧醇濞戞鐩庢俊鐐€栭崝鎴﹀春閸曨倠锝夊箹娴e湱鍘介梺鎸庣箓閹冲骸危婵犳碍鎳氶柨婵嗩槹閻撶姵绻涢弶鎴剱婵炲懎娲弻锝夊箻閹颁礁鍓板銈庝簻閸熷瓨淇婇崼鏇炲耿婵妫欓埛鏍⒒娴h姤纭堕柛鐘叉瀹曟洟鎳犻鍌滅効閻庡箍鍎遍悧鍕瑜版帗鐓欓柣鎴炆戠亸鐢告煕濡吋鏆慨濠呮缁辨帒螣閾忛€涙闂佽棄鍟存禍鍫曞箖濡法鐤€闁挎繂鎳庣粻褰掓⒒閸パ屾Ч缂佺粯绻冪换婵嬪磼濮橆厽顔嶇紓鍌欑椤﹂亶宕曢妶澶婄疄闁靛⿵濡囩弧鈧梺鍛婁緱閸n喗绂掗埡鍐=濞达絼绮欓崫娲偨椤栨稑绗╅柣蹇斿浮濮婃椽骞嗚缁犲鏌嶈閸撴氨绮欓幒妞尖偓浣割潨閳ь剙顫忔繝姘<婵炲棙鍨垫俊浠嬫煟鎼达絿鎳楅柛蹇曞Т閹碱偊顢橀崗鐓庣窞濠电姴瀚悡锝嗙節閻㈤潧浠﹂柛銊ュ閸掓帗鎯旈姀銏╂锤闂備緡鍓欑粔鐢稿煕閹烘嚚褰掓晲閸涱喖鏆堥梺鍝ュ枔閸嬬偟鎹㈠☉姘珰鐟滃繘鎮鹃悽纰樺亾鐟欏嫭绀€缂傚秴锕濠氬幢濡ゅ﹤鎮戦梺鍛婁緱閸ㄤ即鐛崼銉︹拻濞达絼璀﹂弨浼存煙濞茶閭慨濠佺矙瀹曠喖顢涘☉妯圭暗婵犵數鍋涘Λ娆撳箰婵犳碍鍋傞柣妯虹-缁犻箖鏌℃径瀣劸闁稿孩鍔栫换娑㈠川椤撶喎娅i梻鍥ь樀閺岋絽螣閾忕櫢绱為梺娲诲幖閿曨亪寮诲鍥ㄥ枂闁告洦鍋嗘导宀勬⒑閹肩偛濮傜紒鐘崇墵楠炲啫鈻庨幘鏉戠檮婵犮垼娉涢ˇ顖炲垂濠靛鈷掗柛灞剧懄缁佺増銇勯弴鐔哄⒌鐎规洘婢樿灃闁告侗鍋€閸嬫捇宕橀鐓庣獩闂佸搫顦伴崹褰掑矗閳ь剙鈹戦悩顔肩伇闁糕晜鐗犲畷婵嬪即閻樺吀绗夐梺瑙勫劶婵倝鎮″▎鎾寸厵妞ゆ牕妫楅懟顖氣枔閸洘鍋℃繝濠傚缁跺弶绻涚仦鍌氬婵″弶鍔欓獮妯兼嫚閼碱剨绱叉繝鐢靛仜濡瑩宕归懖鈺冪幓婵°倕鎳忛埛鎴︽煕濠靛嫬鍔氶弽锟犳⒑缂佹﹩娈樺┑鐐╁亾闂侀潧妫旂欢姘嚕娴犲鏁囬柣鎰皺閻涒晠姊绘担鍛婅础闁冲嘲鐗撳畷銏$鐎n亞鏌ч梺鎸庣箓椤︿即鍩涢幋鐘电<閻庯綆鍘界涵鍓佺磼閻樺啿鈻曢柡灞剧☉铻i柣妯哄级閸g儤銇勯幇顏嗙煓闁哄矉缍侀獮鍥敊閸撗呮缂傚倷娴囬褍螞濞嗘挸桅闁告洦鍨伴崘鈧梺闈浤涢崨顖氬笓闂備焦鐪归崺鍕垂鏉堚晝鐭欓柟鐑樻⒐瀹曞弶绻涢幋娆忕仼鐎瑰憡绻冮妵鍕箻鐠虹儤鐎婚梺鍝勵儑婵挳鍩為幋锔绘晩缁绢厼鍢叉慨娑氱磽娓氬洤娅橀柛銊ョ埣閻涱喛绠涘☉妯虹獩闁诲孩绋掗敋濞寸媭鍙冨缁樼瑹閸パ冧紟缂備胶濮甸崹鐢稿煝閹炬枼鏀介柛顐犲灮閿涙繈姊虹粙鎸庢拱闁荤噦濡囩划濠囨偋閸稐绨婚梺鍝勬搐濡煤閵堝洤顥氱憸鐗堝笚閻撴洘銇勯鐔风仴婵炲懏锕㈤弻娑㈠Χ閸℃ḿ顦紓浣介哺閹稿骞忛崨顖涘妞ゆ牗绮庣粣妤冪磽閸屾瑨顔夋俊鐙欏洤纾婚柟鍓х帛閳锋帒霉閿濆牜娼愰柛瀣█閺屾稒鎯旈鑲╀桓閻庤娲樼换鍌烆敇婵傜ǹ宸濇い蹇撴噽閳ь剚妞藉娲箹閻愭彃濮堕梺鍛婃尰瀹€鎼佸春濞戙垹绠i柣妯兼暩閿涙粓鏌f惔顖滅У闁稿瀚伴、姘堪閸曨厾鐦堥梺閫炲苯澧存鐐茬Ч椤㈡瑩宕滆缁辨煡姊虹拠鎻掑毐缂傚秴妫濆畷鎴﹀川椤撶姵娈鹃悗鍏夊亾闁逞屽墴閸┾偓妞ゆ帒鍠氬ḿ鎰箾閹绘帞绠荤€规洝顫夌粋鎺斺偓锝庝簽閻g儤绻涚€电ǹ孝妞ゆ垵鎳庨蹇撯攽閸″繑鏂€闂佺粯蓱瑜板啴顢旈埡鍌ゆ闁绘劖鎯屽▓婊勬叏婵犲啯銇濋柟顔惧厴瀵爼骞愭惔鈾€鍋撻鐐粹拺濞村吋鐟х粔闈浢瑰⿰搴濈盎闁伙綁顥撻幉鎾礋椤撶姷妲囨繝娈垮枟閿曗晠宕滃☉銏犲偍闁规壆澧楅埛鎴︽煕濠靛棗顏柛灞诲姂閺屾盯濡搁敂濮愪虎闂佽鍣换婵囦繆閻戣姤鏅滈柦妯侯槸娴煎孩绻濈喊妯活潑闁搞劋鍗抽幃妯衡攽鐎n偄浜楅梺瑙勫婢ф鎮¢悢鍏肩厵闁硅鍔栫涵楣冩煛鐎n偆娲撮柡宀嬬秮楠炴瑩宕橀妸銈呮瀳闁诲氦顫夊ú鏍偉閸忛棿绻嗛柣鎴f鍞梺闈涱槶閸庢盯骞嬮悩鐢碉紳闂佺ǹ鏈悷褔藝閿斿浜滈柟瀛樼箘婢ф洟鏌i敐鍥у幋闁诡喕绮欏畷褰掝敃椤愶絿绋愰梻鍌欑濠€閬嶅磿閵堝拋娼栭柤濮愬€曢ˉ姘舵煕韫囨稒锛熺紒璇叉閵囧嫰寮介妸褏鐣垫繛瀛樼矊缂嶅﹪寮婚敐澶嬫櫜闁割偆鍣ユ禒鈺冪磽娴d粙鍝洪柟绋款煼楠炲繘宕ㄧ€涙ɑ鍎梺鑽ゅ枑婢瑰棝顢曢懖鈺冪=闁稿本鐟︾粊鐗堛亜閺囧棗娲﹂崑瀣煕閳╁啰鈯曢柛瀣ф櫇閳ь剛鎳撶€氫即宕戞繝鍌栫細闁靛ň鏅滈悡鍐喐濠婂牆绀堟慨姗嗗幘閳瑰秴鈹戦悩鎻掍簽婵炲吋澹嗛埀顒€鍘滈崑鎾斥攽閻樻彃鏁柕濞у懐锛濋梺绋挎湰閻燂妇绮婇弶娆炬富闁哄鍨堕幉鎼佹煙楠炲灝鐏茬€规洜鍘ч埞鎴﹀箛椤撶姷鈻夌紓鍌氬€搁崐鐑芥倿閿曚焦鎳屽┑鐘愁問閸ㄤ即顢氶鐘愁潟闁圭儤鍨熷Σ鍫熸叏濡も偓濡宕滈弶搴撴斀闁绘劘灏欐晶娑㈡煕閺冣偓閻熴儵锝炶箛鎾佹椽顢旈崟顓у晣闂備胶绮崝鏍亹閸愵喒鈧牠宕卞☉娆屾嫼闂佸憡绋戦オ鏉戔枔閺冨牊鐓曢柣鏃堟敱閸嬨儵鏌熼鈧粻鏍箖濠婂懐椹抽悗锝庡亝濞呮牠姊绘担铏瑰笡闁告梹岣挎禍绋库枎閹板灚顔旈梺鎼炲労閸撴岸鍩涢幋锔界厽闁绘梻鍘ф禍浼存煕閵堝洤鏋庨柍瑙勫灴椤㈡岸鍩€椤掆偓宀h儻顦归柛鈹垮灲楠炴ê菐椤掆偓娴滄繈姊洪崨濠傚闁哄倷绶氶獮蹇涙惞閸︻厾锛濋梺绋挎湰閻熝囧礉瀹ュ瀚呴梺顒€绉甸悡鍐⒑閸噮鍎忔繛鎼櫍閺岋紕浠﹂悾灞濄垽鏌i敐蹇曠瘈妤犵偛绉归、娆戜焊閺嵮冪阀闂備浇顕х€涒晠顢欓弽顓為棷妞ゆ洍鍋撶€规洘鍨剁换婵嬪磼濠婂嫭顔曢梻浣告贡閸庛倝銆冮崱娑樼9闁绘垼濮ら崐鐢告煟閵忋垺顏㈢憸鐗堝笧瀹撲線鏌涢鐘插姕闁抽攱甯掗湁闁挎繂娲﹂崵鈧梺宕囩帛濞茬喖寮婚埄鍐懝闁搞儜鍕綆闁诲氦顫夊ú姗€宕归崸妤冨祦婵☆垵鍋愮壕鍏间繆椤栨粌甯舵鐐村姍濮婄粯鎷呴崨濠傛殘婵炴挻纰嶉〃濠傜暦閺夋娼╅悹楦挎閻ゅ洭姊洪崨濠佺繁闁哥姵娲滈幑銏ゅ幢濞戞瑧鍘卞┑鐐叉濞存艾危缁嬪簱鏀芥い鏂垮悑閸犳﹢鏌熼挊澶屽煟闁轰焦鍔栧鍕偓锝庝簷閸濇绻濋悽闈涗沪闁搞劌澧庨弫顕€骞掗幘瀛樼彿闂佸搫琚崕鏌ユ偂濞戙垺鐓曢悘鐐佃檸濞堟柨霉濠婂牏鐣烘慨濠傤煼瀹曟帒顫濋钘変壕闁绘垼濮ら崵鍕煕閹捐尙顦﹂柛銊︾箖閵囧嫰寮介顫捕缂備讲鍋撳鑸靛姈閻撴盯鏌涢妷銏℃珔闁逞屽墾缂嶄線骞冮姀銈呬紶闁靛/鍛潓闂傚倷鐒﹂幃鍫曞磿濠婂牆绀冮柍杞扮婵啴姊婚崒姘偓鐑芥嚄閸撲礁鍨濇い鏍仜閽冪喖鏌曟繛鐐珕闁稿骸绉电换婵嬫濞戝崬鍓扮紓鍌欒閺呯娀寮婚妶澶婄畳闁圭儤鍨垫慨灞剧箾鐎涙ḿ鐭嬬紒顔芥崌瀵鏁撻悩鑼槰闂侀潧饪电粻鎴λ囬埡渚囨富闁靛牆鍟崝姘亜閿旂偓鏆€殿喛顕ч埥澶愬閻樻剚妫熼梺鑽ゅТ濞诧妇绮婇幘顔肩;闁圭偓鏋奸弨浠嬫倵閿濆簼绨芥い鏃€鍨垮娲礈閹绘帊绨煎┑鐐插级閿曘垹鐣烽幇鐗堝€婚柤鎭掑劤閸樹粙姊洪悷閭﹀殶闁稿绉剁槐鎾愁潩閼哥數鍘卞┑顔姐仜閸嬫挸霉濠婂棙纭炬い顐㈢箰鐓ゆい蹇撳缁卞爼姊洪崨濠冨闁告挻鐟╁畷鎴濐吋婢跺鎷洪梺鍛婄☉閿曘儵鎮¢妷鈺傜厸闁割偒鍋勬晶瀵糕偓娈垮枟閻撯€崇暦婵傜ǹ鍗抽柕濠忛檮濞呮牠姊绘担铏瑰笡闁告梹娲熼、姘额敇閵忕姴鍋嶉梺鍛婎殘閸嬫劙寮ㄦ禒瀣厽闁归偊鍓欑痪褎銇勯妷锔剧煂缂佽鲸甯炵槐鎺懳熼搹璇″剬缂傚倷绶¢崰姘卞垝椤栨粍宕叉繝闈涙-濞尖晜銇勯幘璺盒㈡鐐村姍濮婅櫣鎷犻懠顒傤唺闂佺ǹ顑囬崰鏍ь嚕閺屻儺鏁冮柨婵嗘閻濓繝姊绘担绛嬪殭婵﹫绠撻敐鐐村緞婵炴帗妞介弫鍐磼濮樻唻绱卞┑鐘垫暩婵挳宕愭繝姘辈闁挎洖鍊归悡鐔兼煛閸愩劌鈧敻骞忛敓鐘崇厸濞达絽鎲¢ˉ銏ゆ煛鐏炵晫啸妞ぱ傜窔閺屾盯骞樼€靛憡鍣伴梺绯曟杺閸ㄥ綊顢橀崗鐓庣窞閻庯綆鍋呴悵鎶芥⒒娴h鍋犻柛搴櫍瀵彃鈹戠€n偅娅栧┑鐘绘涧濞层劎绮绘ィ鍐ㄧ骇闁割偅绻傞埛鏃傜磼鐎n厼鍚归柟鍙夋倐瀵爼宕归鑺ヮ唹缂傚倷绀侀崐鍝ョ矓瑜版帒绠栨繛鍡樻惄閺佸棝鏌涚仦鍓х煂婵℃彃娲缁樼瑹閳ь剙岣胯椤ㄣ儴绠涢弴鐐电瓘闂佸憡鎸嗛崟顐㈠箲闂備胶绮崝锕傚礂濞嗘劗顩叉繝濠傜墛閻撴瑩鎮楀☉娆嬬細缂佺姵鐗滈埀顒傛嚀閹诧紕鎹㈤崟顓燁潟闁圭儤顨忛弫濠囨煕閹炬鍟伴濂告⒒娓氣偓濞佳囨偋閻愮數绀婂ù锝呮憸閺嗭附鎱ㄥ璇蹭壕闂佺硶鏅换婵嗙暦濮椻偓婵℃悂濡疯閸氬姊婚崒姘偓宄懊归崶顒夋晪鐟滃繘鍩€椤掍胶鈻撻柡鍛箘閸掓帒鈻庨幘宕囶唺闂佺懓顕慨瀵哥不閻㈠憡鐓熼柣妯哄帠閼割亪鏌涢弬鍨劉缂佸顦濂稿幢濡搫浼庢繝纰夌磿閸嬬娀顢氳缁傚秵銈i崘鈹炬嫼闂佸憡绻傜€氼垶锝為敃鍌涚厱闁哄倽娉曢悞鎼佹煕閳瑰灝鍔滅€垫澘瀚换娑㈠閵忕姵鐎鹃悗鍨緲鐎氫即骞嗛崒鐐蹭紶闁靛鐏栭幋锔解拺闂傚牊绋掗幖鎰版倵濮樺崬顣煎ǎ鍥э躬楠炴牗鎷呯憴鍕彸闂備礁鎲℃笟妤呭储閼归偊鏉洪梻鍌氬€搁崐宄懊归崶顒夋晪闁哄稁鍘肩粣妤佷繆閵堝懏鍣洪柛瀣剁節閺屽秹宕崟顒€娅¢梺閫炲苯鍘哥紒鑸佃壘椤曪綁顢氶埀顒€鐣烽悡搴樻斀闁割偒鍋呮晥婵犵绱曢崑鎴﹀磹閺嶎厼绠伴柤濮愬€栧畷鏌ユ煕閺囥劌骞橀柣顓炴閺屾盯寮撮妸銉т画闂佹娊鏀辩敮锟犲蓟濞戞矮娌柛鎾楀嫬娅楃紓鍌欐閼宠埖鏅跺Δ鍛﹂柛鏇ㄥ灠閸楁娊鏌i弬鎸庢儓闁冲嘲鐭傞幃妤冩喆閸曨剛锛涢梺鍛婎殔閸熷潡顢氶敐鍡欘浄閻庯絽鐏氶弲婵嬫⒑闂堟稓澧曟繛鏉戝€稿嵄缂佸绨遍弨浠嬫煟濡櫣浠涢柡鍡忔櫅閳规垿顢欓懞銉ュ攭閻庤娲橀崝鏍崲濠靛棭娼╂い鎺嶆祰缁躲垽姊绘担鐟邦嚋婵炲弶鐗犲畷鎰亹閹烘挸浜楀┑鐐叉閸旀垶绂嶅⿰鍫熺厸鐎广儱楠告禍婊兠归悩宕囩煀闂囧绻濇繝鍌涘櫣妞わ絿鍘ц彁闁搞儜宥堝惈闂佺懓纾慨鐢告晬閹邦兘鏀介柛鈩冿供閸炴煡姊婚崒娆戭槮闁汇倕娲敐鐐村緞閹邦剙鐎梺绉嗗嫷娈旈柡鍕╁劦閺屾盯寮撮妸銉т哗缂備讲鍋撻柛鎰靛枟閻撳繐鈹戦悙鎴濆暞閸g兘鏌涚€Q€鍋撻弬銉︽杸闂佹寧绋戠€氼剚绂嶆總鍛婄厱濠电偛鐏濋埀顒佺箓閻g兘濮€鎺抽崑鍛存煕閹扳晛濡挎い蟻鍐f斀闁宠棄妫楅悘鐔兼偣閳ь剟鏁冮崒姘優闂佸搫娲㈤崹娲磻閿濆鐓曢柕澶涚到婵″潡鏌曢崼婵堟憼濞e洤锕獮鎾诲箳閺傚簱鍙洪梻浣告惈閺堫剙煤濠靛牏涓嶆繛鎴欏灩閸楁娊鏌i幋婵囶棡缂傚秴鐭傚缁樻媴缁嬫寧姣愰梺鍦拡閸嬪﹪鐛繝鍛杸婵炴垶鐟ユ禍妤呮椤愩垺澶勯柟灏栨櫊閹垽宕卞☉娆忎化婵°倧闄勭€笛囶敂閻樺樊鐔嗙憸搴∶洪悢鐓庤摕婵炴垯鍨圭猾宥夋煃瑜滈崜鐔肩嵁閹版澘绠柦妯侯槼閹芥洖鈹戦悙鏉戠仧闁搞劎鎳撹灋婵☆垵宕电粻楣冩煕閳╁啰鎳冨ù婊勫劤铻栭柡鍐ㄥ€荤壕浠嬫煕鐏炲墽鎳勭紒浣规緲椤啰鈧稒蓱閸婃劖顨ラ悙鏉戝缂佺粯绻傞~婵嬵敆閸屻倕鏁搁梻鍌欑閹测剝绗熷Δ鍛瀭闁规儼濮ら崕妤佺箾閸℃ɑ灏紒鐘茬秺閹鈽夊▍铏灩娴滄悂顢橀悘鑽ゆ嚀楗即宕奸姀銏℃瘒闂備礁鎼張顒傜矙閹达箑鐓橀柟杈剧畱缁€瀣亜閹扳晛鐏╃悮姗€姊婚崒娆戝妽婵$偛娼″畷銏$鐎n亞顔囨俊銈忕到閸燁偆绮婚悢鍏肩厵闂傚倸顕崝宥夋煕鐎n亶鍎旈柡灞剧洴椤㈡洟鏁愰崶鈺冩毉闂備浇宕甸崰鍡涘礉閹存繍娼栨繛宸簻娴肩娀鏌涢弴銏℃锭闁告搩鍠氱槐鎾存媴閽樺鍘悗鍏夊亾缂佸顑欓崵鏇炩攽閻樺磭顣查柛瀣閺岋綁骞橀搹顐e闯濡炪倧瀵岄崣鍐箖瀹勬壋鍫柛鎰典簽椤斿﹪姊烘潪鎵窗闁哥姵鐗犻崺銉﹀緞閹邦剦娼婇梺鎸庣☉鐎氼剟鐛幇鐗堚拻濞达絽鎲¢崯鐐层€掑顓ф疁鐎规洘婢樿灃闁告侗鍘鹃敍娆撴⒑鐟欏嫬顥嬪褎顨婇幃鈥斥槈閵忊€斥偓鍫曟煟閹伴偊鏉洪柛銈嗙懃閳规垿顢欓悡搴樺亾閸ф钃熼柣鏃傗拡閺佸﹪鏌涘┑鍡楊仱闁稿鎸搁埞鎴﹀幢濞嗘劖顔曢梻浣告贡閸庛倝宕归悢鑲猴綁宕奸悢绋垮伎濠德板€愰崑鎾翠繆椤愶絾鈷掓俊鍙夊姍閺佹捇鏁撻敓锟� ---闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閻愵剙鍔ょ紓宥咃躬瀵鏁愭径濠勵吅闂佹寧绻傞幉娑㈠箻缂佹ḿ鍘辨繝鐢靛Т閸婂綊宕戦妷鈺傜厸閻忕偠顕ф慨鍌溾偓娈垮櫘閸o絽鐣锋總鍛婂亜闁告稑饪撮崬鍫曟⒒閸屾瑨鍏岄弸顏呫亜閹存繃顥㈡鐐村姍瀹曟粏顦查柛銊︾箖閵囧嫰骞樼捄杞版睏濠碘剝褰冮悧濠冪┍婵犲浂鏁嶆慨姗嗗幗閸庢挾绱撴担鍝勑い鏇嗗洤鐓橀柟杈鹃檮閸婄兘鏌涘▎蹇fТ闁哄鐟︾换娑氣偓娑欋缚閻绱掗鑺ュ磳妤犵偛鍟撮崹楣冨棘閵夛富娼旈梻渚€娼ф蹇曟閺囥垹鍌ㄩ柛妤冨亹閺€浠嬫煟閹邦厽缍戦柣蹇嬪劤閳ь剝顫夊ú锕傚礈閻斿吋鍋樻い鏂挎閻旀哺褔宕堕敂鍓ф晨闂傚倷绀侀幖顐﹀磹閸︻厸鍋撶粭娑樻硽婢舵劕顫呴柍鈺佸暙瀵寧绻濋悽闈浶㈤柟鍐茬箻椤㈡棃鎮╃紒妯煎幍闂佽崵鍠愬姗€顢旈鐐╂斀闁斥晛鍟崐鎰攽閿涘嫬鍘撮柡浣稿€块獮鍡氼槾缂佸鐗撳濠氬磼濮橆兘鍋撻悜鑺ュ殑闁割偅娲栫粻鐘绘煙閹规劦鍤欓柛姘秺閺屸€愁吋鎼粹€崇缂備胶濯崹鍫曞蓟閵娾晜鍋嗛柛灞剧☉椤忥拷
开发学院软件开发Java IBM Rational Application Developer 代码覆盖工具... 阅读

IBM Rational Application Developer 代码覆盖工具入门简介

 2010-06-14 00:00:00 来源:WEB开发网 闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閹冣挃闁硅櫕鎹囬垾鏃堝礃椤忎礁浜鹃柨婵嗙凹缁ㄧ粯銇勯幒瀣仾闁靛洤瀚伴獮鍥敍濮f寧鎹囬弻鐔哥瑹閸喖顬堝銈庡亝缁挸鐣烽崡鐐嶆棃鍩€椤掑嫮宓佸┑鐘插绾句粙鏌涚仦鎹愬闁逞屽墰閹虫捇锝炲┑瀣╅柍杞拌兌閻ゅ懐绱撴担鍓插剱妞ゆ垶鐟╁畷銉р偓锝庡枟閻撴洘銇勯幇闈涗簼缂佽埖姘ㄧ槐鎾诲礃閳哄倻顦板┑顔硷工椤嘲鐣烽幒鎴旀瀻闁规惌鍘借ⅵ濠电姷鏁告慨顓㈠磻閹剧粯鈷戞い鎺嗗亾缂佸鏁婚獮鍡涙倷閸濆嫮顔愬┑鐑囩秵閸撴瑦淇婇懖鈺冪<闁归偊鍙庡▓婊堟煛鐏炵硶鍋撻幇浣告倯闁硅偐琛ラ埀顒冨皺閺佹牕鈹戦悙鏉戠仸闁圭ǹ鎽滅划鏃堟偨缁嬭锕傛煕閺囥劌鐏犻柛鎰ㄥ亾婵$偑鍊栭崝锕€顭块埀顒佺箾瀹€濠侀偗婵﹨娅g槐鎺懳熺拠鑼舵暱闂備胶枪濞寸兘寮拠宸殨濠电姵纰嶉弲鎻掝熆鐠虹尨宸ョ€规挸妫濆铏圭磼濡搫顫嶇紓浣风劍閹稿啿鐣烽幋锕€绠婚悹鍥у级瀹撳秴顪冮妶鍡樺鞍缂佸鍨剁粋宥夋倷椤掍礁寮垮┑鈽嗗灣閸樠勭妤e啯鍊垫慨妯煎亾鐎氾拷闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閹冣挃闁硅櫕鎹囬垾鏃堝礃椤忎礁浜鹃柨婵嗙凹缁ㄥジ鏌熼惂鍝ョМ闁哄矉缍侀、姗€鎮欓幖顓燁棧闂備線娼уΛ娆戞暜閹烘缍栨繝闈涱儐閺呮煡鏌涘☉鍗炲妞ゃ儲鑹鹃埞鎴炲箠闁稿﹥顨嗛幈銊╂倻閽樺锛涘┑鐐村灍閹崇偤宕堕浣镐缓缂備礁顑嗙€笛囨倵椤掑嫭鈷戦柣鐔告緲閳锋梻绱掗鍛仸鐎规洘鍨块獮鍥偋閸垹骞嶇紓鍌氬€烽悞锕傛晪缂備焦銇嗛崶銊у帗閻熸粍绮撳畷婊堟晝閸屾氨鐓戦梺鍛婂姦閻撳牆岣块弽顓熺厱婵犻潧妫楅悵鏃傛喐閺傝法鏆﹂柟顖炲亰濡茬偓绻涚€电ǹ孝闁靛牏枪椤繘鎼圭憴鍕彴闂佽偐鈷堥崜娑㈩敊婢舵劖鈷戦柣鎾虫捣缁夎櫣绱掗悩宕囧⒌妤犵偛鍟妶锝夊礃閳轰讲鍋撴繝姘參婵☆垯璀﹀Σ濂告煙閼恒儲绀嬫慨濠冩そ濡啫鈽夋潏顭戔偓鍡樼節绾版ǚ鍋撻搹顐㈡灎閻庤娲忛崹浠嬪箖娴犲宸濆┑鐐靛亾鐎氬ジ姊洪懡銈呮瀾闁荤喆鍎抽埀顒佹皑閸忔ê鐣烽婵堢杸婵炴垶鐟ч崢閬嶆⒑缂佹◤顏嗗椤撶喐娅犻柣銏犳啞閻撳繘鏌涢埄鍐炬當闁逞屽墮濠€杈╃磽閹惧顩烽悗锝庝簻缁愭稒绻濋悽闈浶㈤悗姘煎墴閻涱噣宕奸妷锔规嫼缂佺虎鍘奸幊搴ㄋ夊澶嬬厵婵炶尪顔婄花鑺ヤ繆閸欏濮嶇€殿喗鎸抽幃銏ゅ传閸曘劌褰忛梻鍌氬€搁崐鎼佸磹妞嬪孩顐芥慨姗嗗厳缂傛氨鎲稿鍥у疾闂備線娼ч悧鍡椕洪悩璇茬;闁圭偓鍓氬ḿ鈺傘亜閹扳晛鐏╃紒渚囧櫍濮婅櫣绱掑Ο鍦箒闂侀潻缍囩紞渚€鎮伴鈧獮鎺楀箠閾忣偅顥堥柛鈹惧亾濡炪倖甯掗崐缁樼▔瀹ュ鐓ユ繝闈涙椤ョ姷绱掗埦鈧崑鎾绘⒒閸屾艾鈧悂鎮ф繝鍕煓闁硅揪绠戝Ч鍙夌箾閸℃璐╅柣鐔稿閸亪鏌涢鐘茬伄闁哄棭鍋婂娲传閸曨厾鍔圭紓鍌氱С閻掞箓骞堥妸鈺佺劦妞ゆ帒瀚悡鍐煙椤栨粌顣肩痪顓犲亾缁绘繈鍩€椤掍焦缍囬柕濞у懎楠勯梻浣告惈濞层劑宕伴幘璺哄К闁逞屽墮閳规垿顢欓弬銈勭返闂佸憡锕㈢粻鏍х暦閵忋倖鍋ㄩ柛娑樑堥幏铏圭磽閸屾瑧鍔嶉柨姘攽椤曞棛鐣甸柡灞剧洴楠炴﹢寮堕幋婵囨嚈闂備浇顕栭崰妤勬懌濠电偟鍘х换妯讳繆閹间礁围闁搞儮鏅濋弳浼存⒒閸屾瑧顦︽繝鈧潏鈺佸灊妞ゆ牗绮嶉弳婊堟煟閹邦剛鎽犳繛鍛У缁绘盯骞嬮悙瀵告缂佺偓宕橀崑鎰閹惧瓨濯撮悹鎰靛灣缁辨澘鈹戦悙鏉戠祷妞ゆ洦鍙冮崺鈧い鎺戝枤濞兼劖绻涢崣澶屽ⅹ闁伙絿鍏橀、妤呭礃椤忓啰鑳洪梻鍌氬€风粈渚€骞夐敓鐘茬闁哄洢鍨归悿顕€鏌eΟ娆惧殭缂佲偓閸喓绡€闂傚牊绋撴晶娑氣偓瑙勬礀瀵墎鎹㈠☉銏犵闁绘劑鍔庣槐浼存⒑閸濆嫭顥滄俊顐n殜閸╃偤骞嬮敂钘変汗闁哄鐗滈崑鍕储閿熺姵鈷戦弶鐐村閸斿秹鏌eΔ浣虹煂婵″弶鍔欓獮妯尖偓娑櫭鎾寸箾鐎电ǹ孝妞ゆ垵鎳橀獮妤呮偨閸涘ň鎷洪梺闈╁瘜閸樹粙宕甸埀顒€鈹戦悙鑼勾闁稿﹥绻堥獮鍐┿偅閸愨晛鈧鏌﹀Ο渚Ш妞ゆ柨锕铏规喆閸曨剙鍓归梺鍛娒肩划娆忕暦閹剧粯鍋ㄩ柛娑樑堥幏娲⒑閼姐倕鏋戞繝銏★耿楠炲啯绗熼埀顒勫蓟閿濆绠抽柣鎰暩閺嗐倝姊虹拠鈥虫灍妞ゃ劌锕悰顕€寮介妸锕€顎撻梺绋跨箰椤︽壆鈧俺妫勯埞鎴︽倷閼搁潧娑х紓浣瑰絻濞尖€崇暦閺囥垹围濠㈣泛锕ら幆鐐烘⒑闁偛鑻晶瀛樻叏婵犲啯銇濇鐐寸墵閹瑥霉鐎n亙澹曢梺鍝勭▉閸樹粙宕戠€n喗鐓熸俊顖氱仢閸氬湱鈧鎸风欢姘舵偂椤愶箑鐐婇柕濞р偓婵洭姊洪崫鍕櫤闁诡喖鍊垮濠氬Ω閳哄倸浜為梺绋挎湰缁嬫垿顢旈敓锟�婵犵數濮烽弫鍛婃叏閻戣棄鏋侀柛娑橈攻閸欏繘鏌i幋锝嗩棄闁哄绶氶弻娑樷槈濮楀牊鏁鹃梺鍛婄懃缁绘﹢寮婚敐澶婄闁挎繂妫Λ鍕⒑閸濆嫷鍎庣紒鑸靛哺瀵鈽夊Ο閿嬵潔濠殿喗顨呴悧濠囧极妤e啯鈷戦柛娑橈功閹冲啰绱掔紒妯虹伌濠碉紕鏁诲畷鐔碱敍濮橀硸鍟嬮梻浣告啞椤ㄥ牓宕戦悢鍝ヮ浄闁兼祴鏅濈壕钘壝归敐鍛儓妞ゅ骸鐭傞弻娑㈠Ω閵壯冪厽閻庢鍠涢褔鍩ユ径鎰潊闁绘ḿ鏁搁弶鎼佹⒒閸屾艾鈧悂鎮ф繝鍕煓闁圭儤顨嗛崐鍫曟煕椤愮姴鍔滈柛濠勬暬閺岋綁鎮㈤崫鍕垫毉闂佸摜鍠撻崑鐔烘閹烘梹瀚氶柟缁樺笚濞堢粯绻濈喊澶岀?闁轰浇顕ч悾鐑芥偄绾拌鲸鏅┑顔斤耿绾悂宕€n喗鈷戦悹鍥ㄧ叀閸欏嫭绻涙担鍐叉搐缁犵儤绻濇繝鍌滃闁稿鏅涢埞鎴﹀磼濮橆厼鏆堥梺鎶芥敱閸ㄥ綊鎯€椤忓牜鏁囬柣鎰綑椤庢稑鈹戦悙鎻掓倯闁告梹鐗滈幑銏犫槈閵忊€虫濡炪倖宸婚崑鎾绘煛鐎n亜顒㈤柕鍥у椤㈡洟濮€閵忋埄鍞虹紓鍌欐祰妞村摜鏁幒鏇犱航闂備礁鍚嬬粊鎾疾濠婂牆鍚圭€光偓閸曨兘鎷绘繛鎾村焹閸嬫捇鏌嶈閸撴盯宕戝☉銏″殣妞ゆ牗绋掑▍鐘炽亜閺冨洤浜归柡鍡楁閺屻劌鈹戦崱娆忣暫闂佸憡鏌ㄩ悘姘跺Φ閸曨垱鏅滈柣锝呰嫰瀵劑姊虹拠鈥虫珯缂佺粯绻冩穱濠囨嚋闂堟稓绐為柣搴秵閸撴瑧鏁ィ鍐┾拻濞达絿枪椤ュ繘鏌涚€n亝鍣介柟骞垮灲瀹曟﹢顢欓懖鈺嬬幢婵$偑鍊曠换鎰板箠閹邦喚涓嶉柛鎾椻偓閸嬫捇鎮烽弶娆炬闂佸摜濮靛ú婊堟嚍鏉堛劎绡€婵﹩鍓涢悾楣冩⒑缂佹ɑ鐓ラ柛姘儔閸╂盯骞嬮敂钘夆偓鐢告煕閿旇骞栭弽锟犳⒑闂堟稒顥滈柛鐔告尦瀵濡舵径濠勵槰闂佽偐鈷堥崜娆撴偂閻斿吋鍊甸悷娆忓缁€鍐磼鐠囪尙澧︾€殿噮鍋婂畷姗€顢欓懖鈺佸Е婵$偑鍊栫敮鎺斺偓姘€鍥х劦妞ゆ帊鐒﹂ˉ鍫⑩偓瑙勬礃閿曘垽銆佸▎鎾冲簥濠㈣鍨板ú锕傛偂閺囥垺鐓冮柍杞扮閺嬨倖绻涢崼鐕傝€块柡宀嬬秮閹垻绮欓崹顕呮綒婵犳鍠栭敃銉ヮ渻娴犲绠栭柍鈺佸暞閸庣喖鏌嶉埡浣告殲闁伙讣缍佸缁樻媴閾忕懓绗¢梺缁橆殕濞茬喐淇婇崜浣虹煓閻犳亽鍔嶅▓楣冩⒑缂佹ê鐏﹀畝锝堟硶瀵囧焵椤掑嫭鈷戦柟鑲╁仜閸斺偓闂佸憡鍔戦崝搴ㄥΧ椤曗偓濮婂宕掑▎鎴犵崲濠电偘鍖犻崟鍨啍闂婎偄娲﹀ú姗€锝為弴銏$厸闁搞儯鍎遍悘鈺呮煕鐏炶濡介柕鍥у缁犳盯骞樼捄渚澑闂備焦濞婇弨閬嶅垂閸ф钃熼柣鏂垮悑閸ゅ啴鏌嶆潪鐗堫樂缂侇喖鐖煎娲川婵犲啠鎷瑰銈冨妼閿曨亜顕f繝姘櫢闁绘ɑ褰冪粣娑橆渻閵堝棙顥堥柡渚囧枟閹便劑宕堕埡鍐紳婵炶揪绲挎灙闁逞屽墮濠€閬嶅极椤曗偓閹垺淇婇幘铏窛闁逞屽墴濞佳囧箺濠婂懎顥氬┑鍌溓圭痪褔鏌涢锝団槈濠德ゅ亹缁辨帒螖娴d警鏆$紓浣虹帛閻╊垶骞冮埄鍐╁劅闁挎繂娴傞崯瀣⒒娴h櫣銆婇柡鍌欑窔瀹曟粌鈹戠€n亞顔嗛梺鍛婄☉閻°劑鎮¢妷鈺傚€甸柨婵嗘噽娴犳稓绱撳鍡╂疁婵﹤顭峰畷鎺戭潩椤戣棄浜剧€瑰嫭鍣磋ぐ鎺戠倞鐟滄粌霉閺嶎厽鐓忓┑鐐靛亾濞呭棝鏌涙繝鍌涘仴闁哄被鍔戝鎾倷濞村浜鹃柛婵勫劤娑撳秹鏌$仦璇插姕闁绘挻娲熼弻鏇熷緞濡儤鐏堟繝鈷€灞芥珝闁哄矉绱曢埀顒婄岛閺呮繄绮i弮鍫熺厸鐎光偓閳ь剟宕伴弽褏鏆︽繝濠傛-濡查箖鏌i姀鈺佺仭闁烩晩鍨跺濠氭晸閻樻彃绐涘銈嗘濡嫰鍩€椤掍礁濮嶉柡宀嬬磿娴狅妇鎷犻幓鎺濇綆闂備浇顕栭崰鎾诲磹濠靛棛鏆﹂柟鐑樺灍濡插牊鎱ㄥΔ鈧Λ鏃傛閿燂拷闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閹冣挃闁硅櫕鎹囬垾鏃堝礃椤忎礁浜鹃柨婵嗙凹缁ㄧ粯銇勯幒瀣仾闁靛洤瀚伴獮鍥敍濮f寧鎹囬弻鐔哥瑹閸喖顬堝銈庡亝缁挸鐣烽崡鐐嶆棃鍩€椤掑嫮宓佸┑鐘插绾句粙鏌涚仦鎹愬闁逞屽墰閹虫捇锝炲┑瀣╅柍杞拌兌閻ゅ懐绱撴担鍓插剱妞ゆ垶鐟╁畷銉р偓锝庡枟閻撴洘銇勯幇闈涗簼缂佽埖姘ㄧ槐鎾诲礃閳哄倻顦板┑顔硷工椤嘲鐣烽幒鎴旀瀻闁规惌鍘借ⅵ濠电姷鏁告慨顓㈠磻閹剧粯鈷戞い鎺嗗亾缂佸鏁婚獮鍡涙倷閸濆嫮顔愬┑鐑囩秵閸撴瑦淇婇懖鈺冪<闁归偊鍙庡▓婊堟煛鐏炵硶鍋撻幇浣告倯闁硅偐琛ラ埀顒冨皺閺佹牕鈹戦悙鏉戠仸闁圭ǹ鎽滅划鏃堟偨缁嬭锕傛煕閺囥劌鐏犻柛鎰ㄥ亾婵$偑鍊栭崝锕€顭块埀顒佺箾瀹€濠侀偗婵﹨娅g槐鎺懳熺拠鑼舵暱闂備胶枪濞寸兘寮拠宸殨濠电姵纰嶉弲鎻掝熆鐠虹尨宸ョ€规挸妫濆铏圭磼濡搫顫嶇紓浣风劍閹稿啿鐣烽幋锕€绠婚悹鍥у级瀹撳秴顪冮妶鍡樺鞍缂佸鍨剁粋宥夋倷椤掍礁寮垮┑鈽嗗灣閸樠勭妤e啯鍊垫慨妯煎亾鐎氾拷  闂傚倸鍊搁崐鎼佸磹閹间礁纾归柟闂寸绾惧綊鏌熼梻瀵割槮缁炬儳缍婇弻鐔兼⒒鐎靛壊妲紒鐐劤缂嶅﹪寮婚悢鍏尖拻閻庨潧澹婂Σ顔剧磼閻愵剙鍔ょ紓宥咃躬瀵鏁愭径濠勵吅闂佹寧绻傞幉娑㈠箻缂佹ḿ鍘遍梺闈涚墕閹冲酣顢旈銏$厸閻忕偠顕ч埀顒佺箓閻g兘顢曢敃鈧敮闂佹寧妫佹慨銈夋儊鎼粹檧鏀介柣鎰▕閸ょ喎鈹戦鈧ḿ褔锝炲┑瀣╃憸搴綖閺囥垺鐓欓柟瑙勫姦閸ゆ瑧鐥幆褍鎮戠紒缁樼洴瀹曞崬螣閾忓湱鎳嗛梻浣告啞閿曨偆妲愰弴鐘愁潟闁规儳顕悷褰掓煕閵夋垵瀚ぐ顖炴⒒娴h鍋犻柛鏂跨焸閹儵宕楅梻瀵哥畾闂佸湱铏庨崰鏍矆閸愨斂浜滈柡鍐ㄥ€哥敮鍓佺磼閹邦厾娲存慨濠冩そ瀹曨偊宕熼崹顐嵮囨⒑閹肩偛濡肩紓宥咃工閻g兘濮€閻樺棙妞介、鏃堝川椤撴稑浜鹃柛顭戝亽濞堜粙鏌i幇顖氱毢濞寸姰鍨介弻娑㈠籍閳ь剛鍠婂澶娢﹂柛鏇ㄥ灡閺呮粓鎮归崶顏勭毢濞寸姵鎮傞幃妤冩喆閸曨剛鈹涚紓浣虹帛缁诲牓鎮伴鑺ュ劅闁靛⿵绠戝▓鐔兼⒑闂堟冻绱¢柛鎰╁妼椤╊剟姊婚崒姘偓鎼併偑閹绢喖纾婚柛鏇ㄥ€嬪ú顏呮櫇闁逞屽墰閸欏懘姊洪崫鍕犻柛鏂垮閺呭爼鏁撻悩鏂ユ嫽闂佺ǹ鏈悷锔剧矈閻楀牄浜滈柡鍥ф閹冲宕戦幘璇插瀭妞ゆ劑鍨虹拠鐐烘倵鐟欏嫭绀冪紒顔芥崌楠炲啴濮€閿涘嫰妾繝銏f硾椤戝洨绮欐笟鈧缁樻媴閻熸澘濮㈢紓浣虹帛閸旀洟鏁冮姀鈩冪秶闁宠桨绶″Λ婊堟⒑缁嬭法绠绘俊顐ユ硶閹广垽宕卞Ο闀愮盎闂佸搫绉查崝搴ㄣ€傞弻銉︾厵妞ゆ牗姘ㄦ晶娑㈡煏閸パ冾伃妞ゃ垺娲熸慨鈧柕蹇嬪灩婵鲸绻濆▓鍨灈闁挎洏鍔岄埢宥夋晲婢跺﹦顔嗛梺缁樶缚缁垶宕甸幋鐐簻闁圭儤鍨垫禍鐐烘煕閻愰娼愮紒缁樼箓閳绘捇宕归鐣屼憾闂佺厧鐏曢崶銊у幈闂佸搫鍟犻崑鎾绘煕閵娿儳浠㈤柣锝呭槻鐓ゆい蹇撳閸旓箑顪冮妶鍡楃瑐闂傚嫬绉电粋宥呪堪閸喓鍘甸梺鍛婄箓鐎氼喛鍊存俊鐐€х拋锝囩不閹捐钃熸繛鎴欏灩鍥撮柟鑲╄ˉ閳ь剚鏋奸幏顐︽⒒娴e憡鎯堥柡鍫墴閹嫰顢涢悙闈涚ウ濠碘槅鍨伴崥瀣暦婢舵劖鐓熼柟瀵稿亶缂傛岸鏌嶈閸撴繈顢氳閳ユ棃宕橀鍢壯囧箹缁厜鍋撻懠顒傛晨缂傚倸鍊烽懗鍓佸垝椤栫偛绀夋俊銈呮噹閻鏌涘☉鍗炲季婵炴挸顭烽弻鏇㈠醇濠靛洤娅х紓浣哄С閸楁娊骞冨Δ鈧~婵嬫偂鎼粹檧鎷梻浣筋嚃閸犳銆冩繝鍥モ偓浣割潨閳ь剟骞冨⿰鍫濆耿婵☆垵娅eΣ锝夋⒒閸屾瑧绐旀繛浣冲洦鍋嬮柛鈩冦亗濞戞ǚ鏋庨柟瀵稿Х閻掑ジ姊洪柅鐐茶嫰婢у瓨鎱ㄦ繝鍐┿仢闁诡喚鍏樺鍫曞箰鎼淬垻妲梻鍌氬€风粈浣规償濠婂懎绶ゅù鐘差儐閸嬧晝鈧懓瀚竟瀣醇椤忓牊鐓曢柡鍥ュ妼娴滀粙鏌涢妶鍐ㄢ偓婵嬪蓟閿濆棙鍎熼柕蹇婃噰婵洭鏌ょ憗銈呪偓婵嬪蓟閻斿吋鐓ラ悗锝庡亖娴犮垹鈹戦纭峰姛缂侇噮鍨崇划顓㈡偄閻撳海鍊為悷婊冪灱閼鸿鲸绂掔€n偀鎷虹紓浣割儐椤戞瑩宕曢幇鐗堢厽闁冲搫锕ら悘锔筋殽閻愯韬柟顔哄灮閸犲﹥娼忛妸锔界彨濠电姷鏁搁崑鐐哄垂閸洘鍋¢柨鏇炲€归崑鐔衡偓鐟板閸嬪﹤銆掓繝姘厪闁割偅绻冮ˉ鐐烘煟閹惧崬鍔氭い顓″劵椤︽挳鏌¢崪浣镐簼缂佹梻鍠栧鎾閳ュ厖绨甸梺鐟板悑閹矂宕板璺鸿埞闁汇垹鎲¢悡鐔兼煟濡厧鍔嬫い蹇曞█閹ǹ绠涚€n亜顫囬悗瑙勬礃缁诲牓骞冮姀銈嗘優闁革富鍙忕槐鎻掆攽閻橆喖鐏辨繛澶嬬〒閳ь剚绋堥弲鐘汇€侀弮鍫熷亹缂備焦岣块崢鎾绘偡濠婂嫮鐭掔€规洘绮岄~婵囷紣濠靛洦娅撻梻浣告惈缁嬩線宕㈤懖鈺冪幓婵°倕鎳忛悡娑氣偓骞垮劚妤犳悂鐛幇鐗堢厓鐟滄粓宕滈妸褏涓嶉柟鎹愵嚙閽冪喖鏌曟繛褉鍋撻柛瀣崌閺佹劙宕掑☉娆戝絿缂傚倷鑳舵慨鐢告嚌妤e啫鐓橀柟杈惧瘜閺佸﹪鏌i敐鍛伇闁伙絿鏁诲鍝劽虹拠鎻掔闂佺粯顨呭Λ妤€鐣甸崟顖涒拺缂備焦锚閻忓崬鈹戦鍝勨偓婵嬪春濞戙垹绠i柣妯兼暩閿涙粓鏌f惔顖滅У闁稿甯″畷鏇㈠Ψ閳哄倻鍘遍柟鍏肩暘閸ㄨ鎱ㄥ澶嬬厸鐎光偓閳ь剟宕伴弽顓炵畺闁绘垼濮ら崑瀣煕椤愩倕鏋戦柛濠勫厴濮婃椽骞戦幇顒€鎯為梺绋款儍閸婃繂顕g拠娴嬫闁靛繒濮烽悿鈧梻浣哥枃濡椼劎绮堟担鍛婃殰婵犵數濮烽。浠嬪礈濠靛ǹ浜归柛鎰靛枟閸嬪鈹戦悩鎻掝仾鐎规洖寮剁换娑㈠箣濞嗗繒浠煎Δ鐘靛亼閸ㄧ儤绌辨繝鍥ч柛娑卞幗濞堣泛顪冮妶鍡樼叆妞わ富鍨堕崺鐐哄箣閿旇棄鈧兘鏌ょ喊鍗炲妞ゃ倐鍋撻梻鍌欑劍鐎笛兠鸿箛娑樺瀭鐟滅増甯紞鏍叓閸ャ劍绀堢痪鎯у悑娣囧﹪顢涘┑鎰濡炪倕瀛╅幐缁樼┍婵犲洦鍊风€瑰壊鍠栭崜鎵磽娴i潧濮€闁稿鍔欓獮澶嬪閺夋垵鑰垮┑鐐叉閸ㄥ綊鏁嶅┑瀣拺缂佸瀵у﹢鐗堟叏濡ǹ濮€闁愁亞鏁诲缁樻媴閸涢潧缍婇、鏍幢濞戞ḿ顔囬梺鐓庮潟閸婃牕鐣烽崣澶岀闁瑰鍋涢悞褰掓煕鐎n偅灏柍钘夘槸閳诲海鈧綆鍓涚粣妤呮⒒娴h銇熼柛妯虹秺瀹曟劕鈹戠€n亣鎽曞┑鐐村灟閸ㄥ湱绮绘繝姘仯闁惧繒鎳撻崝瀣煟韫囨挾澧﹂柟顔筋殘閹叉挳宕熼鍌ゆО婵犵绱曢崑妯煎垝濞嗗繒鏆︽繛宸簻閻掑灚銇勯幒宥夋濞存粍绮撻弻鐔煎传閸曨厜褎淇婇幆褍妲婚棁澶嬬節婵犲倸顏柣顓熷浮閺屸€崇暆閳ь剟宕伴弽顓炵畺婵犲﹤鍚橀悢鍏兼優闂侇偅绋掑Ο濠囨⒒閸屾瑧绐旈柍褜鍓涢崑娑㈡嚐椤栨稒娅犳い鏂垮⒔绾剧晫鈧箍鍎遍幏鎴濐啅閵夛负浜滈柡鍥朵簽缁夘喗顨ラ悙鍙夋崳缂侇喚鏁搁埀顒婄秵閸嬪懎鈻嶅畝鍕拻濞达絽鎲¢崯鐐寸箾鐠囇呯暤鐎规洘绮岄埥澶愬閻樻彃浜堕梻鍌欑贰閸撴瑧绮旈悽鍛婂亗闁绘梻鍘х粻褰掓煙绾板崬骞栭柣蹇ョ悼缁辨帗寰勯幇顓熼敪闂傚洤顦扮换婵囩節閸屾稑娅i梺鍛娚戦幐鎶藉蓟閿濆绠奸柛鎰╁妼閳峰顪冮妶鍐ㄧ仾妞ゃ劌锕ら悾鐑藉箳閹宠櫕妫冮崺鈧い鎺嶈兌椤╂彃螖閿濆懎鏆為柛瀣у墲缁绘盯宕卞Δ鍐唶濡炪倕娴氭禍鐐烘儉椤忓牆绠氱憸婊堟偂婵傚憡鐓涢悘鐐插⒔閳藉鎽堕弽顓熺厓鐟滄粓宕滈悢椋庢殾妞ゆ牜鍋涢柨銈嗕繆閵堝拑鏀婚柡鍜佷邯濮婃椽骞愭惔锝囩暤濡炪倧瀵岄崹铏珶閺嚶颁汗闁圭儤鎸鹃崢浠嬫⒑閸濆嫭澶勬慨妯稿姂瀹曟繂顓兼径瀣垫闁诲函缍嗛崰妤呭煕閹烘鐓曢悘鐐插⒔閹冲懏銇勯敂鑲╃暤闁哄瞼鍠撻崰濠囧础閻愭壆鐩庨梺鎹愬吹閸嬨倝骞冨Δ鍛棃婵炴垶鐟﹂崰鎰箾閹寸偞灏紒澶婄秺瀵鎮㈤悡搴n唹闂侀€涘嵆濞佳冣枔椤撱垺鈷戦柦妯侯槸閺嗙喖鏌涢悩宕囧⒌鐎殿喖顭峰鎾偄閾忚鍟庨梻浣虹帛閸旓箓宕滃鑸靛仧闁哄洢鍨洪埛鎴犵磼鐎n偒鍎ラ柛搴$箲娣囧﹪顢曢敐鍥╃杽閻庢鍠涢褔鍩ユ径濠庢僵妞ゆ劧绲芥刊浼存⒒娴e憡鍟為柟绋挎閸┾偓妞ゆ巻鍋撻崡閬嶆煕椤愶絿绠ユ繛鎾愁煼閺屾洟宕煎┑鍥ф畻闂佺粯绋掔划鎾诲蓟閻旂厧绀勯柕鍫濇椤忥拷
核心提示:什么是 Rational Code Coverage 特性?代码覆盖率是软件测试的一个重要方面,对于一个构件的总体系统测试来说可能是一个基本的参数,IBM Rational Application Developer 代码覆盖工具入门简介,覆盖工具背后的动机向您(作为开发员或者测试员)提供了关于代码的一系列观点,这些代

什么是 Rational Code Coverage 特性?

代码覆盖率是软件测试的一个重要方面,对于一个构件的总体系统测试来说可能是一个基本的参数。覆盖工具背后的动机向您(作为开发员或者测试员)提供了关于代码的一系列观点,这些代码在一系列的测试之中会得到检查。该信息会非常的有用,因为您可以使用它来设计新的测试用例以获得足够的覆盖范围。

IBM® Rational® Code Coverage 特性是一个与 IBM® Rational® Application Developer 相集成的工具。您可以使用它来生成并分析关于 Java 程序的覆盖率统计数据。工具会为测试下的程序生成声明覆盖率统计数据(这就是说,执行程序中行的数量与百分比)。

Rational Code Coverage 特性现在只能获得 Rational Application Developer 7.5 版本及其后续版本。本文假设您使用的是 Rational Application Developer 7.5.4 版本。对代码覆盖率而配置 IBM® WebSphere® Application Server 的部分假设您使用的是 7.0 版本,但是提供的指南的一些调整仍然适用于上述版本。

指南

为了适当地分析 Rational Code Coverage 特性中的覆盖率统计数据,理解场景背后所用到的技术是非常重要的。

Eclipse Test 与 Performance Tools Project(TPTP)中提供的 Rational Code Coverage 特性所使用的工具引擎。Probekit 用于控制一个类的比特代码,并引入覆盖率数据收集引擎的通用访问。图 1 提供了关于这个过程的一个高层次的概述:

图 1. Rational Code Coverage 执行环境的概述
IBM Rational Application Developer 代码覆盖工具入门简介

基本快与可执行的单元

Probekit 是一种在 Eclipse 平台上的框架,并可以操作所谓 可执行单元 的比特代码。可执行单元的定义与 基本块 的传统定义有轻微的不同,但是当您在分析结果时,您就需要去关注这点差异了。

根据定义,一个所谓的基本块就是一系列的指南,这些指南不能再进行分支或者分散。这里的关键思想在于,当第一个指南运行的时候,该块中随后所有指南都一定会得到执行而且不会得到中断。接下来的是一个基本块,它可以认为是一个单个组或者一系列的指南。通常来说,基本块的结尾是 branch, call, throw 或者 return 声明。

一个可执行的单元由每一个基本快开始,而与每行源代码相对应的指南与前面版本中的指南有所不同。可执行的单元与基本块的不同点,在于决定一个可执行单元末尾的因素。例如, divide 指南并没有认为是一个可执行单元的结尾,尽管有例外情况的存在。

Probekit 是 Rational Code Coverage 特性所使用的,以将通用代码引入到每一个可执行的单元之中。结果来说,您可以定制 Rational Code Coverage 特性以向组成性(换句话说,就是块覆盖率)可执行单元层次报告统计数据。为了知道这些工具是怎样更改类了,您可以参考接下来的代码清单 1 与代码清单 2。代码清单 1 提供了未处理类的分解输出(从 javap 工具来),同时代码清单 2 为处理过的类提供了分解输出。注意代码清单 2 中 italics 的行就是作为处理步骤一部分导入的代码部分。

清单 1. 未处理的类文件

Compiled from "Part.java" 
public class com.ibm.storeapp.models.Part extends java.lang.Object{ 
public com.ibm.storeapp.models.Part(int); 
 Code: 
  0:  aload_0 
  1:  invokespecial  #15; //Method java/lang/Object."<init>":()V 
  4:  iload_1 
  5:  bipush 10 
  7:  if_icmple    18 
  10: aload_0 
  11: iload_1 
  12: invokespecial  #18; //Method setDiscountedPrice:(I)V 
  15: goto  23 
  18: aload_0 
  19: iload_1 
  20: putfield    #21; //Field price:I 
  23: return 
  
  public int getPrice(); 
 Code: 
  0:  aload_0 
  1:  getfield    #21; //Field price:I 
  4:  ireturn 
 
} 


清单 2. 每一个可执行单元处理的类文件

Compiled from "Part.java" 
public class com.ibm.storeapp.models.Part extends java.lang.Object{ 
public com.ibm.storeapp.models.Part(int); 
 Code: 
 0: ldc #49; //String com/ibm/storeapp/models/Part 2: iconst_0 3: iconst_0 4: 
  invokestatic #48; //Method llc_probe$Probe_0._executableUnit:(Ljava/lang/String;II)V 
 7:  aload_0 
 8:  invokespecial  #15; //Method java/lang/Object."<init>":()V 
 11: ldc #49; //String com/ibm/storeapp/models/Part 13: iconst_0 14: iconst_1 15: 
  invokestatic #48; //Method llc_probe$Probe_0._executableUnit:(Ljava/lang/String;II)V 
 18: iload_1 
 19: bipush 10 
 21: if_icmple    46 
 24: ldc #49; //String com/ibm/storeapp/models/Part 26: iconst_0 27: iconst_2 28: 
  invokestatic #48; //Method llc_probe$Probe_0._executableUnit:(Ljava/lang/String;II)V 
 31: aload_0 
 32: iload_1 
 33: invokespecial  #18; //Method setDiscountedPrice:(I)V 
 36: ldc #49; //String com/ibm/storeapp/models/Part 38: iconst_0 39: iconst_3 40: 
  invokestatic #48; //Method llc_probe$Probe_0._executableUnit:(Ljava/lang/String;II)V 
 43: goto  58 
 46: ldc #49; //String com/ibm/storeapp/models/Part 48: iconst_0 49: iconst_4 50: 
  invokestatic #48; //Method llc_probe$Probe_0._executableUnit:(Ljava/lang/String;II)V 
 53: aload_0 
 54: iload_1 
 55: putfield    #21; //Field price:I 
 58: ldc #49; //String com/ibm/storeapp/models/Part 60: iconst_0 61: iconst_5 62: 
  invokestatic #48; //Method llc_probe$Probe_0._executableUnit:(Ljava/lang/String;II)V 
 65: return 
 
 public int getPrice(); 
 Code: 
 0: ldc #49; //String com/ibm/storeapp/models/Part 2: iconst_2 3: iconst_0 4: 
  invokestatic #48; //Method llc_probe$Probe_0._executableUnit:(Ljava/lang/String;II)V 
 7:  aload_0 
 8:  getfield    #21; //Field price:I 
 11: ireturn 
 static {}; Code: 0: ldc #49; //String com/ibm/storeapp/models/Part 2: ldc #55; 
  //String Part.java 4: ldc #57; //String <init>(I)V+setDiscountedPrice(I)V 
  +getPrice()I 6: ldc #59; //String #10+11032,301,3 8: invokestatic #54; 
  //Method llc_probe$Probe_0._staticInitializer: 
  (Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V 11: return 
 
} 
 

在 Rational Application Developer 中生成覆盖率统计数据

Rational Code Coverage 特性的一个主要的优势在于,您可以通过切换到项目 Properties 的 Code Coverage 窗格,来将其在 Rational Application Developer 中的 Java 项目上激活,如图 2 所示。

图 2. 项目 Properties 中的代码覆盖窗格
IBM Rational Application Developer 代码覆盖工具入门简介

选择图 2 中的 Enable code coverage 复选框以激活项目的代码覆盖率,并评价覆盖下项目的类。您还可以使用该窗格来定制可接受的覆盖率层次。接下来描述了组合的支持层次:

类型覆盖率:一个类中覆盖的类型百分比

方法覆盖率:一个类中覆盖的方法百分比

行覆盖率:类文件中覆盖的行百分比

块覆盖率:一个类文件中覆盖的块的百分比。注意一个块会参考一个可执行的单元(如 以前描述的那样 )

您还可以指定通用的筛选规则,而且它们可以用于控制在项目中评价哪些内容。默认条件下,项目中的所有类都会得到评价,但是您可以创建通用的筛选规则来排除目标包或者指定类型,如果您需要限制结果的话。

Package Explorer

在您激活一个项目中的代码覆盖率以后,覆盖率统计数据就会在下一次程序启动的时候生成。注意不是所有类型启动配置都会自动生成统计数据。表 1 显示了 Rational Application Developer 内支持的启动类型。

表 1. 支持的启动配置

启动类型
Java Applet
OSGi 框架
JUnit
JUnit 插件测试
Java 程序
Eclipse 程序
标准 Widget Toolkit (SWT)程序

在 下载 部分中提供了一个范例程序,本文至始至终都会使用该范例。该程序是一个不同交通工具(汽车、货车、摩托车等等)的简单再现。图 3 中是一个概括了该程序结构的 UML 图。

图 3. 范例程序的 UML 图
IBM Rational Application Developer 代码覆盖工具入门简介

在项目中有两种定义好的 JUnit 测试:TestCar.java 与 TestCarImproved.java。正如其名字所暗含的一样,这些测试的目标是 Car.java 类。而在 Rational Application Developer 的 Java 视角中,您可以右击 TestCar.java 并选择 Run As > JUnit test 来启动 TestCar.java 测试。JUnit 测试的结果会正常显示在 JUnit 视图中。覆盖率数据的结果会集成到 Rational Application Developer UI 中,而且您可以切换回 Package Explorer 来分析它们。图 4 显示了 TestCar.java 测试的一个范例结果。

图 4. Package Explorer 中显示的 TestCar.java 的覆盖率数据
IBM Rational Application Developer 代码覆盖工具入门简介

默认条件下,UI 只与行覆盖率信息一起注释;但是,您可以在工作台偏好中更改它们,并且可以选择为包、类型以及块而包含覆盖率。每一个 Java 项目的百分比是最后一次执行代码覆盖率的中断。您可以在 Package Explorer 中深入研究各种 Java 工件(例如,类、类型与方法)以得到较低组合层次上的覆盖率统计数据。

结果得到的结果的颜色情况取决于成功率:默认条件下,红色意味着没有达到可接受的覆盖率层次,而绿色则意味着得到了适当的覆盖率范围。一般来说,测试的目的在于达到类可接受覆盖率层次的结果。

基于如图 4 所示的结果,第一个测试是不充分的:Car 类(以及抽象父类 AbstractFourWheelVehicle 和 Vehicle)并不能达到适当的覆盖率层次。幸运的是,您有第二次尝试的机会:TestCarImproved.java。您可以再一次将测试作为一次正常的 JUnit 执行,而结果将会在 Package Explorer 中进行自动更新(图 5)。

图 5. Package Explorer 中显示的 TestCarImproved.java 的代码覆盖率数据
IBM Rational Application Developer 代码覆盖工具入门简介

Java 编辑器

行覆盖率结果也是显示的,并在 Java 编辑器中有所标记,而您可以使用它来得到一个更加明确的指示,也就是每一类中涉及到了哪一行。在生成覆盖率数据之后,您就可以使用 Java 编辑器来在项目中打开任意的类了,编辑器中左边的标尺栏显示了关于覆盖率的信息。图 6 显示了 Vehicle.java 的结果:

图 6. Java 编辑器中显示的覆盖率结果
IBM Rational Application Developer 代码覆盖工具入门简介

颜色编辑与在 Package Explorer 中所显示的是一样的。也就是,默认条件下,绿色的行是覆盖的而红色的则不是覆盖的。在 Java 编辑器中查看结果有一个微弱的优势,那就是它还指示了部分覆盖的行。当在源代码中有不止一个的可执行单元时就会产生部分覆盖的行,但是它们中只有一个可以被执行。例如,查看图 6 中 setTargetSpeed(int speed) 方法中第一行的代码 :第一个可执行的单元是 if 声明,而第二个可执行的单元则是 return 声明。默认条件下,一个部分的行会被标上黄色。

生成报告

您可以将代码覆盖率结果数据汇编到报告之中并在 Rational Application Developer 中查看它们,或者将它们保存到文件系统中以便未来的分析。您可以生成两种不同类型的报告:Workbench 报告(基于 Eclipse)与 HTML 报告。为了生成一份报告,您可以选择 Run > Code Coverage > Generate Report。图 7 显示了报告生成对话框。

图 7. 报告生成对话框
IBM Rational Application Developer 代码覆盖工具入门简介

您可以在 Rational Application Developer 中使用对话框中的 Quick View 选项来创建并查看一个报告,或者使用 Save Report 选项将其保存到文件系统中去。

工作台报告

工作台报告(也叫做基于 Eclipse 的报告)为项目提供了所有覆盖率统计数据的稳固视图,并包含了执行时项目中所有类的覆盖率数据。图 8 显示了一个基于 Eclipse 流传的报告。

图 8. 一个基于 Eclipse 报告的覆盖率结果
IBM Rational Application Developer 代码覆盖工具入门简介

工作台报告与 Rational Application Developer 相集成具有额外的优势,因为您可以使用它们作为一个快速的工具,以提供了关于部分代码的视角,这些代码需要改进的测试覆盖率数据。如图 8 所示,工作台报告中的统计数据包含了所有层次组成的覆盖率信息:从一个包到一种方法。右击任意的 Java 工件会显示出一个带有两种操作的弹出菜单: 在 Package Explorer 中显示 与 在 Java 编辑器中将其打开。对于识别和研究带有低覆盖率的代码区域来说,它们是非常有用的工具,因为通过将它们在适当的浏览器或者编辑器中打开,从而强调了代码的选择区域。

HTML 报告

HTML 报告显示了基于 Eclipse 报告所提供的相同类型的信息,但是呈现的格式却是 HTML 的。这些报告能够发挥一定程度的作用,因为它们为在独立于 Rational Application Developer 之外去分析覆盖率数据提供了一种有效的方法,您可以与团队的其他成员一起分享,或者将其发布到一个网站上以方便查看。

在工作台的外部生成统计数据

Rational Code Coverage 工具的一个主要特性是其在 Rational Application Developer 外部生成统计数据的能力。它提供了额外的灵活性,并使得您可以定制环境以利用系统中的 Rational Code Coverage 特性。例如,一个自然的合并过程就是创建一个构建环境并使用 JUnit 测试来生成统计数据。

通过执行以下的三个步骤:评价,执行以及生成报告,您可以将 Rational Code Coverage 特性集成到您的环境之中。

第 1 步. 评价

您可以使用两种不同的方法来评价您的程序。第一个就是使用 <RAD_HOME>/plugins/com.ibm.rational.llc.engine_<date>/scripts 目录中提供的 instrument.bat/sh 脚本。本文并没有关注这个脚本,但是您可以参考 Rational Application Developer 文献以得到更多的信息,如果需要的话。第二个方法是使用 Rational Code Coverage 特性提供的评价 Ant 任务。代码清单 3 显示了评价任务配置的范例用法,以得到本文中的范例程序。

清单 3. 本文范例程序的评价 Ant 任务的范例用法

<target name="instrument"> 
 <taskdef name="instrument" 
  classname="com.ibm.rational.llc.engine.instrumentation.anttask.InstrumentationTask" 
  classpath="{path to com.ibm.rational.llc.engine plugin}"/> 
 <instrument saveBackups="true" 
  baseLineFile="project.baseline" 
  buildPath="VehicleProject" 
  outputDir="VehicleProjectInstr"/> 
</target> 

对预期参数的快速预览,已经列在后续的表 2 中。

表 2. 指南任务的输入参数

参数 描述
buildPath对文件系统上项目的路径
outputDir(可选的)评价项目的输出目录。如果没有指定, buildPath 中的类将会进行评价。
baseLineFile(可选的)基线项目索引文件的输出位置。查看接下来的段落以得到关于该文件更多的信息。
saveBackups(可选的)如果在评价之前先备份原始的类文件,那么您可以设置为 true。

评价的两种方法都会输出一个基线文件。所谓的基线文件是一个特定于 Rational Code Coverage 特性的概念。基线文件包含了项目中所有类的一个索引,并维护了关于每一个类的额外元数据。该文件在报告阶段(接下来的第 3 步)使用以决定程序中的哪一个类 不被 覆盖。该步是需要的,因为 Rational Code Coverage 数据收集引擎只是在 Java™ Virtual Machine(JVM)载入类时才会标记一个类,所以没有执行的类的列表在没有元数据存在的条件下就不能进行决定了。如果基线文件没有在报告时出现,那么没有载入的类将不会出现在报告中。

第 2 步. 执行

为了执行评价好的类,您必须在启动时对 Java 环境做适当的配置。执行过程中所需的两个特定的参数解释如下:

-Dcoverage.out.file=<absolute path to output file>:该 JUM 论断指定的文件就是覆盖率统计数据的输出位置

向 classpath 添加 <Rational Application Developer HOME>/plugins/com.ibm.rational.llc.engine_<date>/RLC.jar:因为代码已经进行了评价并得到了 Rational Code Coverage 数据搜索引擎的回馈,RLC.jar 文件需要在运行时位于 classpath 处。

JUnit Ant 任务提供了这些参数。代码清单 4 提供了范例用法。

清单 4. 怎样指定 Ant 启动中 Rational Code Coverage 特性论断的范例

<target name="run"> 
 <junit showoutput="true" fork="yes"> 
 <jvmarg value="-Dcoverage.out.file={absolute path to the output file}"/> 
 <classpath> 
  <pathelement location="{absolute path to the 
  <Rational Application Developer HOME>/plugins/com.ibm.rational.llc.engine_<date> 
    /RLC.jar file}"/> 
  <pathelement location="{path to the project classes}"/> 
  <pathelement path="{absolute path to the junit.jar}" /> 
 </classpath> 
 <test name="com.ibm.vehicles.tests.TestCar" outfile="TestCar" /> 
 </junit> 
</target> 

第 3 步. 生成报告

您可以使用 Rational Code Coverage 特性所提供的另外一项 Ant 任务来生成报告。该项任务使用 BIRT Eclipse.org 项目所提供的报告功能,并因此需要您去下载 BIRT V2.3.2 Reporting Engine 独立版。该操作可以通过访问 http://www.eclipse.org/birt/download,选择 V2.3.2 版本并下载 Report Engine 版本来完成。注意该 Ant 任务只能产生 HTML 报告。

清单 5 提供了报告 Ant 任务的范例用法。注意,作为输入,它需要在第 2 步中所生成的覆盖率数据以及在第 1 步中(可选)所生成的基线文件。

清单 5. 本文中范例程序报告生成 Ant 任务的范例

<target name="generate-report"> 
 <path id="lib.path"> 
 <pathelement location="{absolute path to the 
  <Rational Application Developer HOME>/plugins/ 
    com.ibm.rational.llc.common_<date>.jar plugin}"/> 
 <pathelement location="{absolute path to the 
  <Rational Application Developer HOME>/plugins/ 
    com.ibm.rational.llc.report_<date> plugin}"/> 
 <pathelement location="{absolute path to the 
  <Rational Application Developer HOME>/plugins/ 
    org.eclipse.equinox.common_<date>.jar plugin}"/> 
 <fileset dir="{absolute path to the BIRT ReportEngine directory}\lib" includes="*.jar"/> 
 </path> 
 
 <taskdef name="code-coverage-report" 
  classname="com.ibm.rational.llc.report.birt.adapters.ant.ReportGenerationTask" 
  classpathref="lib.path"/> 
 
 <code-coverage-report 
  outputDir="{absolute path to the report output directory}" 
  coverageDataFile="{absolute path to the coveragedata file generated in step 1}" 
  baseLineFiles="{absolute path to the baseline file generated in step 1}"/> 
</target> 

在图 9 中显示有一个范例 HTML 报告。使用 Ant 任务生成 HTML 报告会提供一种方法,用户可以通过这种方法来查看独立于 Rational Application Developer 之外 Ant 环境中生成的统计数据。

图 9. HTML 报告中的覆盖率结果
IBM Rational Application Developer 代码覆盖工具入门简介

尝试一下!

本文的 下载 部分为 Ant 环境提供了范例脚本以及构建文件,该环境可以用于指导、执行并生成关于范例程序的报告。如果您对测试该环境感兴趣,那么您可以参考一下 Standalone.zip 文件中的 README 文件。

在 WebSphere Application Server 上生成统计数据

使用 WebSphere Application Server 来生成代码覆盖率统计数据在这里是支持的,但是不幸的是,这个版本中并不支持来自 Rational Application Developer 内部的自动化配置。但是,版本中提供的 Rational Code Coverage 特性足够灵活以集成到服务器环境中去,包括 WebSphere Application Server。为了对代码覆盖率而配置您的 WebSphere Application Server ,您需要按照以下步骤进行操作:

启动服务器

登录到 Administrative Console

在左边的窗格中,展开 Servers

展开 Server Types

点击 WebSphere 程序服务器

选择适当的程序服务器

展开右部窗格选项区域内 Server Infrastructure 部分中 Java and Process Management 项

点击 Process definition

点击 Additional Properties 部分中的 Java Virtual Machine

在 Boot Classpath 部分中,添加 RLC.jar 文件。如上面介绍的那样,该 .jar 文件位于 Rational Code Coverage 数据收集引擎中,并位于 <Rational Application Developer HOME>/plugins/com.ibm.rational.llc.engine_<date>/RLC.jar

在 Generic JVM arguments 中,添加 -Dcoverage.out.file={output file} JVM 论断。如上面所述的那样,该论断指定了应该将输出的统计数据保存在什么地方。

保存服务器配置并重启服务器。

图 10 显示了在作出以上所做的变更之后 Administrative Console 的屏幕截图。注意在每一个服务器实例的后面必须有一个指南,这些服务器实例会执行一个代码覆盖率程序。

图 10. WebSphere Application Server 对 Rational Code Coverage 特性的配置
IBM Rational Application Developer 代码覆盖工具入门简介

在服务器对代码覆盖率进行配置之后,您就可以手动对服务器进行代码覆盖率的配置了(从 Administration Console 上进行),或者使用 Rational Application Developer 中的集成支持功能。注意覆盖率的结果不会自动导入到 Rational Application Developer 中以进行分析,这样您需要执行接下来的步骤来将统计数据导回到工作区中:

在 Rational Application Developer 中的 Java 视角中,右击 Package Explorer 并选择 Import

展开 Code Coverage

选择 Code Coverage Data File 并点击 Next

选择 Data is located on the file system 选项并点击 Next

在 Coverage Data file 区域中,选择服务器所提供的文件系统上的覆盖率数据

在 Into folder 区域中,选择工作区中的一个目录以保存导入的文件。

在 Associate with Project 区域中选择适当的项目。您应该将统计数据与工作区中的项目联系起来,工作区中包含的源代码用于在服务器上生成统计数据。

点击 Finish

当覆盖率数据文件位于工作区中时,您可以在 UI 中显示统计数据并生成报告。您可以右击覆盖率文件并选择 Code Coverage > Show code coverage indicators 或者 Generate Report 来完成该操作。该功能可以使您更加受益,因为它提供了对分析 Rational Application Developer 中结果所用所有工具的访问途径。

本文示例源代码或素材下载

Tags:IBM Rational Application

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接