真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

java如何分析代碼 如何看java代碼

java代碼解讀

第一個(gè)if是判斷searchkey是不是空的,如果不是空的,就追加到name字段作為查詢條件,like模糊查詢

網(wǎng)站設(shè)計(jì)制作過程拒絕使用模板建站;使用PHP+MYSQL原生開發(fā)可交付網(wǎng)站源代碼;符合網(wǎng)站優(yōu)化排名的后臺(tái)管理系統(tǒng);成都做網(wǎng)站、成都網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設(shè)收費(fèi)合理;免費(fèi)進(jìn)行網(wǎng)站備案等企業(yè)網(wǎng)站建設(shè)一條龍服務(wù).我們是一家持續(xù)穩(wěn)定運(yùn)營(yíng)了十余年的創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司。

接著第二個(gè)if判斷如果status的值不為空,就追加到status作為條件

如果status為空,走else分支,從userContext中獲取到employee對(duì)象,接著判斷,如果它的角色不是manager的話

把這個(gè)對(duì)象的id拿出來,作為seller.Id的條件進(jìn)行查詢

java源代碼分析 實(shí)在是不太會(huì),求高手教教我。

package?test2;

import?java.io.BufferedReader;

import?java.io.File;

import?java.io.FileInputStream;

import?java.io.FileOutputStream;

import?java.io.IOException;

import?java.io.InputStream;

import?java.io.InputStreamReader;

import?java.util.HashMap;

import?java.util.Map;

import?java.util.Set;

public?class?JavaCodeAnalyzer?{

public?static?void?analyze(File?file)?throws?IOException{

//FileOutputStream?fos?=?new?FileOutputStream("F;"+File.separator+"result.txt");

if(!(file.getName().endsWith(".txt")||file.getName().endsWith(".java"))){

System.out.println("輸入的分析文件格式不對(duì)!");

}

InputStream?is=?new?FileInputStream(file);

BufferedReader?br=?new?BufferedReader(new?InputStreamReader(is));

String?temp;

int?count=0;

int?countSpace=0;

int?countCode=0;

int?countDesc=0;

MapString,?Integer?map?=?getKeyWords();

while((temp=br.readLine())!=null){

countKeys(temp,?map);

count++;

if(temp.trim().equals("")){

countSpace++;

}else?if(temp.trim().startsWith("/*")||temp.trim().startsWith("http://")){

countDesc++;

}else{

countCode++;

}

}

System.out.printf("代碼行數(shù):"+countCode+"占總行數(shù)的%4.2f\n",(double)countCode/count);

System.out.printf("空行數(shù):"+countSpace+"占總行數(shù)的%4.2f\n",(double)countSpace/count);

System.out.printf("注釋行數(shù):"+countDesc+"占總行數(shù)的%4.2f\n",(double)countDesc/count);

System.out.println("總行數(shù):"+count);

System.out.println("出現(xiàn)最多的5個(gè)關(guān)鍵字是:");

System.out.println("");

System.out.println("");

System.out.println("");

System.out.println("");

System.out.println("");

}

public?static?void?main(String[]?args)?{

getKeyWords();

File?file?=?new?File("F://Test.java");

try?{

analyze(file);

}?catch?(IOException?e)?{

//?TODO?自動(dòng)生成?catch?塊

e.printStackTrace();

}

}

public?static?MapString,Integer?getKeyWords(){

MapString,Integer?map?=?new?HashMapString,?Integer();

String[]keywords?=?{"abstract","assert","boolean","break","byte","case","catch","char","class","continue","default","do","double","else","enum","extends","final","finally","float","for","if","implements","import","instanceof","int","interface","long","native","new","package","private","protected","public","return","????strictfp","short","static","super","????switch","synchronized","this","throw","throws","transient","try","void","volatile","while","goto","const"};

for(String?s:keywords){

map.put(s,?0);

}

return?map;

}

public?static?void?countKeys(String?s,MapString,Integer?map){

SetString?keys?=?map.keySet();

for(String?ss:keys){

if(s.indexOf(ss)!=-1){

map.put(ss,?map.get(ss)+1);

}

}

}

}

上班沒啥時(shí)間了,還有點(diǎn)沒寫完,你在想想。

怎么看懂java代碼?

想要看到都能java代碼,需要了解編程的基礎(chǔ)知識(shí),變量,表達(dá)式,程序執(zhí)行結(jié)構(gòu),邏輯判斷等等。最重要是要學(xué)會(huì)如何調(diào)試代碼,慢慢練習(xí),熟練了自然就會(huì)了。

JXTA Platform JAVA參考實(shí)現(xiàn)源代碼分析(2)

