博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java学生管理系统
阅读量:7079 次
发布时间:2019-06-28

本文共 2594 字,大约阅读时间需要 8 分钟。

学生管理系统

实现学生对象的增删改查

  • 学生类:
public class Student {    static int num = 0;    int id ;   //系统自动生成id;    String name;    boolean gender;   //true 男,  false 女    //当初始化对象的时候调用构造方法,通过num自动生成id;    public Student() {        this.id = num++;     }    //为了防止打印的是地址    @Override    public String toString() {        String temp = "男";        if (!gender) {            temp = "女";        }        String string = "学号是:" + this.id + "姓名是:" + this.name + "性别是:" + temp;        return string;    }    }
  • 管理类

    public class Control {

    //数组

    Student[] arr = new Student[2];
    //记录当前数组中存放几个学生
    int index = 0;
    //初始化学生
    void init (){
    Student student = new Student();
    student.name = "小敏";
    student.gender = false;
    student.id = 1;

    Student student1 = new Student();  student1.name = "小张";  student1.gender = true;  student1.id = 2;  arr[0] = student;  arr[1] = student1;  this.index = 2;  //存放两个学生;

    }

    public Control() {

    this.init();
    }
    //1,显示所有学生
    void show() {
    System.out.println("--------------");
    //遍历存储的学生;
    for (int i = 0; i < this.index; i++) {
    //打印学生信息
    System.out.println(arr[i]);
    }
    }

    //2,根据ID查找学生 (返回查找到的学生)

    Student selectStudentById(int id) {
    for (int i = 0; i < index; i++) {
    //判断,传进去的ID和数组中的ID是否相同
    if (this.arr[i].id == id) {
    //如果相同,输出这个对象
    System.out.println(this.arr[i]);
    return this.arr[i];
    }
    }
    //如果代码执行到这个位置没有找到学生,返回null;
    return null;
    }

    //3,根据ID删除学生;并且返回被删除的元素对象

    Student deleteStudentByid(int id) {
    //如果ID小于0,直接返回空
    if (id < 0) {
    return null;
    }
    //先找到这个学生
    int tag = -1; //假定的学生在数组中的位置,不可以为0;因为如果为0,当没有找到要删除的学生的时候,就会把第0个元素的学生删除.
    for (int i = 0; i < index; i++) {
    if (id == this.arr[i].id) { //找到这个学生
    tag = i; //记录他的下标
    break;
    }
    }
    if (tag == -1) { //说明没有找到要删除的学生;
    return null;
    }
    //记录要删除的元素对象,根据记录的tag去找
    Student temp = this.arr[tag];
    //删除学生,后边的元素向前移动一位;(如果有四个学生对象,删除一个,所以只需移动三次即可,所以index要减一)
    for (int i = 0; i < index - 1; i++) {
    //后边的元素前移;
    this.arr[i] = this.arr[i+1];
    }
    index--;
    return temp;
    }

    //4,增加学生对象

    void addStudent(Student st) {
    //如果index < 数组的长度,直接添加元素
    if (index < this.arr.length) {
    this.arr[index] = st;
    index++;
    }else { //数组没有空位置了
    //扩充数组
    this.expandArr();
    //添加 当扩充完数组以后,index就小于数组的长度,上边的判断就可以成立,,所以这里调用方法自身;
    this.addStudent(st);

    }

    }

    //5,修改学生信息

    void updateStudentByStudent(Student stu) {
    //查找学生
    Student st = this.selectStudentById(stu.id);
    //修改
    st.name = stu.name;
    st.gender = stu.gender;
    }

    //扩充数组

    void expandArr() {
    //创建一个新数组 (直接给他的长度加10,避免多次增加长度)
    Student[] stus = new Student[this.arr.length + 10];
    //把元素复制过去
    for (int i = 0; i < index; i++) {
    //把旧数组的元素给新数组
    stus[i] = this.arr[i];
    }
    //新数组名存放的是地址,把这个地址再赋值给旧数组,所以通过旧数组访问的也是新的元素
    this.arr = stus; //把新数组赋值给数组;
    }
    }

转载于:https://www.cnblogs.com/S-YAnLEi/p/7492794.html

你可能感兴趣的文章
【转】mysql对large page的支持
查看>>
11-unittest
查看>>
学习OpenSeadragon之四(导航视图)
查看>>
PHP表单数据写入MySQL代码
查看>>
ASP.NET:Session对并发访问的影响
查看>>
Insertion sort list
查看>>
centos7 安装java+tomcat
查看>>
Uncaught TypeError: form.attr is not a function 解决办法
查看>>
HDU 1023 Train Problem II( 大数卡特兰 )
查看>>
策略模式
查看>>
图片的画图板
查看>>
【网摘】C#中TransactionScope的使用方法和原理
查看>>
SAE 部署 bilibili 爬虫
查看>>
IQ:1,11,21,1211,111221,下一个数是什么?
查看>>
4.4.1 二维复合矩阵编程实例
查看>>
laravel进程管理supervisor的简单说明
查看>>
Python Xpath 提取html整个元素(标签与内容)
查看>>
PDF417条码简介
查看>>
VC线程同步方法总结
查看>>
Activex、OLE、COM、OCX、DLL之间的区别(转)
查看>>