聚合工程java的代碼 java聚合項目

求java編程的代碼

代碼如下,望采納

創(chuàng)新互聯(lián)公司是一家集做網(wǎng)站、網(wǎng)站建設、網(wǎng)站頁面設計、網(wǎng)站優(yōu)化SEO優(yōu)化為一體的專業(yè)的建站公司,已為成都等多地近百家企業(yè)提供網(wǎng)站建設服務。追求良好的瀏覽體驗,以探求精品塑造與理念升華,設計最適合用戶的網(wǎng)站頁面。 合作只是第一步,服務才是根本,我們始終堅持講誠信,負責任的原則,為您進行細心、貼心、認真的服務,與眾多客戶在蓬勃發(fā)展的市場環(huán)境中,互促共生。

public?class?PrintPrime{

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

//設置一個計數(shù)變量count,用于統(tǒng)計一行當中已經(jīng)輸出數(shù)字的個數(shù)

int?count?=?0;

//寫代碼時人為判斷200為非素數(shù),如果不考慮題目的嚴格要求的話,可以寫成200

for(int?i?=?100;i=200;i++){

//判斷數(shù)字是否為素數(shù),若是,則count+1并輸出數(shù)字

if(PrintPrime.IsPrime(i)){

count++;

System.out.print(i+"?");

}

//如果一行十個已經(jīng)輸出完畢,計數(shù)歸零,換行

if(count==10){

count=0;

System.out.println();

}

}

}

//判斷數(shù)字是否為素數(shù)

public?static?boolean?IsPrime(int?n){

//如果小于等于三,則大于一即為素數(shù)

if?(n?=?3)?{

return?n??1;

}

//從2循環(huán)到數(shù)字的開平方,算法優(yōu)化

for(int?i=2;i=Math.sqrt(n);i++){

if(n%i?==?0)

return?false;

}

return?true;

}

}

java怎么理解組合/聚合關系給個例子最好能將細點

聚合(Aggregation)?關系是關聯(lián)關系的一種,是強的關聯(lián)關系。聚合是整體和個體之間的關系。例如,汽車類與引擎類、輪胎類,以及其它的零件類之間的關系便整體和個體的關系。與關聯(lián)關系一樣,聚合關系也是通過實例變量實現(xiàn)的。但是關聯(lián)關系所涉及的兩個類是處在同一層次上的,而在聚合關系中,兩個類是處在不平等層次上的,一個代表整體,另一個代表部分。?

組合(Composition)?關系是關聯(lián)關系的一種,是比聚合關系強的關系。它要求普通的聚合關系中代表整體的對象負責代表部分對象的生命周期,組合關系是不能共享的。代表整體的對象需要負責保持部分對象和存活,在一些情況下將負責代表部分的對象湮滅掉。代表整體的對象可以將代表部分的對象傳遞給另一個對象,由后者負責此對象的生命周期。換言之,代表部分的對象在每一個時刻只能與一個對象發(fā)生組合關系,由后者排他地負責生命周期。部分和整體的生命周期一樣。

class?Driver?{???

//使用成員變量形式實現(xiàn)關聯(lián)???

Car?mycar;???

public?void?drive(){???

mycar.run();???

}???

...???

//使用方法參數(shù)形式實現(xiàn)關聯(lián)???

public?void?drive(Car?car){???

car.run();???

}???

}

聚合關系是是一種比較強的關聯(lián)關系,java中一般使用成員變量形式實現(xiàn)。對象之間存在著整體與部分的關系。例如上例中

class?Driver?{???

//使用成員變量形式實現(xiàn)聚合關系???

Car?mycar;???

public?void?drive(){???

mycar.run();???

}???

}

假如給上面代碼賦予如下語義:車是一輛私家車,是司機財產(chǎn)的一部分。則相同的代碼即表示聚合關系了。聚合關系一般使用setter方法給成員變量賦值。?

假如賦予如下語義:車是司機的必須有的財產(chǎn),要想成為一個司機必須要先有輛車,車要是沒了,司機也不想活了。而且司機要是不干司機了,這個車就砸了,別人誰也別想用。那就表示組合關系了。一般來說,為了表示組合關系,常常會使用構(gòu)造方法來達到初始化的目的,例如上例中,加上一個以Car為參數(shù)的構(gòu)造方法?

public?Driver(Car?car){???

mycar?=?car;???

}

所以,關聯(lián)、聚合、組合只能配合語義,結(jié)合上下文才能夠判斷出來,而只給出一段代碼讓我們判斷是關聯(lián),聚合,還是組合關系,則是無法判斷的。

如何用idea創(chuàng)建maven的聚合工程

