Go语言基础练习三

函数版学生管理系统

写一个系统能够查看、新增、删除学生

package main

import (
    "fmt"
    "os"
)

/*
    函数版学生管理系统
    写一个系统能够查看、新增、删除学生
*/


type student struct {
    id int64
    name string
}

var (
    allStudent map[int64]*student // 变量声明
)

// newStudent 是student类型的构造函数
func newStudent(id int64 ,name string) *student {
    return &student{
        id :id,
        name :name,
    }

}

func showAllStudent() {
    // 把所有的学生打印出来
    for k, v := range allStudent {
        fmt.Printf("学号:%d 姓名:%s\n",k ,v.name)
    }

}

func addStudent()  {
    // 向allStudent中添加一个新的学生
    // 1. 创建一个新学生
    // 1.1 获取用户输入
    var (
        id int64
        name string
    )
    fmt.Print("请输入学生学号:")
    fmt.Scanln(&id)
    fmt.Print("请输入学生姓名:")
    fmt.Scanln(&name)
    // 1.2 造学生(调用构造函数)
    newStu := newStudent(id,name)
    // 2.追加到allStudent这个map中
    allStudent[id] = newStu
}   


func deleteStudent() {
    //1.请输入要删除的学生的学号
    var (
        deleteID int64
    )
    fmt.Print("请输入学生学号:")
    fmt.Scanln(&deleteID)
    //2.去allStudent这个map中根据学号删除对应的键值队
    delete(allStudent,deleteID)

}

func main() {
    allStudent = make(map[int64]*student,48) // 初始化(开辟内存空间)
    for{
        // 1.打印菜单
        fmt.Println("欢迎光临学生管理系统!")
        fmt.Println(`
            1.查看所有学生
            2.新增学生
            3.删除学生
            4.退出
        `)
        fmt.Print("请输入你的操作:")
        // 2.等待用户选择要做什么
        var choice int
        fmt.Scanln(&choice)
        fmt.Printf("你选择了%d这个选项!\n",choice)
        // 3.执行对应的函数
        switch choice {
        case 1 :
            showAllStudent()
        case 2 :
            addStudent()
        case 3 :
            deleteStudent()
        case 4 :
            os.Exit(1)
        default :
            fmt.Println("请离开~")
        }

    }


}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • MYSQL 基础知识 1 MySQL数据库概要 2 简单MySQL环境 3 数据的存储和获取 4 MySQL基本操...
    Kingtester阅读 12,336评论 5 116
  • 关系数据库入门 关系数据库概述 数据持久化 - 将数据保存到能够长久保存数据的存储介质中,在掉电的情况下数据也不会...
    d4d98020ef88阅读 4,110评论 0 0
  • oracle数据库 前言 oracle sql 第一章 Selecting Rows 第二章 Sortin...
    冰川_阅读 4,459评论 0 0
  • 33、JS中的本地存储 把一些信息存储在当前浏览器指定域下的某一个地方(存储到物理硬盘中)1、不能跨浏览器传输:在...
    萌妹撒阅读 6,362评论 0 2
  • 元组 1.什么是元组 使用()将多个元素括起来,多个元素之间用逗号隔开a.容器,可以同时存储多个数据,不可变的,有...
    莫名ypc阅读 1,605评论 0 0