package com.entity;

import java.text.SimpleDateFormat;
import java.util.Date; public class DVD {
private String name;
private boolean borrowed;
private Date borrowedTime;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Date getBorrowedTime() {
return borrowedTime;
}
public void setBorrowedTime(Date borrowedTime) {
this.borrowedTime = borrowedTime;
}
public DVD(String name, boolean borrowed, Date borrowedTime) {
super();
this.name = name;
this.setBorrowed(borrowed);
this.borrowedTime = borrowedTime;
}
public DVD() {
super();
}
public String toString(){
String status= isBorrowed()?"已借出":"可借";
String date;
if(getBorrowedTime()==null){
date="";
}else{
date=new SimpleDateFormat("yyyy-MM-dd").format(getBorrowedTime());
}
return "《"+getName()+"》\t"+status+"\t"+date;
}
public void setBorrowed(boolean borrowed) {
this.borrowed = borrowed;
}
public boolean isBorrowed() {
return borrowed;
} }
package com.entity; import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.Scanner; public class DVDManager {
private ArrayList<DVD> dvdList;
private final int price=2;//一张DVD2块钱1天
SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd");
Scanner input=new Scanner(System.in); public void setDvdList(ArrayList<DVD> dvdList) {
this.dvdList = dvdList;
} public ArrayList<DVD> getDvdList() {
return dvdList;
}
public DVDManager(){ }
public DVDManager(ArrayList<DVD> dvdList){
this.dvdList=dvdList;
}
public void initial(){
dvdList=new ArrayList<DVD>();
try {
DVD d=new DVD("罗马假日",true,sdf.parse("2013-07-01"));
DVD d2=new DVD("风声鹤唳",false,null);
DVD d3=new DVD("浪漫满屋",false,null);
dvdList.add(d);
dvdList.add(d2);
dvdList.add(d3);
} catch (ParseException e) {
e.printStackTrace();
}
} public void mainMenu(){
System.out.println("欢迎使用迷你DVD管理器");
System.out.println("-------------------------------------------------------");
System.out.println("" +
"1. 新增DVD\n" +
"2. 查看DVD\n" +
"3. 删除DVD\n" +
"4. 借出DVD\n" +
"5. 归还DVD\n" +
"6. 退出DVD");
System.out.println("-------------------------------------------------------");
System.out.print("请选择:");
input=new Scanner(System.in);
String regex="^[1-6]{1}$";
while(!input.hasNext(regex)){
input=new Scanner(System.in);
System.out.print("输入有误,请重新选择:");
}
int check_1=input.nextInt();
switch(check_1){
case 1:
addDVD();
break;
case 2:
queryAll();
break;
case 3:
deleteDVD();
break;
case 4:
borrowDVD();
break;
case 5:
lend();
break;
case 6:
System.out.println();
System.out.println("谢谢使用!");
System.exit(0);
break;
}
System.out.println("********************************");
back();
} public void back(){
System.out.print("输入0返回:");
input=new Scanner(System.in);
String regex="^0$";
while(!input.hasNext(regex)){
input=new Scanner(System.in);
System.out.print("输入有误,输入0返回:");
}
mainMenu();
}
public void queryAll(){
System.out.println("----> 查看DVD\n");
System.out.println("序号\t 名称 \t\t状态\t 借出日期");
for(int i=0;i<dvdList.size();i++){
System.out.println((i+1)+"\t"+dvdList.get(i));
}
}
public DVD findDVDByName(String name){
//DVD dvd=null; 与DVD dvd=new DVD();是有不同的
DVD dvd=null;
for(int i=0;i<dvdList.size();i++){
if(dvdList.get(i).getName().equals(name)){
dvd=dvdList.get(i);
break;
}
}
return dvd;
} public void addDVD(){//新增DVD
System.out.println("----> 新增DVD\n");
System.out.print("请输入DVD名称:");
String name=input.next();
DVD d=findDVDByName(name);
if(d!=null){
System.out.println("该DVD已经存在,不能再次添加!");
return;
}
d=new DVD(name,false,null);
dvdList.add(d);
System.out.println("新增《"+d.getName()+"》成功!");
} public void borrowDVD(){
System.out.println("----> 借出DVD\n");
System.out.print("请输入DVD名称:");
String name=input.next();
DVD d=findDVDByName(name);
if(d==null){
System.out.println("该DVD不存在,无法借出!");
return;
}else if(d.isBorrowed()){
System.out.println("不好意思,该DVD已被借出!");
}
System.out.print("请输入借书日期(年-月-日):");
String regex="\\d{4}-(([1][012])|([0][0-9]))-(([012][0-9])|([3][0]))";
while(!input.hasNext(regex)){
input=new Scanner(System.in);
System.out.print("借书日期格式有误请重新输入:");
}
Date date = null;
try {
date=sdf.parse(input.next());
} catch (ParseException e) {
e.printStackTrace();
}
int index=dvdList.indexOf(d);
d.setBorrowed(true);
d.setBorrowedTime(date);
dvdList.set(index, d);
System.out.println("借出《"+name+"》成功!");
} public void deleteDVD(){
System.out.println("----> 删除DVD\n");
System.out.print("请输入DVD名称:");
String name=input.next();
DVD d=findDVDByName(name);
if(d==null){
System.out.println("该DVD不存在,无法删除!");
return;
}else if(d.isBorrowed()){
System.out.println("该DVD已被借出,无法删除");
return;
}
dvdList.remove(d);//移除第一个,后面自动左移
System.out.println("删除《"+name+"》成功!");
} public void lend(){
System.out.println("----> 归还DVD\n");
System.out.print("请输入DVD名称:");
String name=input.next();
DVD d=findDVDByName(name);
if(d==null){
System.out.println("归还失败,该DVD不是我们店里的!");
return;
}else if(!d.isBorrowed()){
System.out.println("归还失败,该DVD已经归还,您的DVD不是我们店里的!");
return;
}
Date borrowDate = d.getBorrowedTime();
Date lendDate = null;
long spend;
System.out.print("请输入还书日期(年-月-日):");
String regex="\\d{4}-(([1][012])|([0][0-9]))-(([012][0-9])|([3][0]))";
while(true){//感觉还是玩死循环跳出爽
while(!input.hasNext(regex)){
input=new Scanner(System.in);
System.out.print("还书日期格式有误请重新输入:");
}
try {
lendDate=sdf.parse(input.next());
} catch (ParseException e) {
e.printStackTrace();
} if(lendDate.before(borrowDate)){//Date的比较前者是否在后者之前的方法
System.out.println("还书日期不可能比借出日期还早,请重新输入");
}else{
break;
}
}
spend=lendDate.getTime()-borrowDate.getTime();
int money=(int) Math.ceil(spend/(24*60*60*1000))*price;
int index=dvdList.indexOf(d);
d.setBorrowed(false);
d.setBorrowedTime(null);
dvdList.set(index, d);
System.out.println("归还成功!");
System.out.println("应付租金(元):"+money);
} }
package com.test; import com.entity.DVDManager; public class Test {
public static void main(String[] args) {
DVDManager dm=new DVDManager();
dm.initial();
dm.mainMenu();
}
}

