大数据学习--day08(hnapp 后台系统开发、面向对象)
hnapp 后台系统开发、面向对象
利用前面所学的知识,写一个控制台登陆注册后台界面
package sy180918.hnapp.array; import java.util.Arrays;
import java.util.Scanner; public class HnApp {
static Scanner sc = new Scanner(System.in); // 成员变量 提高作用域 static int[] users = new int[2]; // 存储 用户名
static int[] pswds = new int[2]; // 存储密码
static int count; // 默认是 0 记录真实的用户个数 static boolean userState ;// 默认是 false 用来记录登录状态
static int userName ; // 当前登录用户的用户名 public static void main(String[] args) {
test: while(true){
mainHtml();
int next = sc.nextInt();
switch (next) {
case 1: zhuce();break;
case 2: logon(); break;
case 3: setPswd();break;
case 4: System.out.println("退出");break test;
default:
System.out.println("非法字符");break;
}
} } /**
* 修改密码
*/
private static void setPswd() {
if(!userState){
System.out.println("请先登录 之后再来改密码");
return ;
} int i = 0;
for( ; i < count ; i++){
if(userName == users[i])
break; } System.out.println("请输入新密码");
int newPswd = sc.nextInt(); pswds[i] = newPswd;
System.out.println("密码修改成功 你已下线 请重新登录");
userName = 0;
userState = false; } /**
* 登录方法
*/
private static void logon() {
if(userState){
System.out.println("不能重复登录");
return ;
} System.out.println("欢迎来到登录页面");
System.out.println("请输入登录的用户名");
int user = sc.nextInt();
System.out.println("请输入登录的密码");
int pswd = sc.nextInt(); // 判断用户在不在
boolean flag = selectUser(user); if(flag){// 此时有用户 // 判断密码是否对应 // 1. 找到 在数组中 user 的索引
int i = 0;
for( ; i < count ; i++){
if(users[i] == user)
break;
} if( pswds[i] == pswd){
System.out.println("欢迎登录");
userState = true; // 修改登录状态
userName = user;
}else{
System.out.println("密码错误");
} }else{// 此时没有该用户
System.out.println("用户 "+user+" 不存在");
}
} /**
* 注册的方法
*/
private static void zhuce() {
// 键盘录入 用户
System.out.println("欢迎来到注册页面");
System.out.println("请输入注册的用户名");
int user = sc.nextInt();
System.out.println("请输入注册的密码");
int pswd = sc.nextInt(); // 查看用户是否已经存在
boolean flag = selectUser(user);
if(flag){
System.out.println("用户 "+user+" 已经存在 , 请更换其他用户");
return ;
} // 增加存储介质的 容量
if( count == users.length ){
System.out.println("正在扩容");
int oldLength = users.length ;
int newLength = oldLength + (oldLength>>1);
System.out.println(oldLength+"->"+newLength);
users = Arrays.copyOf(users, newLength); // 1.5 倍扩容
pswds = Arrays.copyOf(pswds, newLength);
} // 写入 存储介质
users[count] = user;
pswds[count] = pswd;
count++;
System.out.println("用户 "+user+" 注册成功");
} /**
* 查看 存储介质中 是否有指定的 user
* @return 规定 : 有该用户返回 true
*/
public static boolean selectUser(int user){
// 查看用户是否已经存在
for(int i = 0 ; i < count ; i++){
if(users[i] == user)
return true;
}
return false;
} /**
* 主菜单页面
*/
public static void mainHtml(){
System.out.println("=====欢迎来到 HnApp 后台系统========");
System.out.println("=================================");
System.out.println("----请按照提示进行操作----"); System.out.println("输入1 : 注册用户");
System.out.println("输入2 : 登录用户");
System.out.println("输入3 : 修改密码");
System.out.println("输入4 : 退出系统\n\n\n");
}
}
这些逻辑就当复习了,注意算术运算符优先级大于位运算符。
每次操作之后立即更新状态,全局变量。
面向对象
大数据学习--day08(hnapp 后台系统开发、面向对象)的更多相关文章
- 大数据学习路线之linux系统基础搭建
		
学习大数据是必须掌握一定Linux知识的,工欲善其事,必先利其器.在学习之前,首先需要搭建Linux系统,本节将讲解VMware Workstation的安装和CentOS 7系统的安装. 1.2.1 ...
 - 大数据学习——azkaban工作流调度系统
		
azkaban的安装部署 在/root/apps 1目录下新建azkaban文件夹 上传安装包到azkaban 2解压 .tar.gz 3删掉安装包 [root@mini1 azkaban]# .ta ...
 - 大数据学习day26----hive01----1hive的简介  2 hive的安装(hive的两种连接方式,后台启动,标准输出,错误输出)3. 数据库的基本操作 4. 建表(内部表和外部表的创建以及应用场景,数据导入,学生、分数sql练习)5.分区表  6加载数据的方式
		
