2012012194信安1202李自然_UML-实验报告(06)-顺序图.doc_第1页
2012012194信安1202李自然_UML-实验报告(06)-顺序图.doc_第2页
2012012194信安1202李自然_UML-实验报告(06)-顺序图.doc_第3页
2012012194信安1202李自然_UML-实验报告(06)-顺序图.doc_第4页
2012012194信安1202李自然_UML-实验报告(06)-顺序图.doc_第5页
已阅读5页,还剩9页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

北京信息科技大学实验(上机)报告课程名称 UML及建模工具 学号 2012012194 姓名 李自然 成绩_专业名称信息安全实验室名称3-702实验时间15.6实验名称实验6: 绘制顺序图1. 实验目的:1) 掌握UML顺序图建模的意义。2) 掌握Rational Rose或其他工具绘制顺序图的方法。3) 理解顺序图和类图之间的关系。2. 实验内容:1) 根据附录一源程序,绘制顺序图(店员租赁影片用例)。2) 根据上学期的数据库系统开发的试卷题目及答案(见附录二),绘制顺序图(教务员添加课程用例)3) 同步课程设计任务:小组成员在分层架构和实体类的共同讨论的基础上,对个人负责的用例进行详细设计(用例的界面、界面数据的说明、实现用例的参与类、用例的详细流程的顺序图)。3. 实验要求:1) 直接将顺序图拷贝粘贴到实验报告中提交。2) 正确使用消息。3) 个人独立完成。4) 提交最后期限:当日提交。4. 实验准备:1)5. 实验过程和结果:1) 根据附录一源程序,绘制顺序图(店员租赁影片用例)2) 根据上学期的数据库系统开发的试卷题目及答案(见附录二),绘制顺序图(教务员添加课程用例)6. 实验总结:通过这次试验,掌握UML顺序图建模的意义。掌握了用Rational Rose绘制顺序图的方法。理解顺序图和类图之间的关系附录一:影片租赁源程序/租赁类的定义class Rental private Movie _movie; / 影片 private int _rentDate; / 租赁日期 private int _daysRented; / 租期public Rental(Movie movie, int daysRented) _movie = movie; _daysRented = daysRented; public int getDaysRented() return _daysRented; public Movie getMovie() return _movie; double getCharge() return _movie.getCharge(_daysRented); int getFrequentRenterPoints() return _movie.getFrequentRenterPoints(_daysRented); /顾客类的定义class Customer private String _name; / 姓名 private String _phone; / 电话号码 private Vector _rentals = new Vector(); / 租借纪录public Customer(String name) _name = name; public void addRental(Rental arg) _rentals.addElement(arg); public String getName() return _name; /输出租赁交易报告public String statement() Enumeration rentals = _rentals.elements(); String result = Rental Record for + getName() + n; while (rentals.hasMoreElements() Rental each = (Rental) rentals.nextElement(); /显示该顾客的每个租赁 result += t + each.getMovie().getTitle()+ t + String.valueOf(each.getCharge() + n; /结尾打印(总费用和积分) result += Amount owed is + String.valueOf(getTotalCharge() + n; result += You earned + String.valueOf(getTotalFrequentRenterPoints() + frequent renter points; return result; /已超文本方式输出租赁交易报告public String htmlStatement() Enumeration rentals = _rentals.elements(); String result = Rentals for + getName() + n; while (rentals.hasMoreElements() Rental each = (Rental) rentals.nextElement(); /显示该顾客的每个租赁 result += each.getMovie().getTitle()+ : + String.valueOf(each.getCharge() + n; /结尾打印(总费用和积分) result += You owe + String.valueOf(getTotalCharge() + n; result += On this rental you earned + String.valueOf(getTotalFrequentRenterPoints() + frequent renter points; return result; / 计算总积分private int getTotalFrequentRenterPoints() int result = 0; Enumeration rentals = _rentals.elements(); while (rentals.hasMoreElements() Rental each = (Rental) rentals.nextElement(); result += each.getFrequentRenterPoints(); return result; / 计算总费用private double getTotalCharge() double result = 0; Enumeration rentals = _rentals.elements(); while (rentals.hasMoreElements() Rental each = (Rental) rentals.nextElement(); result += each.getCharge(); return result; /抽象价格类的定义abstract class Price abstract int getPriceCode(); / 取得价格代号 abstract double getCharge(int daysRented); / 根据租期计算费用int getFrequentRenterPoints(int daysRented) / 根据租期计算积分 return 1; /儿童价格类的定义class ChildrensPrice extends Price int getPriceCode() return Movie.CHILDRENS; double getCharge(int daysRented) double result = 1.5; if (daysRented 3) result += (daysRented - 3) * 1.5; return result; /新片价格类的定义class NewReleasePrice extends Price int getPriceCode() return Movie.NEW_RELEASE; double getCharge(int daysRented) return daysRented * 3; int getFrequentRenterPoints(int daysRented) return (daysRented 1) ? 2: 1; /普通片价格类的定义class RegularPrice extends Price int getPriceCode() return Movie.REGULAR; double getCharge(int daysRented) double result = 2; if (daysRented 2) result += (daysRented - 2) * 1.5; return result; /影片类和主程序public class Movie public static final int CHILDRENS = 2; public static final int REGULAR = 0; public static final int NEW_RELEASE = 1; private String _title; / 名称 private Price _price; / 影片的价格public Movie(String title, int priceCode) _title = title; setPriceCode(priceCode); public int getPriceCode() return _price.getPriceCode(); public void setPriceCode(int arg) switch (arg) case REGULAR: / 普通片 _price = new RegularPrice(); break; case CHILDRENS: / 儿童片 _price = new ChildrensPrice(); break; case NEW_RELEASE: / 新片 _price = new NewReleasePrice(); break; default: throw new IllegalArgumentException(Incorrect Price Code); public String getTitle() return _title; / 影片租金double getCharge(int daysRented) return _price.getCharge(daysRented); / 影片积分int getFrequentRenterPoints(int daysRented) return _price.getFrequentRenterPoints(daysRented); / 主程序using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Text;using System.Windows.Forms;public partial class RentForm : Form public RentForm() InitializeComponent(); private void button1_Click(object sender, EventArgs e) Movie m1 = new Movie(阿凡达, 1); Movie m2 = new Movie(将爱情进行到底, 2); Movie m3 = new Movie(喜羊羊与灰太郎, 3); /客户的租赁 Customer c1 = new Customer(张三); Rental r1 = new Rental(m1, 4); Rental r2 = new Rental(m2, 2); Rental r3 = new Rental(m3, 2); c1.addRental(r1); c1.addRental(r2); c1.addRental(r3); /输出顾客c1的消费报告 textBox1.Text = c3.statement(); 附录二:五、程序题(本题满分37分,共含4道小题)学校对重点课程建设进行管理,在SQL Server数据库中建立一张表courses,表结构如下:字段名含义数据类型备注CourseID课程编号int主键Name名称nVarChar(20)Hours学时intSchool学院nVarchar(20)一门课程只能属于一个学院Web.Config文件中关于数据库连接串的配置代码如下: 1编写一个courses表对应的DTO类,类名为Course,命名空间是Model,额外为该类编写一个只读属性Credit(学分),学分按照学时计算(48:4学分)。(8分)2编写一个courses表的数据访问类,类名为CourseDal,命名空间是Dal。该类包括2个方法int Insert(Course course)和List SelectCoursesBySchool(string school)。Insert方法将Course对象作为一个新行插入到数据表courses中;SelectCoursesBySchool方法将根据学院从数据表courses检索指定学院的所有课程记录,并返回Course对象集合。(15分)提示1:该类已存在私有方法private Course GetCourseFromDataRow(DataRow row) ,该方法利用传入的DataRow对象生成一个Course对象并返回,可直接使用该方法。提示2:代码中不能使用DBObject对象,要求直接采用ADO.NET对象访问数据库。3编写courses表对应的业务逻辑类,类名为CourseBll,命名空间是Bll,包含Add()、GetCoursesBySchool()方法。请仅为方法int Add(Course course)编写代码实现一门课程的添加。业务规则如下:课程的学时必须大于等于32,小于等于64;每个学院至多有10门课程。(8分)4现有一个AddCourse.aspx页面,在这个页面上有以下控件:4个TextBox控件(Text1、Text2、Text3、Text4,分别用来输入课程编号、名称、学时、学院)、一个Button控件(名为Button1)。编写Button1的单击事件处理程序,根据用户的输入调用第3小题中CourseBll类中的Add方法向数据库中添加一门课程(暂不考虑数据验证)。(6分)参考答案1编写一个courses表对应的DTO类,类名为Course,命名空间是Model,额外为该类编写一个只读属性Credit(学分),学分按照学时计算(48:4学分)。(8分)答:命名空间1分,类名定义1分,4个属性每个1分,Credit属性2分。namespace Model Serializable public class Course private int _CourseID; public int CourseID get return _CourseID; set _CourseID = value; private string _name; public string Name get return _name; set _name = value; private int _hours; public int Hourse get return _hours; set _hours = value; private string _school; public string School get return _school; set _school = value; public int Credit get if (_hours 32 and _hours 48) return 4; 答:命名空间1分,类名定义1分,数据库连接串1分,Insert方法的Sql语句2分,命令执行3分(使用DBObject得1分),SelectCoursesBySchool方法执行查询3分(使用DBObject得1分),获取结果返回3分。using导入命名空间Model得1分。namespace DAL public class CourseDal private string connString; public CourseDal() connString = ConfigurationManager.ConnectionStringsConnString1.ConnectionString; public int Insert(Course course) string sql = insert into Course (CourseID,Name,Hourse,School) values(; sql += course.CourseID = ? null, : ( + course.CourseID + ,); sql += course.Name = ? null, : ( + course.Name + ,); sql += course.Hours = null ? null, : ( course.Hours + ,); sql += course.School = ? null) :( + course.School + ); SqlConnection cn = new SqlConnection(connString);cn.Open(); SqlCommand cmd = new SqlCommand(sql, cn);int result = cmd.ExecuteNonQuery()cn.Close(); return (result); public List SelectCoursesBySchool(string school) List Courses = new List(); string sql = select * from Course where School= + school + ;DataSet ds = new DataSet(); SqlDataAdapter da = new SqlDataAdapter(sql, connString);da.Fill(ds, Course);for (int i = 0; i = 32 and c1.Hours =64 ) CourseDal cDal = new CourseDal(); List courses; courses = cDal.SelectCoursesByS

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论