Java語(yǔ)言程序設(shè)計(jì)A實(shí)驗(yàn)3:接口剖析_第1頁(yè)
Java語(yǔ)言程序設(shè)計(jì)A實(shí)驗(yàn)3:接口剖析_第2頁(yè)
Java語(yǔ)言程序設(shè)計(jì)A實(shí)驗(yàn)3:接口剖析_第3頁(yè)
Java語(yǔ)言程序設(shè)計(jì)A實(shí)驗(yàn)3:接口剖析_第4頁(yè)
Java語(yǔ)言程序設(shè)計(jì)A實(shí)驗(yàn)3:接口剖析_第5頁(yè)
已閱讀5頁(yè),還剩10頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、實(shí)驗(yàn)課程名稱(chēng):Java語(yǔ)言程序設(shè)計(jì)A實(shí)驗(yàn)項(xiàng)目名稱(chēng)實(shí)驗(yàn)3:接口實(shí)驗(yàn)成績(jī)實(shí)驗(yàn)者專(zhuān)業(yè)班級(jí)組另U同組者無(wú)開(kāi)始日期第一部分:實(shí)驗(yàn)預(yù)習(xí)報(bào)告(包括實(shí)驗(yàn)?zāi)康募耙饬x,實(shí)驗(yàn)基本原理與方法,主要儀器設(shè)備及耗材,實(shí)驗(yàn)內(nèi)容及要求,實(shí)驗(yàn)方案與技術(shù)路線(xiàn)等)一實(shí)驗(yàn)?zāi)康募耙饬x1 自定義接口。2 自定義類(lèi)實(shí)現(xiàn)接口。3. 接口及實(shí)現(xiàn)類(lèi)的多態(tài)處理。二.實(shí)驗(yàn)基本原理與方法1. 接口的概念。2 接口對(duì)多態(tài)的支持。三主要儀器設(shè)備及耗材1. PC及其兼容機(jī)。2. 計(jì)算機(jī)操作系統(tǒng)。3. 程序編輯器 EditPlus / Eclipse。4. Java開(kāi)發(fā)工具 JDK。四. 實(shí)驗(yàn)內(nèi)容及要求自定義形狀接口Shape,該接口聲明了計(jì)算面積、周長(zhǎng)的方

2、法。然后,分別編寫(xiě)三角形類(lèi)Triangle、六邊形類(lèi)Hexagon、橢圓形類(lèi)Ellipse,它們都實(shí)現(xiàn)了 Shape接口。最后,編寫(xiě)測(cè)試類(lèi)ShapesDemo,多態(tài)地創(chuàng)建各種形狀對(duì)象,計(jì)算面積、周長(zhǎng)。五. 實(shí)驗(yàn)方案及技術(shù)路線(xiàn)(含各種形狀面積、周長(zhǎng)的計(jì)算公式,UML類(lèi)圖,注意事項(xiàng))因?yàn)槊糠N形狀的面積、周長(zhǎng)計(jì)算所需要的參數(shù)個(gè)數(shù)不同,并且不同類(lèi)型的三角形計(jì)算周 長(zhǎng)的面積的方法也不同,所以抽象類(lèi)的參數(shù)就定為可變長(zhǎng)度集合ArrayList,一般三角形的面積S=a*h/2,周長(zhǎng)L=a+b+c ;直角三角形面積 S=a*b,周長(zhǎng)L=a+b+ * a 2 - b 2 ,等邊三角形的 面積S=i3*a2/4,周

3、長(zhǎng)L=3*a ;六邊形的面積 S=3 3* a2/2,周長(zhǎng)L=6*a。以下是簡(jiǎn)略的UML類(lèi)圖:1)接口 ShapeOculAreaLit: A culGirthtListDoubk) ; double2) 三角形類(lèi)Triangle3Trianglea : double月 b : double. c : double. h : doublelL也 IktData.: ListvDoLiblEa c Trianglff(double) ” Tnanglefdouble, double)o 1 Triangle(double. double, double, double)G getListData

