0

0

如何使用Java来创建简单的学生信息管理系统

P粉602998670

P粉602998670

发布时间:2025-10-04 21:34:02

|

669人浏览过

|

来源于php中文网

原创

先创建Student类封装学生信息,再通过StudentManager类实现增删改查功能,使用ArrayList存储学生对象,结合Scanner接收用户输入,最后在Main类中启动菜单循环,完成控制台版学生信息管理系统。

如何使用java来创建简单的学生信息管理系统

用Java创建一个简单的学生信息管理系统,可以通过控制台实现增删改查功能。不需要数据库或图形界面,适合初学者练习面向对象编程和基础语法。

1. 定义学生类(Student)

先创建一个Student类,用来封装学生的基本信息,比如学号、姓名、年龄和成绩。

这个类包含属性、构造方法和getter/setter方法:

public class Student {
    private String id;
    private String name;
    private int age;
    private double score;

    public Student(String id, String name, int age, double score) {
        this.id = id;
        this.name = name;
        this.age = age;
        this.score = score;
    }

    // Getter 和 Setter 方法
    public String getId() { return id; }
    public void setId(String id) { this.id = id; }

    public String getName() { return name; }
    public void setName(String name) { this.name = name; }

    public int getAge() { return age; }
    public void setAge(int age) { this.age = age; }

    public double getScore() { return score; }
    public void setScore(double score) { this.score = score; }

    @Override
    public String toString() {
        return "学号:" + id + ",姓名:" + name + ",年龄:" + age + ",成绩:" + score;
    }
}

2. 创建管理类(StudentManager)

使用ArrayList来存储多个学生对象,并提供添加、删除、修改、查询等方法。

网奇IOS智能在线订单系统
网奇IOS智能在线订单系统

产品简介: 网奇IOS智能订单系统,是网奇公司研发的一款智能在线订单编辑以及管理系统。本系统适合使用在;在线报名、酒店预定、信息反馈、在线订单和在线投诉等等诸多应用上。本系统所有选项字段完全通过后台控制,在线报名系统可以变为在线预定系统,同时可以变为任何其它的系统,里面的栏目字段,可以任意添加、删除、 修改。本系统为网奇公司全国独家首创,顺应网络需求,安装十分便利,上传即可使用。产品特色:

下载

立即学习Java免费学习笔记(深入)”;

以下是核心代码结构:

import java.util.ArrayList;
import java.util.Scanner;

public class StudentManager {
    private ArrayList students = new ArrayList<>();
    private Scanner scanner = new Scanner(System.in);

    // 添加学生
    public void addStudent() {
        System.out.print("输入学号:");
        String id = scanner.nextLine();
        System.out.print("输入姓名:");
        String name = scanner.nextLine();
        System.out.print("输入年龄:");
        int age = Integer.parseInt(scanner.nextLine());
        System.out.print("输入成绩:");
        double score = Double.parseDouble(scanner.nextLine());

        Student student = new Student(id, name, age, score);
        students.add(student);
        System.out.println("添加成功!");
    }

    // 查看所有学生
    public void viewStudents() {
        if (students.isEmpty()) {
            System.out.println("暂无学生信息。");
        } else {
            for (Student s : students) {
                System.out.println(s);
            }
        }
    }

    // 根据学号查找学生
    public Student findStudentById(String id) {
        for (Student s : students) {
            if (s.getId().equals(id)) {
                return s;
            }
        }
        return null;
    }

    // 删除学生
    public void deleteStudent() {
        System.out.print("输入要删除的学号:");
        String id = scanner.nextLine();
        Student student = findStudentById(id);
        if (student != null) {
            students.remove(student);
            System.out.println("删除成功!");
        } else {
            System.out.println("未找到该学生。");
        }
    }

    // 修改学生信息
    public void updateStudent() {
        System.out.print("输入要修改的学号:");
        String id = scanner.nextLine();
        Student student = findStudentById(id);
        if (student != null) {
            System.out.print("新姓名:");
            student.setName(scanner.nextLine());
            System.out.print("新年龄:");
            student.setAge(Integer.parseInt(scanner.nextLine()));
            System.out.print("新成绩:");
            student.setScore(Double.parseDouble(scanner.nextLine()));
            System.out.println("修改成功!");
        } else {
            System.out.println("未找到该学生。");
        }
    }

    // 主菜单
    public void showMenu() {
        while (true) {
            System.out.println("\n=== 学生信息管理系统 ===");
            System.out.println("1. 添加学生");
            System.out.println("2. 查看所有学生");
            System.out.println("3. 删除学生");
            System.out.println("4. 修改学生");
            System.out.println("5. 退出");
            System.out.print("请选择操作:");

            String choice = scanner.nextLine();
            switch (choice) {
                case "1" -> addStudent();
                case "2" -> viewStudents();
                case "3" -> deleteStudent();
                case "4" -> updateStudent();
                case "5" -> {
                    System.out.println("退出系统。");
                    return;
                }
                default -> System.out.println("无效选择,请重试。");
            }
        }
    }
}

3. 编写主程序入口

创建一个Main类,启动系统。

public class Main {
    public static void main(String[] args) {
        new StudentManager().showMenu();
    }
}
运行效果示例:
  • 用户选择“1”可添加学生信息
  • 选择“2”查看当前所有学生
  • 输入“3”按学号删除
  • 选择“4”修改已有信息
  • 输入“5”退出程序
基本上就这些。不复杂但容易忽略细节,比如输入类型转换和空值判断。可以后续扩展功能,比如保存到文件、支持模糊查询等。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
go语言 面向对象
go语言 面向对象

本专题整合了go语言面向对象相关内容,阅读专题下面的文章了解更多详细内容。

56

2025.09.05

java面向对象
java面向对象

本专题整合了java面向对象相关内容,阅读专题下面的文章了解更多详细内容。

51

2025.11.27

C++类型转换方式
C++类型转换方式

本专题整合了C++类型转换相关内容,想了解更多相关内容,请阅读专题下面的文章。

299

2025.07.15

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

356

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2078

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

348

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

256

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

325

2023.10.09

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.9万人学习

C# 教程
C# 教程

共94课时 | 7.7万人学习

Java 教程
Java 教程

共578课时 | 51.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号