Java案例整理
1.随机点名器案例
1.1 案例介绍
随机点名器,即在全班同学中随机的找出一名同学,打印这名同学的个人信息。
此案例在我们昨天课程学习中,已经介绍,现在我们要做的是对原有的案例进行升级,使用新的技术来实现。
我们来完成随机点名器,它具备以下3个内容:
l 存储所有同学姓名
l 总览全班同学姓名
l 随机点名其中一人,打印到控制台
1.2 案例需求分析
全班同学中随机的找出一名同学,打印这名同学的个人信息。
我们对本案例进行分析,得出如下分析结果:
1.存储全班同学信息(姓名、年龄)
2.打印全班同学每一个人的信息(姓名、年龄)
3.在班级总人数范围内,随机产生一个随机数,查找该随机数所对应的同学信息(姓名、年龄)
随机点名器明确地分为了三个功能。如果将多个独立功能的代码写到一起,则代码相对冗长,我们可以针对不同的功能可以将其封装到一个方法中,将完整独立的功能分离出来。
而在存储同学姓名时,如果对每一个同学都定义一个变量进行姓名存储,则会出现过多孤立的变量,很难一次性将全部数据持有。此时,我们采用ArrayList集合来解决多个学生信息的存储问题。
package com.oracle.linkedlist;
public class Student {
String name;
int age;
}
package com.oracle.linkedlist;
import java.util.Scanner;
import java.util.Random;
class Test04 {
public static void main(String[] args) {
String[] arr=new String[5];
// 存储所有同学姓名
StudentName(arr);
// 总览全班同学姓名
StudentCname(arr);
// 存储所有同学姓名
StudentSname(arr);
}
// 存储所有同学姓名
public static void StudentName(String[] arr){
Scanner sc=new Scanner(System.in);
for (int i=0;i<arr.length;i++) {
System.out.println("第"+(i+1)+"同学姓名");
arr[i]=sc.next();
}
}
// 总览全班同学姓名
public static void StudentCname(String[] arr){
for(int i=0;i<arr.length;i++){
System.out.println("第"+(i+1)+"个同学:"+arr[i]);
}
}
// 存储所有同学姓名
public static void StudentSname(String[]arr){
int a = new Random().nextInt(arr.length);
System.out.println("被点到名的同学是:" +arr[a]);
}
}
运行结果:

2.库存管理案例
2.1 案例介绍
现在,我们将原有的库存管理案例,采用更好的集合方式实现。