4、O : Li5t) -:: id業(yè) culArea(Ust*Double :e0a culGirth(lj5l) : double3) 六邊形類(lèi)J2_ Hex 日 gon嚴(yán) m : doublea listData : List*Double* c Hexagcrr(doijble)O厶 culArea(ListCoubl亡:double 住 culGirthfListDoubles) : double0 getListDataQ : list4)橢圓形類(lèi) 5? Ellipse丄口 a : doubleb : doublelistData : List & Ellipsefdouble, do

5、uble)亠 culArea(ListDoublo) : double 4 culGirth(List*Double*) : double0 getListDataQ : List.第二部分:實(shí)驗(yàn)過(guò)程記錄(可加頁(yè))(代碼、運(yùn)行結(jié)果、實(shí)驗(yàn)中出現(xiàn)的問(wèn)題及解決過(guò)程)importShape 接口: java.util.List;in terfacepublic double culArea(List list ); public double culGirth(Listlist );六邊形類(lèi)Hexagon:import java.util.*;public class Hexag on impleme

6、 nts Shapeprivate double a;List listData=new ArrayList();public Hexag on( double a)this.a = a; listData.add(a);Overridepublic double culArea(List list) double s=0;s=Math.sqrt(3)*3*Math.pow(list.get(0), 2)/2; return s;Overridepublic double culGirth(List list) double l=0;l=list.get(0)*6;return l;publi

7、c List getListData() return listData;三角形類(lèi)Triangle :import java.util.*;public class Triangleimplements Shape privatedoublea;privatedoubleb;privatedoublec;privatedoubleh;ListlistData =new ArrayList();publicTrian gle(double a)this . a = a; listData .add(1.0); listData .add( a);public Triangle( double a

8、, double this . a = a;this . b = b;listData .add(2.0);listData .add( a); listData .add( b);public Triangle( double a, double b) b, double c, doubleh)super ();this.a =a;this.b =b;this.c =c;this.h =h;listData.add(3.0);listData.add(a);listData.add(b);listData.add(c);listData.add(h);public List getListD