File-New-Project,然后選擇maven,具體操作見圖(2):

新手一般選擇quickstart,因為相關配置少,可以很快建好一個maven項目,如有需求可以選擇與需求相關的其他archetype(比如如果是web項目,你可以選擇maven-archetype-webapp,idea就會自動幫你把web目錄建好)。

打開新建的maven項目后Messages窗口會出現(xiàn)圖(6)的信息

這就說明maven在下載相關配置,不用著急,等一會兒,這是我們新建一個src文件夾用來儲存java代碼

一個java項目的代碼怎么整合到一起

一個java項目的代碼一般使用的svn版本控制工具來整合到一起。

svn是可以每天更新代碼,上傳各自代碼,遇到?jīng)_突的時候,可以比較解決。

什么是java聚合工程

聚合就是由很多節(jié)點合到一起的一個工程,但是每個節(jié)點不能獨立存在。有一個相對的概念叫組合,組合也有很多節(jié)點組成,但是它的每個節(jié)點可以獨立存在。

如何寫出更好的Java代碼

1. 優(yōu)雅需要付出代價。

從短期利益來看,對某個問題提出優(yōu)雅的解決方法,似乎可能花你更多的時間。但當它終于能夠正確執(zhí)行并可輕易套用于新案例中,不需要花上數(shù)以時計,甚至以天計或以月計的辛苦代價時,你會看得到先前所花功夫的回報(即使沒有人可以衡量這一點)。這不僅給你一個可更容易開發(fā)和調(diào)試的程序,也更易于理解和維護。這正是它在金錢上的價值所在。這一點有賴某種人生經(jīng)驗才能夠了解,因為當你努力讓某一段程序代碼變得比較優(yōu)雅時,你并不是處于一種具生產(chǎn)力的狀態(tài)下。但是,請抗拒那些催促你趕工的人們,因為那么做只會減緩你的速度罷了。

2. 先求能動,再求快。

即使你已確定某段程序代碼極為重要,而且是系統(tǒng)的重要瓶頸,這個準則依然成立。盡可能簡化設計,讓系統(tǒng)能夠先正確動作。如果程序的執(zhí)行不夠快,再量測其效能。幾乎你總是會發(fā)現(xiàn),你所認為的”瓶頸”其實都不是問題所在。把你的時間花在刀口上吧。

3. 記住”各個擊破”的原理。

如果你所探討的問題過于混雜,試著想像該問題的基本動作會是什么,并假設這一小塊東西能夠神奇地處理掉最難的部分。這”一小塊”東西其實就是對象–請撰寫運用該對象的程序代碼,然后檢視對象,并將其中困難的部分再包裝成其他對象,依此類推。

4. 區(qū)分class開發(fā)者和class使用者(使用端程序員)。

Class 使用者扮演著”客戶”角色,不需要(也不知道)class的底層運作方式。Class開發(fā)者必須是class設計專家,并撰寫class,使它能夠盡可能被大多數(shù)新手程序員所用,而且在程序中能夠穩(wěn)當執(zhí)行。一套程序庫只有在具備通透性的情況下,使用起來才會容易。

5.當你撰寫class時,試著給予明了易懂的名稱,減少不必要的注解。

你給客戶端程序員的接口,應該保持概念上的單純性。不了這個目的,當函數(shù)的重載(overloading)適合制作出直覺、易用的接口時,請善加使用。

6. 也必你的分析和設計必須讓系統(tǒng)中的classes保持最少,須讓其Public interfaces保持最少,以及讓這些classes和其他classes之間的關聯(lián)性( 尤其是base classes)保持最少。

如果你的設計所得結(jié)果更甚于此,請問問自己,是否其中每一樣東西在整個程序生命期中都饒富價值?如果并非如此,那么,維護它們會使你付出代價。開發(fā)團隊的成員都有不維護”無益于生產(chǎn)力提升”的任何東西的傾向;這是許多設計方法無法解釋的現(xiàn)象。

7. 讓所有東西盡量自動化。先撰寫測試用的程序代碼(在你撰寫class之前),并讓它和class結(jié)合在一起。請使用makefile或類似工具,自動進行測試動作。

通過這種方式,只要執(zhí)行測試程序,所有的程序變動就可以自動獲得驗證,而且可以立即發(fā)現(xiàn)錯誤。由于你知道的測試架構(gòu)所具備的安全性,所以當你發(fā)現(xiàn)新的需求時,你會更勇于進行全面修改。請記住,程序語言最大的改進,是來自型別檢查、異常處理等機制所賦予的內(nèi)置測試動作。但這些功能只能協(xié)助你到達某種程度。開發(fā)一個穩(wěn)固系統(tǒng)時,你得自己驗證自己的classes或程序的性質(zhì)。

