软件体系结构实验报告Word下载.docx

上传人:b****5 文档编号:19757937 上传时间:2023-01-09 格式:DOCX 页数:20 大小:24.94KB
下载 相关 举报
软件体系结构实验报告Word下载.docx_第1页
第1页 / 共20页
软件体系结构实验报告Word下载.docx_第2页
第2页 / 共20页
软件体系结构实验报告Word下载.docx_第3页
第3页 / 共20页
软件体系结构实验报告Word下载.docx_第4页
第4页 / 共20页
软件体系结构实验报告Word下载.docx_第5页
第5页 / 共20页
点击查看更多>>
下载资源
资源描述

软件体系结构实验报告Word下载.docx

《软件体系结构实验报告Word下载.docx》由会员分享,可在线阅读,更多相关《软件体系结构实验报告Word下载.docx(20页珍藏版)》请在冰豆网上搜索。

软件体系结构实验报告Word下载.docx

〔4〕外文、符号、公式要准确,应使用统一规定的名词和符号。

〔5〕应独立完成实验报告的书写,严禁抄袭、复印,一经发现,以零分论处。

实验报告批改说明

实验报告的批改要及时、认真、仔细,一律用红色笔批改。

实验报告的批改成绩采用百分制,具体评分标准由各院部自行制定。

实验报告装订要求

实验批改完毕后,任课教师将每门课程的每个实验工程的实验报告以自然班为单位、按**升序排列,装订成册,并附上一份该门课程的实验大纲。

实验工程名称:

经典软件体系构造风格实验学时:

4学时

同组学生:

实验地点:

1216

实验日期:

实验成绩:

批改教师:

批改时间:

一、实验目的和要求

〔1〕理解管道-过滤器软件体系构造、面向对象软件体系构造的原理

〔2〕掌握管道-过滤器软件体系构造、面向对象软件体系构造特点

〔3〕面向对象软件体系构造的编程实现

二、实验仪器和设备

奔腾以上计算机,Windows10、VisualStudio2013、MySQL

三、实验过程

〔1〕在dos下体会管道过滤器的体系构造。

使用dir|more命令了解管道-过滤器风格的程序。

〔2〕数据抽象和面向对象软件体系构造设计实现。

设计一个应用程序,在该程序定义平面图形的抽象类和其派生类圆、矩形、三角形,椭圆。

该程序的功能包括:

输入相应的图形参数,如矩形的长和宽,单击相应按钮,能根据输入参数创立图形类并输出该对象的面积。

使用c#、c++或Java或语言进展面向对象的程序设计:

〔1〕首先考虑数据封装性,〔2〕考虑继承性,〔3〕考虑抽象类。

应用程序代码:

Graphic.cs:

namespaceWindowsFormsApplication1

{

publicabstractclassGraphic

{

publicabstractdoubleArea();

}

}

Rectangle.cs:

publicclassRectangle:

Graphic

doublelen;

doublewid;

publicRectangle(doublelength,doublewidth)

len=length;

wid=width;

publicoverridedoubleArea()

returnlen*wid;

Triangle.cs:

publicclassTriangle:

doublebtm;

doublehgt;

publicTriangle(doublebottom,doubleheight)

btm=bottom;

hgt=height;

returnbtm*hgt/2;

Circle.cs:

publicclassCircle:

Graphic

doubleradius;

publicCircle(doubler)

radius=r;

returnradius*radius*3.14;

}

Ellipse.cs:

usingSystem;

usingSystem.Collections.Generic;

usingSystem.Linq;

usingSystem.Te*t;

publicclassEllipse:

doublela;

doublelb;

publicEllipse(doublea,doubleb)

la=a;

lb=b;

returnla*lb*3.14;

From1.cs:

usingSystem.ponentModel;

usingSystem.Data;

usingSystem.Drawing;

usingSystem.Windows.Forms;

publicpartialclassForm1:

Form

publicForm1()

Initializeponent();

privatevoidbutton1_Click(objectsender,EventArgse)