9、ata()return listData ;public void setListData(List this . listData = listData ;Overridepublic double culArea(List double s=0;if (list .get(0)=1.0)s=Math. sqrt (3)*Math. pow( list if (list .get(0)=2.0)s=list.get(1)*list .get(2)/2;if (list .get(0)=3.0)s=list.get(1)*list .get(4)/2;return s;Overridepubl

10、ic double culGirth(List double l =0;if (list .get(0)=1.0)l =3* list .get(1);if (list .get(0)=2.0)listData )list ).get(1), 2)/4;list ) I =list .get(1)+ list .get(2)+Math. sqrt (Math. pow( list .get(1), 2)+Math. pow( list .get(2), 2);if (list .get(0)=3.0)l=list.get(1)+ list .get(2)+ list .get(3);retur

11、nl ;測(cè)試類(lèi)ShapesDemopublicclassShapesDemo public static void main(Stringargs )menuStrip ();public static void menu Strip()Scanner sc = new Scanner(System.in );Stringchoice = null ;do System. out .println(選擇需要計(jì)算面積和周長(zhǎng)的圖形形狀。);System. out .println(1.三角形);System. out .println(2.正六邊形);System. out .println(3.

12、橢圓形);System. out .println(4.退出);System. out .println(請(qǐng)輸入選項(xiàng)【1-4 】);choice = sc. next();switch ( choice ) case 1 : option1 (); break ;case 2 : option2 (); break ;case 3 : option3 (); break ;case 4 :System. exit (0); default :System. err .println(輸入錯(cuò)誤!);menu Strip (); while (!( choice .equals( 4 );priv

13、ate static void option 1()Scanner sc1 = new Sca nn er(System.in);String tempChoiceSystem. out .println(System. out .println(.out .=null ;請(qǐng)選擇需要三角形的類(lèi)型。1.等邊三角形);2.直角形););System. out .println( 3.普通”);System. out .println(請(qǐng)輸入選項(xiàng)【1-3】(返回上一級(jí)請(qǐng)輸入0);tempChoice =sc1 .n ext();if (tempChoice .equals( 1)try for (;

14、)System. out .print(請(qǐng)輸入等邊三角形的邊長(zhǎng):);double aln =sc1 .n extDouble();if (aln 0)Tria ngle tria ngle1 =new Trian gle( aln);doublearea =tria ngle1 .culArea( tria ngle1.getListData();doublegirth =tria ngle1.culGirth(tria ngle1.getListData();System. out .println(此三角形的面積為:+area +n此三角形的周長(zhǎng)為:+girth );break ;else

15、System. err .println(輸入錯(cuò)誤,請(qǐng)輸入大于0的數(shù)值!); catch (Exception e)System. err .println(輸入錯(cuò)誤,請(qǐng)重新輸入!);opti on1 ();else if (tempChoice .equals( 2 )try for (;)System. out .print(請(qǐng)輸入一條直角邊長(zhǎng):);double aIn =sc1 .n extDouble();System. out .print(請(qǐng)輸入另一條直角邊長(zhǎng):); double bln =sc1 .n extDouble();if ( aIn 0&bln 0)Triangletr

16、iangle1=new Triangle(aln , bln );doublearea =tria ngle1 .culArea( tria ngle1.getListData();doublegirth =tria ngle1.culGirth(tria ngle1.getListData();System. out .println(此三角形的面積為:+area +n 此三角形的周長(zhǎng)為:+girth );break ;elseSystem. err .println(輸入錯(cuò)誤,請(qǐng)輸入大于0的數(shù)值!); catch (Exceptione)System. err .println(輸入錯(cuò)誤,

17、請(qǐng)重新輸入!);option1 ();else if (tempChoice .equals( 3)try for (;)System. out .print(請(qǐng)輸入三角形底邊長(zhǎng):);double aln =sc1 .n extDouble();System. out .print(請(qǐng)輸入高:);double hln =sc1 .n extDouble();System. out .print(請(qǐng)輸入三角形一條側(cè)邊邊長(zhǎng):);double bln =sc1 .n extDouble();System. out .print(請(qǐng)輸入三角形另一條側(cè)邊邊長(zhǎng): );double cIn =sc1 .n

18、extDouble();if (aIn 0&bln 0&cIn 0&hIn 0)if ( aIn +bln ) cln &(aln +cIn ) bln &(bln +cln ) aln )Tria ngletria ngle1=newTriangle( aln , bln , cln , hln );doublearea =tria ngle1 .culArea( tria ngle1 .getListData();doublegirth =tria ngle1 .culGirth( tria ngle1 .getListData();System. out .println(此三角形的面積

19、為:+area +n 此三角形的周長(zhǎng)為:+girth );break ;elseSystem. err .println(輸入錯(cuò)誤!不能構(gòu)成三角形!請(qǐng)重新輸入數(shù).);elseSystem. err .println(輸入錯(cuò)誤,請(qǐng)輸入大于 0的數(shù)值!); catch (Exception e)System. err .println(輸入錯(cuò)誤,請(qǐng)重新輸入!);optio n1 ();else if (tempChoice .equals( 0)menuStrip ();elseSystem. err .println( 輸入錯(cuò)誤! ”);Stringc=reChoice ();if (c.equ

20、als( 1)optio n1 ();else/返回主菜單private static void option2()Sca nnersc2 = new Sca nn er(System.in);String c=reChoice ();if (c.equals( 1 )try for (;)System. out .print(請(qǐng)輸入正六邊形的邊長(zhǎng):);double aln =sc2 .nextDouble();if (aln 0)Hexagon hexagon =new Hexagon( aln );doublearea =hexagon .culArea(hexagon .getListD

21、ata();doublegirth =hexagon .culGirth(hexagon .getListData();System. out .println(此正六邊形的面積為:+area +n此正六邊形的周長(zhǎng)為:+girth );break ;elseSystem. err .println( 輸入錯(cuò)誤,請(qǐng)輸入大于0的數(shù)值!); catch (Exception e)System. err .println(輸入錯(cuò)誤,請(qǐng)重新輸入!);option2 ();else/返回主菜單menu Strip ();private static void option3()Scanner sc3= n

22、ew Scanner(System.in);String c=reChoice ();if (c.equals( 1)try for (;)System. out .print(請(qǐng)輸入橢圓長(zhǎng)半軸長(zhǎng):); double aln =sc3 .nextDouble();System. out .print(請(qǐng)輸入橢圓短半軸長(zhǎng):); double bIn =sc3 .nextDouble();if (aln 0&bIn 0)if (aIn bIn )Ellipse ellipse =new Ellipse( aIn , bIn ); doublearea =ellipse .culArea( elli

23、pse .getListData();doublegirth =ellipse .culGirth( ellipse .getListData();System. out .println( 此橢圓形的面積為: +area+n 此橢圓的周長(zhǎng)為:+girth );break ;elseSystem. err .println(輸入錯(cuò)誤,長(zhǎng)半軸長(zhǎng)度小于短半軸,請(qǐng)重新您輸入!);elseSystem. err .println( 輸入錯(cuò)誤,請(qǐng)輸入大于0的數(shù) 值!); catch (Exceptione)System. err .println(輸入錯(cuò)誤,請(qǐng)重新輸入!);option3 ();else

24、 /返回主菜單 menuStrip () ; private staticStri ng reChoice()Scanner sc4=new Scanner(System.in);String tempSelect ;for (;) System. out .println(是否要繼續(xù)計(jì)算? n + 1繼續(xù)計(jì)算.2返回主菜單.n+ 請(qǐng)輸入選擇【1-2】:);tempSelect = sc4 .next();if (tempSelect .equals( 1 )| tempSelect .equals( 2) break ;else System. err .println(錯(cuò)誤選項(xiàng)!請(qǐng)重新選擇

25、!);/繼續(xù)循環(huán)return tempSelect ;運(yùn)行結(jié)果如下:三角形的計(jì)算畐_ Problemi 丘 Javadoe 將 Declaration 旦 匚cnsole 3ShapesDemo Java Application C:Program FilesJavajdkl.7.0_79binjavaw.exe (2015年6月宜E 下午9:12:43)選擇需要計(jì)算面積和周長(zhǎng)的圖形形狀.2 三角形2. 正六邊形3 *橢圓形4退出請(qǐng)輸入選頂1-41請(qǐng)選擇需要三角形的類(lèi)型。2”等邊三角形2 直角形3 普通請(qǐng)輸入選項(xiàng)1-31 (返回上一級(jí)請(qǐng)輸入)1請(qǐng)輸入等邊三角形的邊長(zhǎng)匕5此三角形的面和劃10.8

26、25317S47305483此三角形的周長(zhǎng)為;15.0J Problems Javadoc 虜 Declaration 貝 Console 卻ShapesDemo Java Application GProgram Fi 1 esJavajdkl.7.O_79binjavaw.exe (2015年6月6日F午9:12:43)選擇需要計(jì)算面積和周長(zhǎng)的圖形形狀。三角形2 正六邊形3 橢區(qū)形4 退出請(qǐng)輸入選頂1-41請(qǐng)選擇需要三角形的類(lèi)型。1 等邊三角形2 直角形3. #)1請(qǐng)輸入選項(xiàng)1-3(返回上一級(jí)請(qǐng)輸入0)2請(qǐng)輸入一條直角邊長(zhǎng):4 請(qǐng)輸入另一條直角邊長(zhǎng):5 此三角形的面積為:100此三角形的周

27、長(zhǎng)為:15403124237432849Problems Javadoc 曉 Declaration 旦 Console 總ShapesDemo Java Application C:Program FilesJavajdkl.7.0_79binavaw.exe (2015年6月6日下午9:22:17) 請(qǐng)選擇需要三角形的類(lèi)型。1 等邊三角形2 直角形3 昔通請(qǐng)輸入選項(xiàng)L1-3(返回上一級(jí)請(qǐng)輸入*0*)3請(qǐng)輸入三角形底邊長(zhǎng):55請(qǐng)輸入高:34請(qǐng)輸入三角形一條側(cè)邊邊長(zhǎng):5請(qǐng)輸入三角形另一條側(cè)邊邊長(zhǎng):9請(qǐng)輸入三角形底邊長(zhǎng):輸入錯(cuò)誤!不能構(gòu)成三角形!請(qǐng)重新輸入數(shù)7請(qǐng)輸入高:13請(qǐng)輸入三角形一條側(cè)邊邊長(zhǎng):15請(qǐng)輸入三角形另一條側(cè)邊邊長(zhǎng):9此三角形的面積為:455此三角形的周長(zhǎng)為:310計(jì)算六邊形:2 Problems Javadoc 匚.,Declaration 旦 Console 3ShapesDemo Jav

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶(hù)所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論