8. 在你撰寫class之前先寫測試碼,以便驗證你的class 是否設計完備。如果你無法撰寫測試碼,你便無法知道你的class 的可能長相。撰寫測試碼通常能夠顯現(xiàn)出額外的特性(features)或限制 ( constraints)__它們并不一定總是能夠在分析和設計過程中出現(xiàn)。測試碼也可做為展示class 用法的示例程序。

9. 所有軟件設計上的問題,都可以通過”引入額外的概念性間接層(conceptual indirection)”加以簡化。這個軟件工程上的基礎法則是抽象化概念的根據(jù),而抽象化概念正是面向?qū)ο蟪绦蛟O計的主要性質(zhì)。

10. 間接層(indirection)應該要有意義(和準則-9致)。

這里所指的意義可以像”將共用程序代碼置于惟一函數(shù)”這么簡單。如果你加入的間接層(或抽象化、或封裝等等)不具意義,它可能就和沒有適當?shù)拈g接層一樣糟糕。

11. 讓class盡可能微小而無法切割(atomic)。

賦予每個class單一而清楚的用途。如果你的classes或你的系統(tǒng)成長得過于復雜,請將復雜的classes切割成比較簡單的幾個classes。最明顯的一個判斷指針就是class的大?。喝绻艽螅敲此ぷ髁窟^多的機會就可能很高,那就應該被切割。重新設計class的建議線索是:

1) 復雜的switch語句:請考慮運用多態(tài)(Polymorphism)。

2) 許多函數(shù)各自處理類型極為不同的動作:請考慮切割為多個不同的(classes)。

12. 小心冗長的引數(shù)列(argument lists)。

冗長的引數(shù)列會使函數(shù)的調(diào)用動作不易撰寫、閱讀、維護。你應該試著將函數(shù)搬移到更適當?shù)腸lass中,并盡量以對象為引數(shù)。

13. 不要一再重復。

如果某段程序代碼不斷出現(xiàn)于許多derived class函數(shù)中,請將該段程序代碼置于某個base class 函數(shù)內(nèi),然后在derived class函數(shù)中調(diào)用。這么做不僅可以省下程序代碼空間,也可以讓修改該段程序代碼動作更易于進行。有時候找出此種共通程序代碼還可以為接口增加實用功能。

14. 小心switch語句或成串的if-else 子句。

通常這種情況代表所謂的”type-check coding”。也就是說究竟會執(zhí)行哪一段程序代碼,乃是依據(jù)某種型別信息來做抉擇(最初,確切型別可能不十分明顯)。你通??梢允褂美^承和多態(tài)來取代此類程序代碼;Polymorphical method (多態(tài)函數(shù))的調(diào)用會自動執(zhí)行此類型別檢驗,并提供更可靠更容易的擴充性。

15. 從設計觀點來看,請找出變動的事物,并使它和不變的事物分離。

也就是說,找出系統(tǒng)中可能被你改變的元素,將它們封裝于classes中。你可以在《Thinking in Patterns with Java》(可免費下載于 www. BruceEckel. Com)大量學習到這種觀念。

16. 不要利用subclassing來擴充基礎功能。

如果某個接口元素對class而言極重要,它應該被放在base class 里頭,而不是直到衍生(derivation)時才被加入。如果你在繼承過程中加入了函數(shù),或許你應該重新思考整個設計。

17. 少就是多。

從class 的最小接口開始妨展,盡可能在解決問題的前提下讓它保持既小又單純。不要預先考量你的class被使用的所有可能方式。一旦class被實際運用,你自然會知道你得如何擴充接口。不過,一旦class被使用后,你就無法在不影響客戶程序代碼的情況下縮減其接口。如果你要加入更多函數(shù)倒是沒有問題–不會影響既有的客戶程序代碼,它們只需重新編譯即可。但即使新函數(shù)取代了舊函數(shù)的功能,也請你保留既有接口。如果你得通過”加入更多引數(shù)”的方式來擴充既有函數(shù)的接口,請你以新引數(shù)寫出一個重載化的函數(shù);通過 這種方式就不會影響既有函數(shù)的任何客戶了。

18. 大聲念出你的classes,確認它們符合邏輯。

請base class和derived class 之間的關系是”is-a”(是一種),讓class和成員對象之間的關系是”has-a”(有一個)。

19. 當你猶豫不決于繼承(inheritance)或合成(組合,composition)時,請你問問自己,是否需要向上轉(zhuǎn)型(upcast)為基礎型別。