03_模拟DVD的更多相关文章

  1. java模拟DVD管理器

    import java.util.*;import java.text.*;class DVDSet{    String[] name = new String[50]; //名字    int[] ...

  2. SpringBoot系列: JdbcTemplate 事务控制

    ============================Spring JdbcTemplate 事务控制============================之前使用 JDBC API 操作, 经常 ...

  3. SpringBoot系列: JdbcTemplate 快速入门

    对于一些小的项目, 我们没有必要使用MyBatis/JPA/Hibernate等重量级技术, 直接使用Spring JDBC 即可, Spring JDBC 是对 jdbc的简单封装, 很容易掌握. ...

  4. MySQL Sakila样本数据库

    Sakila样本数据库介绍 Sakila样本数据库是MySQL官方提供的一个模拟DVD租赁信息管理的数据库,提供了一个标准模式,可作为书中例子,教程.文章.样品,等等,对学习测试来说是个不错的选择. ...

  5. 诸城模拟赛 dvd的逆序对

    [题目描述] dvd是一个爱序列的孩子. 他对序列的热爱以至于他每天都在和序列度过 但是有一个问题他却一直没能解决 给你n,k求1~n有多少排列有恰好k个逆序对 [输入格式] 一行两个整数n,k [输 ...

  6. 03_天气查询_socket方式模拟_多线程方式

    [简述] 要重视Socket开发,企业后台服务特长使用Socket. 1.服务端要有可持续运行能力,保证线程一致在运行 2.并发处理能力,使用多线程 [工程截图] [WeatherRunner.jav ...

  7. X-Plane飞行模拟资源整理一

    计划开一个博客整理一下飞行仿真软件二次开发的相关内容 预计将陆续介绍X-Plane.Microsoft Flight Simulator.FlightGear三个主流飞行模拟器. 此处为目录(占坑,随 ...

  8. 【Java基础】【18Map集合&模拟斗D主X排和F排】

    18.01_集合框架(Map集合概述和特点) A:Map接口概述 查看API可以知道: 将键映射到值的对象 一个映射不能包含重复的键 每个键最多只能映射到一个值 B:Map接口和Collection接 ...

  9. RHCSA-EXAM 模拟题目

    参考答案:http://www.cnblogs.com/venicid/category/1088924.html 请首先按找以下要求配置考试系统: * Hostname: server0.examp ...

随机推荐

  1. springcloud---2

    每一个都是独立的springboot工程.通过自己的ip和端口访问. Eureka是服务发现组件,Eureka里面有一个服务注册表,存的是服务消费者和服务生产者的ip和端口.Eureka集群里面每个E ...

  2. linux下不同服务器间数据传输(wget,scp)

    一.wget是Linux下最常用的http/ftp文件下载工具1.wget断点续传,只需要加上-c参数即可,例如:代码:wget-chttp://www.abc.com/abc.zip-Oabc.zi ...

  3. 使用C++11实现一个半同步半异步线程池

    前言 C++11之前我们使用线程需要系统提供API.posix线程库或者使用boost提供的线程库,C++11后就加入了跨平台的线程类std::thread,线程同步相关类std::mutex.std ...

  4. XPO开发指南简要

    一.XPO简介: XPO即eXpress Persistent Objects for .NET,现在这里介绍的版本是1.5. XPO在应用程序代码和数据库之间扮演了一个中间层的角色,简单而言,就是将 ...

  5. oracle导入时报错

    之前在oracle数据库中新建了一个表空间和用户,在新建的用户下导入".dmp"文件是出现了这个错误. 解决方法: 使用管理员登陆进去,创建一个对应的表空间和用户,就OK了. (表 ...

  6. 使用tcpdump 对nginx的access.log 非400的ip进行自动抓包

    #抓取nginx access日志不是 400 的行,找出该ip ,并且启动抓包 #该脚本的执行要放在 crond 里面或者 while循环里面 ################## #网卡名称 ne ...

  7. [BZOJ1044木棍分割]

    Description 有n根木棍, 第i根木棍的长度为Li,n根木棍依次连结了一起, 总共有n-1个连接处. 现在允许你最多砍断m个连 接处, 砍完后n根木棍被分成了很多段,要求满足总长度最大的一段 ...

  8. ETL增量处理总结

    1 LOG表 1.1 思路 用log表记录业务库某表yw_tableA发生变化数据的主键.数据进入BI库目标表bi_tableA前,先根据log表记录的主键进行delete. 1.2 设计 1.2.1 ...

  9. SQL 循环 FOR 语句

    ) DECLARE My_Cursor CURSOR --定义游标 FOR (SELECT userid FROM User) --查出需要的集合放到游标中 OPEN My_Cursor; --打开游 ...

  10. 对spring boot 之AutoConfiguration 的理解

    来自:http://rensanning.iteye.com/blog/2363467 https://blog.csdn.net/tincox/article/details/79186067 Au ...