摘要:問題農(nóng)場一頭小母牛,母牛每年生母牛。母牛歲產(chǎn)母牛,年后多少牛前提第一頭母牛已經(jīng)歲思路脈絡(luò)面向?qū)ο蠡舅枷?,注意狀態(tài)和行為,抽象出對應(yīng)的屬性和方法思想考慮類母牛農(nóng)場一開始可能不會想到把農(nóng)場設(shè)計為一個類。
問題:
農(nóng)場一頭小母牛,
母牛每年生母牛。
母牛5歲產(chǎn)母牛,
20年后多少牛?
PS:前提:第一頭母牛已經(jīng)>=5歲
思路脈絡(luò):
面向?qū)ο蠡舅枷?,注意狀態(tài)和行為,抽象出對應(yīng)的屬性和方法
1、Object Oriented思想
考慮類:母牛、農(nóng)場
PS:一開始可能不會想到把農(nóng)場設(shè)計為一個類。但母牛是成長在農(nóng)場里的,隨著時間推移,農(nóng)場里的母牛數(shù)量不斷增長。
考慮屬性:母牛有age、農(nóng)場有oldcows群體(age >= 5) 和 newcows群體(age < 5)。
考慮方法:母牛可以生產(chǎn)小母牛:produceCow() ;農(nóng)場可以得到母??倲?shù) :getNums()
考慮類之間的關(guān)系:農(nóng)場的屬性oldcows、newcows是母牛的對象集合
2、具體實現(xiàn)
類Cow:
public class Cow { private int age; //母牛屬性:年齡 public Cow(int age) { super(); this.age = age; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public Cow produceCow() { if(age >= 5) { return new Cow(0); //若母牛年齡 >= 5歲,則生產(chǎn)小母牛 } return null; } }
類Farm:
import java.util.ArrayList; import java.util.Iterator; import java.util.List; public class Farm { //農(nóng)場的老母牛集合(age>=5)、小母牛集合(age<5) private static Listoldcows,newcows; static { oldcows = new ArrayList<>(); newcows = new ArrayList<>(); Cow cow=new Cow(5); //最初的5歲母牛 oldcows.add(cow); } //獲取第year年的母??倲?shù) public static void getNums(int year) { for(int i=0;i = 5) { oldcows.add(cow); newcows.remove(cow); break; //對java.util.ConcurrentModificationException的處理 } } for(Cow cow : oldcows) { Cow babycow = cow.produceCow(); newcows.add(babycow); } System.out.printf("第%d年農(nóng)場有%d只母牛呢!%n", i+1, oldcows.size() + newcows.size()); } } }
主類:
public class Test { public static void main(String[] args) { Farm.getNums(20); } }
問題反思:
1、在方法produceCow()中,如果將生出的小baby設(shè)置為0歲:
return new Cow(0);
2、一開始運行時會報錯:java.util.ConcurrentModificationException(并發(fā)修改異常)
原因:在對newcows進行遍歷的時候,并發(fā)地對它進行了remove操作 解決:在remove操作后立即執(zhí)行break跳出foreach語句。
3、在for(int i=0;i 引自: 一開始是將母牛age的++都寫到了newcows和oldcows各自的遍歷當(dāng)中去的,但是這樣程序就會有bug:新的一年變成5歲的母牛被放入oldcows后,age再次被++。所以要進行一些修改。
https://blog.csdn.net/ac2017f...
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://www.ezyhdfw.cn/yun/76102.html
摘要:很多人將這一波的上漲解讀為比特幣小牛市的到來,無論從技術(shù)層面還是從消息層面來看,比特幣都有逐步回暖的跡象。到日,關(guān)于英雄鏈網(wǎng)絡(luò)詐騙案被破獲的報道便鋪天蓋地地傳播開來。 摘要:不在風(fēng)口上,長了翅膀的項目同樣可以起飛,價值終究會超越時間。 showImg(https://segmentfault.com/img/bVbrS0N?w=4096&h=3575); 自四月初以來,比特幣就開啟了起...
摘要:很多人將這一波的上漲解讀為比特幣小牛市的到來,無論從技術(shù)層面還是從消息層面來看,比特幣都有逐步回暖的跡象。到日,關(guān)于英雄鏈網(wǎng)絡(luò)詐騙案被破獲的報道便鋪天蓋地地傳播開來。 摘要:不在風(fēng)口上,長了翅膀的項目同樣可以起飛,價值終究會超越時間。 showImg(https://segmentfault.com/img/bVbrS0N?w=4096&h=3575); 自四月初以來,比特幣就開啟了起...
摘要:如果初學(xué)者接觸的第一門語言是,學(xué)習(xí)曲線則會平滑得多,掌握一些基本語法和內(nèi)置的數(shù)據(jù)結(jié)構(gòu),已經(jīng)可以上手寫一些小工具或者小型應(yīng)用。如果你的學(xué)習(xí)時間充足,我的建議是一定要學(xué)數(shù)據(jù)結(jié)構(gòu)和算法。 前言 Python是最容易入門的編程語言,沒有之一。如果初學(xué)者接觸的第一門語言是C或者C++,對他們來說最難的不是語法,而是容易出現(xiàn)內(nèi)存泄漏、指針等問題。有時候排查這些問題對初學(xué)者的打擊很大,尤其是沒掌握排...
摘要:編者按本文作者為,主要介紹世上最怪異最難用的種編程語言。這些語言被稱為極品編程語言。創(chuàng)造它們的原因通常是為了測試編程語言設(shè)計的臨界,或者只是一個玩笑。就是母牛的編程語言設(shè)計時充分考慮了母牛的想法。 【編者按】本文作者為 Deepak Karanth,主要介紹世上最怪異、最難用的5種編程語言。文章系國內(nèi) ITOM 管理平臺 OneAPM 編譯呈現(xiàn)。 最難學(xué)編程語言有哪些?很多人都用過Ja...
閱讀 2551·2021-09-22 16:05
閱讀 3126·2021-09-10 11:24
閱讀 3728·2019-08-30 12:47
閱讀 3023·2019-08-29 15:42
閱讀 3453·2019-08-29 15:32
閱讀 2036·2019-08-26 11:48
閱讀 1145·2019-08-23 14:40
閱讀 962·2019-08-23 14:33