if(boBo*1.SelectedItem=="

圆"

doubler=Convert.ToDouble(te*tBo*1.Te*t);

Circlecircle=newCircle(r);

te*tBo*4.Te*t=Convert.ToString(circle.Area());

elseif(boBo*1.SelectedItem=="

矩形"

doublelen=Convert.ToDouble(te*tBo*1.Te*t);

doublewid=Convert.ToDouble(te*tBo*2.Te*t);

Rectanglerec=newRectangle(len,wid);

te*tBo*4.Te*t=Convert.ToString(rec.Area());

三角形"

doublebtm=Convert.ToDouble(te*tBo*1.Te*t);

doublehgt=Convert.ToDouble(te*tBo*3.Te*t);

Triangletri=newTriangle(btm,hgt);

te*tBo*4.Te*t=Convert.ToString(tri.Area());

椭圆"

doublea=Convert.ToDouble(te*tBo*1.Te*t);

doubleb=Convert.ToDouble(te*tBo*2.Te*t);

Ellipseelp=newEllipse(a,b);

te*tBo*4.Te*t=Convert.ToString(elp.Area());

privatevoidboBo*1_SelectedInde*Changed(objectsender,EventArgse)

label1.Te*t="

半径"

;

label2.Visible=false;

label3.Visible=false;

te*tBo*2.Visible=false;

te*tBo*3.Visible=false;

长"

label2.Visible=true;

te*tBo*2.Visible=true;

底"

label3.Visible=true;

te*tBo*3.Visible=true;

半长轴"

label2.Te*t="

半短轴"

四、实验结果与分析

程序初始界面:

如选择椭圆,输入半长轴和半短轴,点击计算,输出结果:

如选择三角形,输入底和高,点击计算,输出结果:

五、思考题

(1)管道-过滤器软件体系构造与批处理软件体系构造的区别和联系是什么?

答:

管道/过滤器构造通常导致进程成为批处理的构造,因为虽然过滤器可增量式地处理数据,但它们是独立的,所以设计者必须将每一个过滤器看成一个完整的从输入到输出的转换。

.限定过滤器的数据存储容量,就可以得到有界管道/过滤器。

过滤器将所有输入数据作为单个实体进展处理,这就是批处理系统

〔2〕面向对象软件体系构造与主程序-子程序软件体系构造的区别和联系是什么?

主程序-子程序体系构造在设计上使用层次化的划分方法,通常采用自顶向下的功能化设计方法,面向对象体系构造在设计上使用面向对象的设计方法,可以隐藏对象的部状态并且要求所有对象间的交互都通过该方法,即进展了数据封装,这也是面向对象编程的根本原则

六、实验心得与体会

在管道/过滤器风格的软件体系构造中,每个构件都有一组输入和输出,构件读输入的数据流,经过部处理,然后产生输出数据流。

这个过程通常通过对输入流的变换及增量计算来完成,所以在输入被完全消费之前,输出便产生了。

因此,这里的构件被称为过滤器,这种风格的连接件就象是数据流传输的管道,将一个过滤器的输出传到另一过滤器的输入。

通过实验,我对这种软件体系构造有了进一步了解。

多层C/S构造应用设计实验学时:

设计并实现一个基于多层C/S构造的数据库应用,熟悉多层C/S体系构造及其根本处理流程,了解多层构造表现层、业务逻辑层〔功能层〕、数据访问层所完成的功能,掌握多层C/S构造的数据库应用设计方法,对这三层进展明确分割,并在逻辑上使其独立。

学生通过本实验的训练能够熟练掌握对小型数据库应用系统三层构造层次划分方法及系统实现技术。

分别采用二层C/S构造和多层C/S构造实现个人通讯录系统。

该系统的设计目标是能够轻松地管理个人的联系人信息,包括添加、修改和删除操作。

联系人信息包括、住址、。

整个系统的功能图如下列图所示:

usingMySql.Data.MySqlClient;

namespaceWindowsFormsApplication2

publicintaction=0;

//0:

添加;

1:

修改

privatevoidgroupBo*3_Enter(objectsender,EventArgse)

privatevoidbutton3_Click(objectsender,EventArgse)

frm1.Enabled=true;

frm2.Enabled=false;

action=0;

privatevoidadd()

longid=0;

intcount=list1.Items.Count;

if(count==0)

id=1001;

else

id=long.Parse(list1.Items[count-1].Te*t)+1;

Dbconconnector=newDbcon();

MySqlConnectioncon=connector.dbcon();

con.Open();

MySqlmandcmd=newMySqlmand("

insertintoperson(id,name,phoneno,location)values(id,name,phoneno,location)"

con);

cmd.Parameters.AddWithValue("

name"

name.Te*t);

phoneno"

phoneno.Te*t);

location"

location.Te*t);