引言 管道的概念源于Unix 是不同線程之間直接傳輸數(shù)據(jù)的基本手段 JDK中java io包中就有管道類 同時(shí) 管道在JXTA中是最基本的概念 是對(duì)等點(diǎn)之間的數(shù)據(jù)傳輸?shù)闹饕绞?對(duì)等管道協(xié)議(PBP)明確規(guī)范了對(duì)等管道的綁定 解析 響應(yīng) 本文依次剖析集中式(JDK)和對(duì)等環(huán)境下(JXTA)管道的實(shí)現(xiàn)方式 對(duì)比分析其異同 然后嘗試在JXTA中建立一個(gè)虛擬的全雙工的管道 本文的目標(biāo)是通過對(duì)不同環(huán)境下管道的實(shí)現(xiàn)方式對(duì)比分析 來理解為什么JXTA采用管道作為基本的數(shù)據(jù)傳輸手段 管道的形象化描述 一個(gè)生活中的情景 現(xiàn)在有兩個(gè)地區(qū)A B A是石油生產(chǎn)區(qū) B是石油消費(fèi)區(qū) 現(xiàn)在B地區(qū)需要消費(fèi)A地區(qū)的石油 當(dāng)然可以通過海運(yùn) 空運(yùn)獲得 然而最通常的方式是架設(shè)輸油管道 如圖所示   引言 管道的概念源于Unix 是不同線程之間直接傳輸數(shù)據(jù)的基本手段 JDK中java io包中就有管道類 同時(shí) 管道在JXTA中是最基本的概念 是對(duì)等點(diǎn)之間的數(shù)據(jù)傳輸?shù)闹饕绞?對(duì)等管道協(xié)議(PBP)明確規(guī)范了對(duì)等管道的綁定 解析 響應(yīng) 本文依次剖析集中式(JDK)和對(duì)等環(huán)境下(JXTA)管道的實(shí)現(xiàn)方式 對(duì)比分析其異同 然后嘗試在JXTA中建立一個(gè)虛擬的全雙工的管道 本文的目標(biāo)是通過對(duì)不同環(huán)境下管道的實(shí)現(xiàn)方式對(duì)比分析 來理解為什么JXTA采用管道作為基本的數(shù)據(jù)傳輸手段 管道的形象化描述 一個(gè)生活中的情景 現(xiàn)在有兩個(gè)地區(qū)A B A是石油生產(chǎn)區(qū) B是石油消費(fèi)區(qū) 現(xiàn)在B地區(qū)需要消費(fèi)A地區(qū)的石油 當(dāng)然可以通過海運(yùn) 空運(yùn)獲得 然而最通常的方式是架設(shè)輸油管道 如圖所示 java中流的概念和管道的概念都可以通過此案例闡述 A與B之間連接的就是管道 負(fù)責(zé)將A的石油向B輸出 A向管道輸出數(shù)據(jù)(output) B從管道輸入數(shù)據(jù)(input) 可以這樣理解 管道是A的輸出對(duì)象 是B的數(shù)據(jù)源 這里就產(chǎn)生了三個(gè)類 輸出流A 輸入流B 管道 輸入流B負(fù)責(zé)如何獲取數(shù)據(jù)(read 操作) 輸出流A負(fù)責(zé)如何消費(fèi)數(shù)據(jù)(write操作) 管道負(fù)責(zé)連接它們(connect 操作) 其實(shí) 在實(shí)現(xiàn)時(shí) 管道類分解為管道口 管道出口 由入口出口負(fù)責(zé)連接 在復(fù)雜的網(wǎng)絡(luò)環(huán)境中 這種連接方式可以有專門的網(wǎng)絡(luò)協(xié)議負(fù)責(zé)(例如 JXTA中的PBP 全稱Pipe Bind Protocol) 由以上描述 我們可以清楚知道最原始的管道就是單向的 文章后面介紹的雙向管道 是用兩個(gè)單向管道虛擬的 而非真實(shí)的連接方式 不難發(fā)現(xiàn)管道最關(guān)鍵的問題是如何協(xié)調(diào)輸出(A)與輸入(B) 這在不同的網(wǎng)絡(luò)環(huán)境會(huì)遇到不同的問題 最簡(jiǎn)單的是同一JVM下的不同過程(線程或任務(wù))之間用同步方式傳遞數(shù)據(jù) 而對(duì)等環(huán)境下 如何去發(fā)現(xiàn)對(duì)方就是一個(gè)很現(xiàn)實(shí)的問題 這僅僅只是問題的其中之一 下面的章節(jié)會(huì)依次分析 集中式環(huán)境下管道的實(shí)現(xiàn) 問題的描述 A與B是在同一JVM中 A B有一方能夠發(fā)現(xiàn)另一方的存在 A將數(shù)據(jù)發(fā)往B方 A發(fā)送數(shù)據(jù)與B接收數(shù)據(jù)是相互獨(dú)立的 現(xiàn)在回到問題的最初 為什么要使用管道?A只管發(fā)送 B只管接受 那么數(shù)據(jù)在哪兒呢?經(jīng)過下面的分析 就會(huì)明白管道把管理數(shù)據(jù)緩沖區(qū)的重任交給了他自己 A B均是圍繞這個(gè)緩沖區(qū)來啟停線程的 顯然這才是問題的本質(zhì) JDK中 類PipeInputStream(即前面所述的B)與PipeOutputStream(即前面所述的的A)可以很好的解決這一問題 首先給出類圖如下   下面是將類PipeOutputStream的connect方法代碼簡(jiǎn)化后給予注釋 public synchronized void connect(PipedInputStream snk) throws IOException { sink = snk; //將PipeInputStream的實(shí)例作為PipeOutputStream的一個(gè)屬性 以便調(diào)用 snk in = ;//緩沖區(qū)的輸入位置 表示緩沖區(qū)為空 snk out = ;//緩沖區(qū)的輸出位置nnected = true;}連接以后 PipeOutputStream的write操作直接調(diào)用sink receive(b);這樣 對(duì)緩沖區(qū)buffer的維護(hù) 就變成了read()和receive()操作之間的線程同步 JDK對(duì)緩沖區(qū)的處理非常巧妙 采用了循環(huán)列表 它用緩沖區(qū)的標(biāo)志位的變化來代替數(shù)據(jù)的移動(dòng) 類似于生活中的時(shí)鐘把線性的時(shí)間規(guī)范為 小時(shí)來表示 這不屬于本文的論述范圍 就不繼續(xù)分析了 read操作 正常情況下 從out位置讀取數(shù)據(jù) 緩沖區(qū)空時(shí)進(jìn)入等待狀態(tài) 以輪詢的方式( 秒間隔)來自我釋放 receive操作 正常情況下 向in位置寫入數(shù)據(jù) 緩沖區(qū)滿時(shí)進(jìn)入等待狀態(tài) 同樣 以輪詢的方式( 秒間隔)來自我釋放 JXTA對(duì)等管道的實(shí)現(xiàn) 通過對(duì)JDK的分析 我們可以了解到在集中式環(huán)境下 管道的架設(shè)方案是比較簡(jiǎn)單的 在對(duì)等環(huán)境下(分布式環(huán)境下也類似) 出于同樣的目標(biāo) 遇到的問題卻在急劇的擴(kuò)大 例如 管道入口和出口之間如何相互發(fā)現(xiàn)?數(shù)據(jù)如何保證在不同的環(huán)境下傳送?甚至 對(duì)管道本身的概念發(fā)生質(zhì)疑 一定是單入口 單出口嗎?JXTA規(guī)范中 管道是在端點(diǎn)之上的服務(wù)或應(yīng)用之間發(fā)送和接收信息的虛擬連接通道 管道提供在對(duì)等端點(diǎn)傳輸之上的網(wǎng)絡(luò)抽象 管道有點(diǎn)到點(diǎn)和廣播兩種通信模式 JXTA是通過管道廣告來唯一標(biāo)示管道的 輸出管道要找到與其廣告相同的輸入管道才能發(fā)送數(shù)據(jù) 廣告內(nèi)容如下!DOCTYPE jxta:PipeAdvertisementjxta:PipeAdvertisement xmlns:jxta= ; Idurn:jxta:uuid A E AE ABBE EF CBE /Id Type JxtaUnicast /Type Name PipeExample /Name/jxta:PipeAdvertisement如果您需要對(duì)JXTA管道有實(shí)例化的概念 請(qǐng)參考Sing Li的使p p能進(jìn)行交互操作 Jxta命令shell 這篇文章有部分內(nèi)容專門介紹了如何在通過shell使用管道 本文主要是從編程的視角去看管道是如何實(shí)現(xiàn)的 客戶視角Project JXTA : Java Programmer s Guide Chapter 有個(gè)例子闡述如何去在對(duì)等點(diǎn)之間發(fā)送信息 讀者可以到下載源碼 現(xiàn)在從客戶視角簡(jiǎn)要的分析它的傳送原理 要深入的了解可以看下一節(jié)的系統(tǒng)視角分析 該例中 有兩個(gè)對(duì)等點(diǎn) 并且構(gòu)建了兩個(gè)不同的類 一個(gè)負(fù)責(zé)接收(Pipelistener) 一個(gè)負(fù)責(zé)發(fā)送(PipeExample) 具體的接收次序可以參考時(shí)序圖  educity cn/img_ / / / gif 類Pipelistener實(shí)現(xiàn)了接口PipeMsgListener 類PipeExample實(shí)現(xiàn)了接口OutputPipeListener 由時(shí)序圖(這是兩個(gè)JVM中的類 所以時(shí)序符號(hào)是獨(dú)立標(biāo)示的)可以清晰的獲知 各個(gè)對(duì)等點(diǎn)的前 步是相互獨(dú)立的 各自的第 步 采用回調(diào)的方式建立輸入和輸出管道 一旦對(duì)等系統(tǒng)探測(cè)到對(duì)方的存在 就分別觸發(fā)各自的事件發(fā)送或接收消息 顯然JXTA中管道是異步的 調(diào)試該例程時(shí) 注意先建立輸入管道 然后建立輸出管道 因?yàn)?輸出管道在一定的時(shí)間和次數(shù)內(nèi)探測(cè)不到輸入管道的存在 就會(huì)主動(dòng)放棄 否則 容易讓網(wǎng)絡(luò)系統(tǒng)在這些無休止的探測(cè)中癱瘓 系統(tǒng)視角從上面的例程中 可以了解對(duì)等管道的創(chuàng)建方法 以及數(shù)據(jù)流程 但是不能明確對(duì)等系統(tǒng)是如何去實(shí)現(xiàn)的 JXTA中管道的實(shí)現(xiàn)比在JDK中實(shí)現(xiàn)要復(fù)雜得多 具體的技術(shù)標(biāo)準(zhǔn)可以參考對(duì)等管道綁定協(xié)議(PBP) 此協(xié)議規(guī)范了JXTA中管道的概念 但并沒有涉及到如何去實(shí)現(xiàn) 這同樣是所有JXTA協(xié)議的特征 它們的目標(biāo)是闡述what it is 而把how to do it留給開發(fā)者 這樣有利于增強(qiáng)系統(tǒng)的開放性 其中Java參考實(shí)現(xiàn) 就是該協(xié)議實(shí)現(xiàn)的一個(gè)案例 以下將具體分析 首先看管道實(shí)現(xiàn)的類圖(以單播為例)  educity cn/img_ / / / gif 關(guān)鍵的類  InputPipeImpl 輸入管道的實(shí)現(xiàn)類 NonBlockingOutputPipe 輸出管道的實(shí)現(xiàn)類 PipeServiceImpl 管道服務(wù)的實(shí)現(xiàn)類 負(fù)責(zé)創(chuàng)建輸入輸出管道 PipeResolver 提供管道綁定的解析服務(wù) 通過客戶視角的分析 可以得知系統(tǒng)外部是通過PipeServiceImpl來獲取輸入輸出管道 那么消息是如何在對(duì)等系統(tǒng)中通過管道過濾和傳遞的? 從程序?qū)崿F(xiàn)的角度 涉及到太多的技術(shù)細(xì)節(jié) JXTA的參考實(shí)現(xiàn)中有著龐雜的監(jiān)聽系統(tǒng) 本文嘗試用一個(gè)案例從兩個(gè)層次去解析這個(gè)問題 兩個(gè)層次分別是消息的具體形式 服務(wù)和端點(diǎn)協(xié)議的具體分發(fā)策略 很顯然 這里我們把注意力放在了管道的架構(gòu)路徑上 而把如何去架構(gòu)放在了一邊 我想它們是有先后關(guān)系的 并且距離并不遙遠(yuǎn) 案例描述 現(xiàn)在假設(shè)有兩個(gè)對(duì)等點(diǎn)alas 和sisal 在一個(gè)局域網(wǎng)內(nèi) 按照客戶視角那一節(jié)的例程sisal先建立輸入管道 alas建立輸出管道 由于同一網(wǎng)內(nèi)可以用廣播的方式發(fā)送查詢信息 可以不設(shè)rendevous 并且路由是兩點(diǎn)間的 消息傳遞過程得到了一定的簡(jiǎn)化 案例分析 以上案例中 從輸入輸出管道的建立到完成對(duì)接并傳輸數(shù)據(jù)總共有 個(gè)步驟 sisal建立輸入管道 alasl建立輸出管道 需要查找輸入管道 通過廣播向網(wǎng)絡(luò)發(fā)出管道查詢消息 sisal獲得alas的管道查詢消息 通過單播向sisal發(fā)出響應(yīng)表示 alas獲得sisal的響應(yīng) 通過單播向alas發(fā)出數(shù)據(jù) sisal獲得數(shù)據(jù) lishixinzhi/Article/program/Java/gj/201311/27397


當(dāng)前標(biāo)題:java如何分析代碼 如何看java代碼
本文網(wǎng)址:http://weahome.cn/article/ddecpde.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部