将对下列功能进行方法封装:
l 打印库存清单功能
l 库存商品数量修改功能
l 退出程序功能
2.2 案例需求分析
管理员能够进行的操作有3项(查看、修改、退出),我们可以采用(switch)菜单的方式来完成。
-------------库存管理------------
1.查看库存清单
2.修改商品库存数量
3.退出
请输入要执行的操作序号:
每一项功能操作,我们采用方法进行封装,这样,可使程序的可读性增强。
选择“1.查看库存清单”功能,则控制台打印库存清单
选择“2.修改商品库存数量”功能,则对每种商品库存数进行更新
选择“3.退出”功能,则退出库存管理,程序结束
package com.oracle.demo03;
public class Stores {
String sname;
double ssize;
double smoney;
int sinventory;
}
package com.oracle.demo03;
import java.util.ArrayList;
import java.util.Scanner;
public class store {
public static void main(String[] args) {
ArrayList<Stores> list=new ArrayList();
Scanner sc=new Scanner(System.in);
while(true){
MainMenu();
int num=sc.nextInt();
switch(num){
case 1:QueryStore(list);
break;
case 2:updateStore(list);
break;
case 3:addStore(list);
break;
case 4:delectStore(list);
break;
case 5:
return;
default:
break;
}
}
}
//主菜单
public static void MainMenu(){
System.out.println("----------库存管理-----------");
System.out.println("1.查看库存清单");
System.out.println("2.修改商品库存数量");
System.out.println("3.添加商品");
System.out.println("4.删除商品");
System.out.println("5.退出");
System.out.println("请输入您要执行的编号:");
}
//查看库存清单
public static void QueryStore(ArrayList<Stores> list){
System.out.println("---------商城库存清单----------");
System.out.println("品牌型号\t\t尺寸\t价格\t库存数");
//MacBookAir品牌
Stores s1=new Stores();
s1.sname="MacBookAir";
s1.ssize=13.3;
s1.smoney=6988.88;
s1.sinventory=5;
System.out.println(s1.sname+"\t"+s1.ssize+"\t"+s1.smoney+"\t"+s1.sinventory);
//ThinkpadT450品牌
Stores s2=new Stores();
s2.sname="ThinkpadT450";
s2.ssize=14.0;
s2.smoney=5999.99;
s2.sinventory=10;
System.out.println(s2.sname+"\t"+s2.ssize+"\t"+s2.smoney+"\t"+s2.sinventory);
//ASUS-FL5800品牌
Stores s3=new Stores();
s3.sname="ASUS-FL5800";
s3.ssize=15.6;
s3.smoney=4999.5;
s3.sinventory=18;
System.out.println(s3.sname+"\t"+s3.ssize+"\t"+s3.smoney+"\t"+s3.sinventory);
//总库存数
int sum=s1.sinventory+s2.sinventory+s3.sinventory;
//库存商品总金额
double SUM=s1.smoney*5+s2.smoney*10+s3.smoney*18;
for(int i=0;i<list.size();i++){
System.out.println(list.get(i).sname+"\t\t"+list.get(i).ssize+"\t"+list.get(i).smoney+"\t"+list.get(i).sinventory);
}
System.out.println("---------------------------");
System.out.println("总库存数:"+sum);
System.out.println("库存商品总金额:"+SUM);
}
//修改商品数量
public static void updateStore(ArrayList<Stores> list){
QueryStore(list);
Scanner sc=new Scanner(System.in);
System.out.println("请输入要修改的品牌数量:");
int inventory=sc.nextInt();
Stores stores=new Stores();
stores.sinventory=inventory;
for(int i=0;i<list.size();i++){
if(inventory==list.get(i).sinventory){
list.set(i, stores);
}
}
}
//添加清单
public static void addStore(ArrayList<Stores> list){
Scanner sc=new Scanner(System.in);
Stores stores=new Stores();
System.out.println("请输入新增加的品牌型号:");
String name=sc.next();
System.out.println("请输入新增加的品牌尺寸:");
double size=sc.nextDouble();
System.out.println("请输入新增加的品牌价格:");
double money=sc.nextDouble();
System.out.println("请输入新增加的品牌库存数:");
int inventory=sc.nextInt();
stores.sname=name;
stores.ssize=size;
stores.smoney=money;
stores.sinventory=inventory;
list.add(stores);
System.out.println("添加商品成功!");
}
//删除清单
public static void delectStore(ArrayList<Stores> list){
QueryStore(list);
Scanner sc=new Scanner(System.in);
System.out.println("请输入您要删除的品牌名称:");
String num=sc.next();
for(int i=0;i<list.size();i++){
if(num==list.get(i).sname){
list.remove(i);
}
System.out.println("删除商品成功!");
}
}
}
运行结果:

Java案例整理的更多相关文章
- Java validator整理
Java validator整理 因为想对方法的入参和出参作简单的非空或者非空字符做校验,所以找了下相关的@NotNull注解 类 | 说明 --- | --- javax.validation.co ...
- _00019 Storm架构介绍和Storm获取案例(简单的官方网站Java案例)
博文作者:妳那伊抹微笑 itdog8 地址链接 : http://www.itdog8.com(个人链接) 博客地址:http://blog.csdn.net/u012185296 博文标题:_000 ...
- java笔记整理
Java 笔记整理 包含内容 Unix Java 基础, 数据库(Oracle jdbc Hibernate pl/sql), web, JSP, Struts, Ajax Spring, E ...
- Java资料整理
Java资料整理 原创 2017年08月25日 17:20:44 14211 1.LocalThread的应用场景,数据传输适合用LocalThread么 2.linux的基本命令 软链接.更 ...
- ETL工具之kittle使用案例整理
主花了一下午时间,收集全网,学习了下kittle,觉得该大v写的不错,特意整理给大家!学会这几个案例kittle基本就没问题了. 1.kettle案例一抽取gz格式文本内容保存到mongodb ht ...
- JAVA基础整理-集合篇(一)
集合作为JAVA的基础知识,本来感觉自己理解的很清楚了,但是在最近的一次面试中还是答得不尽如人意!再次做一下整理,以便加深理解以及随时查阅. 首先,java.util包中三个重要的接口及特点:List ...
- Java数据结构整理(一)
ava数据结构内容整理关键字: 数据结构 Collection:List.SetMap:HashMap.HashTable如何在它们之间选择一.Array , ArraysJava所有“存储及随机访问 ...
- 面试之Java知识整理
1.面向对象都有哪些特性 继承.封装.多态性.抽象 2.Java中实现多态的机制是什么? 继承与接口 3.Java中异常分为哪些种类 3.1按照异常需要处理的时机分为编译时异常(CheckedExce ...
- Java案例:双色球的实现
//随机生成双色球号码 //案例:6颗红球(33选1) 1颗蓝球(16选1) 代码实现如下: import java.util.Random; import java.util.Arrays; // ...
随机推荐
- LeetCode:152_Maximum Product Subarray | 最大乘积连续子数组 | Medium
题目:Maximum Product Subarray Find the contiguous subarray within an array (containing at least one nu ...
- Chessboard POJ - 2446(最大流 || 匹配)
there is a pair of integers (x, y) in each line, which represents a hole in the y-th row, the x-th c ...
- PhoneGap & Cordova 安装白皮书
1.前题: PhoneGap是一个用基于HTML,CSS和JavaScript的,创建移动跨平台移动应用程序的快速开发平台.它使开发者能够利用 iPhone,Android,Palm,Symbian, ...
- MT【274】一道漂亮的不等式题
已知$x_1^2+x_2^2+\cdots+x_6^2=6,x_1+x_2+\cdots+x_6=0,$证明:$x_1x_2\cdots x_6\le\dfrac{1}{2}$ 解答:显然只需考虑2个 ...
- 【Gym - 100796C 】Minimax Tree
BUPT2017 wintertraining(15) #7FMinimax Tree 题意 给你一棵多叉树,非叶子节点中分配k个为子节点的min函数,剩下的是max函数. 现在求根节点(1)的最大值 ...
- 【CF671D】Roads in Yusland(贪心,左偏树)
[CF671D]Roads in Yusland(贪心,左偏树) 题面 洛谷 CF 题解 无解的情况随便怎么搞搞提前处理掉. 通过严密(大雾)地推导后,发现问题可以转化成这个问题: 给定一棵树,每条边 ...
- Docker使用阿里云docker镜像加速
首先进入阿里云docker库首页 https://dev.aliyun.com/ 点击 管理中心 点击 加速器 复制下面的加速地址 进入docker的 Settings 把basic 切换成 adva ...
- 【原】本地仓库推送到远程仓库:fatal: refusing to merge unrelated histories
最近,在操作git的时候,遇到各种问题,下面总结一下. 最开始,我不是先把远程仓库拉取到本地 ,而是直接在本地先创建一个仓库,再git remote add添加远程仓库. 当然,gitee官方还是有操 ...
- Crash 的文明世界
题目描述 给一棵树,求以每个点为根时下列式子的值. 题解 当k=1时这就是一个经典的换根dp问题. 所以这道题还是要用换根dp解决. 部分分做法: 考虑转移时是这样的一个形式(图是抄的). 用二项式定 ...
- http_proxy_module模块常用参数
Nginx的upstream模块相当于是建立一个函数库一样,把后端的服务器地址放在了一个池子里,而proxy模块则是从这个池子里调用了这些服务器. http_proxy_module模块常用参数: p ...