1. hive的简介(具体见文档) Hive是分析处理结构化数据的工具 本质:将hive sql转化成MapReduce程序或者spark程序 Hive处理的数据一般存储在HDFS上,其分析数据底 ...
 - 大数据学习之Linux基础01
		
大数据学习之Linux基础 01:Linux简介 linux是一种自由和开放源代码的类UNIX操作系统.该操作系统的内核由林纳斯·托瓦兹 在1991年10月5日首次发布.,在加上用户空间的应用程序之后 ...
 - 大数据学习:storm流式计算
		
Storm是一个分布式的.高容错的实时计算系统.Storm适用的场景: 1.Storm可以用来用来处理源源不断的消息,并将处理之后的结果保存到持久化介质中. 2.由于Storm的处理组件都是分布式的, ...
 - 大数据学习之Hadoop快速入门
		
1.Hadoop生态概况 Hadoop是一个由Apache基金会所开发的分布式系统集成架构,用户可以在不了解分布式底层细节情况下,开发分布式程序,充分利用集群的威力来进行高速运算与存储,具有可靠.高效 ...
 - 大数据学习(一) | 初识 Hadoop
		
作者: seriouszyx 首发地址:https://seriouszyx.top/ 代码均可在 Github 上找到(求Star) 最近想要了解一些前沿技术,不能一门心思眼中只有 web,因为我目 ...
 - 大数据学习笔记——Hadoop编程实战之HDFS
		
HDFS基本API的应用(包含IDEA的基本设置) 在上一篇博客中,本人详细地整理了如何从0搭建一个HA模式下的分布式Hadoop平台,那么,在上一篇的基础上,我们终于可以进行编程实操了,同样,在编程 ...
 - 大数据学习day31------spark11-------1. Redis的安装和启动,2 redis客户端 3.Redis的数据类型  4. kafka(安装和常用命令)5.kafka  java客户端
		
1. Redis Redis是目前一个非常优秀的key-value存储系统(内存的NoSQL数据库).和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list ...
 
随机推荐
- Linux-->Mysql:安装,测试
			
环境准备 mysql下载地址:https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.19-linux-glibc2.12-x86_64.tar ...
 - Vc code
			
通达信L2行情接口, 包括普通行情接口所有功能, 并新增了十档行情, 逐笔成交,买卖队列和深圳逐笔委托(上海证券交易所不对外提供逐笔委托数据)这四个新功能. // TdxHqDemoCpp.cpp : ...
 - Python学习---Python下[字典]的学习
			
Python中唯一的映射类型(哈希表) -->Java中的HashMap<K,V> Python对key进行了哈希函数运算,根据计算的结果决定value的存储地址,所以字 ...
 - 在IE浏览器输入测试servlet程序报:HTTP Status 404(The requested resource is not available)错
			
一.HTTP Status 404(The requested resource is not available)异常主要是路径错误或拼写错误造成的,请按以下步骤逐一排查: 1.未部署Web应用 2 ...
 - python 爬虫网络图片中遇到的问题总结
			
1.只导入了import urllib,读取网页的时候page =urllib.urlopen(url),提示 “module’ object has no attribute ’urlopen’”, ...
 - TCP、UDP、Socket 通信(原)
			
说明:本随笔主要演示自己给自己发送消息例子,分别使用了TCP协议.UDP协议以及socket套接字通信.使用socket套接字了模拟TCP.UDP通信实现原理.其中有些源码都来自<C#高级编程 ...
 - Windows Server 2012/2012 R2:安装和配置 SMTP 服务器
			
Windows Server 2012/2012 R2:安装和配置 SMTP 服务器 安装 SMTP 服务器 以下是安装 SMTP 服务器功能的步骤: 打开“服务器管理器”:单击键盘上的 Window ...
 - Android(java)学习笔记211:Android线程池形态
			
1. 线程池简介 多线程技术主要解决处理器单元内多个线程执行的问题,它可以显著减少处理器单元的闲置时间,增加处理器单元的吞吐能力. 假设一个服务器完成一项任务所需时间为:T1 创建线程时间, ...
 - php 多种输入参数完整性检查
			
说明:(1)输入可能有多重类型的输入,即需要对输入参数进行多次匹配. (2)希望能够返回缺少的参数 代码如下: /** * @param $param 输入参数 (get,post 参数) * @pa ...
 - docker-3-常用命令(中)
			
容器命令 1.有镜像才能创建容器,这是根本前提(下载一个CentOS镜像演示) docker pull centos 2.新建并启动容器 docker run [OPTIONS] IMAGE [COM ...