如果不需要,請優(yōu)先選擇合成(也就是是使用成員對象)。這種作法可以消除”過多基礎型別”。如果你采用繼承,使用者會認為他們應該可以向上轉(zhuǎn)型。

20. 運用數(shù)據(jù)成員來表示數(shù)值的變化,運用經(jīng)過覆寫的函數(shù)(overrided method)來代表行為的變化 。

也就是說,如果你找到了某個 class, 帶有一些狀態(tài)變量,而其函數(shù)會依據(jù)這些變量值切換不同的行為,那么你或許就應該重新設計,在subclasses 和覆寫后的函數(shù)(overrided methods)中展現(xiàn)行為止的差異。

21. 小心重載(overloading)。

函數(shù)不應該依據(jù)引數(shù)值條件式地選擇執(zhí)行某一段程序代碼。這種情況下你應該撰寫兩個或更多個重載函數(shù)(overloaded methods)

22. 使用異常體系(exception hierarchies)

最好是從Java標準異常體系中衍生特定的classes, 那么,捕捉異常的人便可以捕捉特定異常,之后才捕捉基本異常。如果你加入新的衍生異常,原有的客戶端程序仍能通過其基礎型別來捕捉它。

23. 有時候簡單的聚合(aggregation)就夠了。

飛機上的”旅客舒適系統(tǒng)”包括數(shù)個分離的元素:座椅、空調(diào)、視訊設備等等,你會需要在飛機上產(chǎn)生許多這樣的東西。你會將它們聲明為Private成員并開發(fā)出一個全新的接口嗎?不會的,在這個例子中,元素也是Public接口的一部分,所以仍然是安全的。當然啦,簡單聚合并不是一個常被運用的解法,但有時候的確是。

24. 試著從客戶程序員和程序維護的角度思考。

你的class應該設計得盡可能容易使用。你應該預先考量可能性有的變動,并針對這些 可能的變動進行設計,使這些變動日后可輕易完成。

25. 小心”巨大對象并發(fā)癥”。

這往往是剛踏OOP領域的過程式(procedural)程序員的一個苦惱,因為他們往往最終還是寫出一個過程式程序,并將它們擺放到一個或兩個巨大對象中。注意,除了application framework (應用程序框架,譯注:一種很特殊的、大型OO程序庫,幫你架構(gòu)程序本體)之外,對象代表的是程序中的觀念,而不是程序本身。

26. 如果你得用某種丑陋的方式來達成某個動作,請將丑陋的部分局限在某個class里頭。

27. 如果你得用某種不可移植方式來達成某個動作,請將它抽象化并局限于某個class里頭。這樣一個”額外間接層”能夠防止不可移植的部分擴散到整個程序。這種作法的具體呈現(xiàn)便是Bridge設計模式(design pattern)。

28. 對象不應僅僅只用來持有數(shù)據(jù)。

對象也應該具有定義明確界限清楚的行為。有時候使用”數(shù)據(jù)對象”是適當?shù)?,但只有在通用形容器不適用時,才適合刻意以數(shù)據(jù)對象來包裝、傳輸一群數(shù)據(jù)項。

29. 欲從既有的classes身上產(chǎn)生新的classes時,請以組合(composition)為優(yōu)先考量。

你應該只在必要時才使用繼承。如果在組合適用之處你卻選擇了繼承,你的設計就滲雜了非必要的復雜性。

30. 運用繼承和函數(shù)覆寫機制來展現(xiàn)行為上的差異,運用fields(數(shù)據(jù)成員)來展現(xiàn)狀態(tài)上的差異。

這句話的極端例子,就是繼承出不同的classes表現(xiàn)各種不同的顏色,而不使用”color”field.

31. 當心變異性(variance)。

語意相異的兩個對象擁有相同的動作(或說責任)是可能的。OO世界中存在著一種天生的引誘,讓人想要從某個class繼承出另一個subclass,為的是獲得繼承帶來的福利。這便是所謂”變異性”。但是,沒有任何正當理由足以讓我們強迫制造出某個其實并不存在的superclass/subclass關系。比較好的解決方式是寫出一個共用的base class,它為兩個derived classes制作出共用接口–這種方式會耗用更多空間,但你可以如你所盼望地從繼承機制獲得好處,而且或許能夠在設計上獲得重大發(fā)現(xiàn)。

32. 注意繼承上的限制。

最清晰易懂的設計是將功能加到繼承得來的class里頭;繼承過程中拿掉舊功能(而非增加新功能)則是一種可疑的設計。不過,規(guī)則可以打破。如果你所處理的是舊有的class程序庫,那么在某個class的subclass限制功能,可能會比重新制定整個結(jié)構(gòu)(俾使新class得以良好地相稱于舊 class)有效率得多。