id"

Convert.ToString(id));

cmd.E*ecuteNonQuery();

con.Close();

build();

privatevoidmodify()

foreach(ListViewItemiteminlist1.SelectedItems)

MySqlmandcmd=con.Createmand();

cmd.mandTe*t="

updatepersonsetname=name,phoneno=phoneno,location=locationwhereid=id"

item.Te*t);

if(action==0)

add();

elseif(action==1)

modify();

name.Clear();

phoneno.Clear();

location.Clear();

frm2.Enabled=true;

frm1.Enabled=false;

privatevoidbutton4_Click(objectsender,EventArgse)

name.Te*t=item.SubItems[1].Te*t;

phoneno.Te*t=item.SubItems[2].Te*t;

location.Te*t=item.SubItems[3].Te*t;

action=1;

privatevoidForm1_Load(objectsender,EventArgse)

publicvoidbuild()

list1.BeginUpdate();

list1.Items.Clear();

select*fromperson"

MySqlDataReaderdr=cmd.E*ecuteReader();

while(dr.Read())

ListViewItemitem=newListViewItem();

item.Te*t=Convert.ToString(dr["

]);

item.SubItems.Add(Convert.ToString(dr["

]));

list1.Items.Add(item);

dr.Close();

list1.EndUpdate();

privatevoidbutton5_Click(objectsender,EventArgse)

deletefrompersonwhereid="

+item.Te*t,con);

privatevoidbutton2_Click(objectsender,EventArgse)

privatevoidte*tBo*2_Te*tChanged(objectsender,EventArgse)

privatevoidlist1_SelectedInde*Changed(objectsender,EventArgse)

//MessageBo*.Show();

privatevoidbutton6_Click(objectsender,EventArgse)

MessageBo*.Show("

developedbyaltair"

);

publicclassDbcon

publicMySqlConnectiondbcon()

Stringconstr="

server=localhost;

UserId=root;

password=root;

Database=contact"

MySqlConnectioncon=newMySqlConnection(constr);

returncon;

程序主界面:

点击“添加联系人信息〞:

点击“确定〞:

选中列表上的*项容,点击“修改联系人信息〞:

修改信息并点击“确定〞:

与二层C/S体系构造比拟,三层(多层)体系构造有什么优点?

采用三层体系构造在系统设计时应该注意哪些问题?

三层体系构造的优点:

①允许合理地划分三层构造的功能,使之在逻辑上保持相对独立性 

②允许更灵活有效地选用相应的平台和硬件系统

③三层C/S构造中,应用的各层可以并行开发,各层也可以选择各自最适宜的开发语言。

④允许充分利用功能层有效地隔离层表示层与数据层。

⑤三层C/S构造各层间的通信效率假设不高,即使分配给各层的硬件能力很强,其作为整体来说也达不到所要求的性能。

在设计三层构造时,首先要考虑的问题在于数据层和业务层的连接是否畅通,数据的吞吐量是否过大。

在用户对于程序相应速度要求一般或者数据吞吐量较小的情况下,可以采用三层构造进展设计

实验涉及到c#技术对于JDBC的操作,遇到一定困难,但都完美解决了。

收获了很多经历和知识。

同时我对多层c/s构造也有了更加深刻的认知和了解,掌握了这种软件体系结设想必十分有用。

B/S构造应用设计实验学时:

设计并实现一个基于B/S构造的数据库应用,熟悉B/S体系构造及其根本处理流程,了解B/S构造系统各局部所完成的功能,掌握B/S构造的数据库应用设计方法。

学生通过本实验的训练能够熟练掌握对小型

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 党团工作 > 其它

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1