33. 使用設計模式(design patterns)來減少”赤裸裸無加掩飾的機能(naked functionality)”。

舉個例子,如果你的class只應該產(chǎn)出惟一一個對象,那么請不要以加思索毫無設計的手法來完成它,然后撰寫”只該產(chǎn)生一份對象”這樣的注解就拍拍屁股走人。請將它包裝成singleton(譯注:一個有名的設計模式,可譯為”單件”)。如果主程序中有多而混亂的”用以產(chǎn)生對象”的程序代碼,請找出類似 factory method這樣的生成模式(creational patterns),使價錢可用以封裝生成動作減少”赤裸裸無加掩飾的機能”(naked functionality)不僅可以讓你的程序更易理解和維護,也可以阻止出于好意卻帶來意外的維護者。

34. 當心”因分析而導致的癱瘓(analysis paralysis)”。

請記住,你往往必須在獲得所有信息之前讓項目繼續(xù)前進。而且理解未知部分的最好也最快的方式,通常就是實際前進一步而不只是紙上談兵。除非找到解決辦法,否則無法知道解決辦法。Java擁有內(nèi)置的防火墻,請讓它們發(fā)揮作用。你在單一class或一組classes中所犯的錯誤,并不會傷害整個系統(tǒng)的完整性。

35. 當你認為你已經(jīng)獲得一份優(yōu)秀的分析、設計或?qū)崿F(xiàn)時,請試著加以演練。

將團隊以外的某些人帶進來-他不必非得是個顧問不可,他可以是公司其他團隊的成員。請那個人以新鮮的姿態(tài)審視你們的成果,這樣可以在尚可輕易修改的階段找出問題,其收獲會比因演練而付出的時間和金錢代價來得高。實現(xiàn) (Implementation)

36. 一般來說,請遵守Sun的程序編寫習慣。

價錢可以在以下網(wǎng)址找到相關文檔:java.sun.com/docs/codeconv/idex.html。本書盡可能遵守這些習慣。眾多Java程序員看到的程序代碼,都有是由這些習慣構(gòu)成的。如果你固執(zhí)地停留在過去的編寫風格中,你的(程序代碼)讀者會比較辛苦。不論你決定采用什么編寫習慣,請在整個程序中保持一致。你可以在home.wtal.de/software-solutions/jindent上找到一個用來重排Java程序的免費工具。

37. 無論使用何種編寫風格,如果你的團隊(或整個公司,那就更好了)能夠加以標準化,那么的確會帶來顯著效果。這代表每個人都可以在其他人不遵守編寫風格修改其作品,這是個公平的游戲。標準化的價值在于,分析程序代碼時所花的腦力較小,因而可以專心于程序代碼的實質(zhì)意義。

38. 遵守標準的大小寫規(guī)范。

將 class名稱的第一個字母應為大寫。數(shù)據(jù)成員、函數(shù)、對象(references)的第一個字母應為小寫。所有識別名稱的每個字都應該連在一塊兒,所有非首字的第一個字母都應該大寫。例如: ThisIsAClassName thisIsAMethodOrFieldName 如果你在static final 基本型別的定義處指定了常量初始式(constant initializers),那么該識別名稱應該全為大寫,代表一個編譯期常量。 Packages是個特例,其名稱皆為小寫,即使非首字的字母亦是如此。域名(org, net, edu 等等)皆應為小寫。(這是Java 1.1遷移至Java 2時的一項改變) 。

39、不要自己發(fā)明”裝飾用的”Private數(shù)據(jù)成員名稱。

通常這種的形式是在最前端加上底線和其他字符,匈牙利命名法(Hungarian notation)是其中最差的示范。在這種命名法中,你得加入額外字符來表示數(shù)據(jù)的型別、用途、位置等等。仿佛你用的是匯編語言(assembly language)而編譯器沒有提供任何協(xié)肋似的。這樣的命名方式容易讓人混淆又難以閱讀,也不易推行和維護。就讓classes和packages來進行”名稱上的范

圍制定(name scoping)”吧。

40、當你擬定通用性的class時,請遵守正規(guī)形式(canonical form)。

包括equals( )、hashCode( )、clone( ) ( 實現(xiàn)出Cloneable),并實現(xiàn)出Comparable和Serialiable等等。

本文題目:聚合工程java的代碼 java聚合項目
URL地址:http://muchs.cn/article2/hjecic.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供微信公眾號、Google、企業(yè)網(wǎng)站制作、App開發(fā)、全網(wǎng)營銷推廣、手機網(wǎng)站建設

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設公司