Golang-简单的学生管理系统的实现

简介: 简单的学生管理系统的实现

1. 编写 main.go 程序

package main

import (
    "fmt"
    "os"
)

var smr stuMgr //声明一个全局的全局变量学生管理smr

// 菜单函数

func showMenu() {
    fmt.Println("------------Welcome to sms!---------------")
    fmt.Println(`
    1. 查看所有学生
    2. 添加学生
    3. 删除学生
    4. 修改学生姓名
    5. 退出
    `)
}

func main() {

    smr = stuMgr{
        allStudent: make(map[int64]student, 100),
    }

    for {
        showMenu()
        fmt.Print("请输入操作(1 2 3 4):")
        var choice int
        fmt.Scanln(&choice)
        fmt.Printf("你输入的是:%d", choice)

        switch choice {
        case 1:
            smr.showStudent()
        case 2:
            smr.addStudent()
        case 3:
            smr.editStudent()
        case 4:
            smr.delStudent()
        case 5:
            os.Exit(1)
        default:
            fmt.Println("输入错误!")
        }
    }
}

2. 编写 student_mgr.go 程序

package main

import "fmt"

// 学生管理系统
// 有一个物件:
// 1. 它保存了一些数据 ---> 结构体的字段
// 2. 他有三个功能     ---> 结构体的方法 :面向对象编程语言的思维

// 定义学生结构体
type student struct {
    id   int64
    name string
}

// 造一个学生的管理者
type stuMgr struct {
    allStudent map[int64]student
}

// 查看所有学生
func (s stuMgr) showStudent() {
    // 遍历s.allStudent
    for _, v := range s.allStudent { // v是具体某个学生
        fmt.Printf("学号:%d 姓名:%s\n", v.id, v.name)
    }
}

// 增加学生
func (s stuMgr) addStudent() {
    // 1. 根据用户输入的内容新建一个学生
    // 2. 追加数据
    var (
        id   int64
        name string
    )
    // 获取用户输入
    fmt.Print("请输入学号:")
    fmt.Scanln(&id)
    fmt.Print("请输入学生姓名:")
    fmt.Scanln(&name)
    newStu := student{
        id:   id,
        name: name,
    }
    s.allStudent[newStu.id] = newStu
    fmt.Println("添加成功!")
}

// 编辑学生
func (s stuMgr) editStudent() {
    // 1. 获取用户输入的ID
    // 2. 展示学号对应的学生信息,如果没有提示查无此人
    // 3. 请输入修改后的学生名
    // 4. 更新
    var stuid int64
    fmt.Print("请输入学生学号:")
    fmt.Scanln(&stuid)
    stuobj, ok := s.allStudent[stuid]
    if !ok {
        fmt.Println("查无此人!")
        return
    }
    fmt.Printf("你要修改的学生信息如下:学号-%d 姓名-%s\n", stuobj.id, stuobj.name)
    fmt.Print("请输入学生的新名字:")
    var newname string
    fmt.Scanln(&newname)
    stuobj.name = newname
    s.allStudent[stuid] = stuobj //更新值
    fmt.Println("修改成功!")
}

// 删除学生
func (s stuMgr) delStudent() {
    //1. 请用户输入要删除学生的ID
    //2. 找学生,如果没有,打印查无此人
    //3. 执行删除操作
    fmt.Print("请输入要删除学生的学号:")
    var stuid int64
    fmt.Scanln(&stuid)
    _, ok := s.allStudent[stuid]
    if !ok {
        fmt.Println("查无此人!")
        return
    }
    delete(s.allStudent, stuid)
    fmt.Println("删除成功!")
}

3. 编译并执行



目录
相关文章
|
Go 调度 数据库
Golang:gocron定时任务管理系统的安装与使用
Golang:gocron定时任务管理系统的安装与使用
389 0
Golang:gocron定时任务管理系统的安装与使用
|
Go C语言 Python
Golang学习之路(八):结合GO+的学生管理系统
Golang学习之路(八):结合GO+的学生管理系统
220 0
Golang学习之路(八):结合GO+的学生管理系统
|
8天前
|
监控 算法 Go
Golang深入浅出之-Go语言中的服务熔断、降级与限流策略
【5月更文挑战第4天】本文探讨了分布式系统中保障稳定性的重要策略:服务熔断、降级和限流。服务熔断通过快速失败和暂停故障服务调用来保护系统;服务降级在压力大时提供有限功能以保持整体可用性;限流控制访问频率,防止过载。文中列举了常见问题、解决方案,并提供了Go语言实现示例。合理应用这些策略能增强系统韧性和可用性。
36 0
|
6天前
|
分布式计算 Java Go
Golang深入浅出之-Go语言中的分布式计算框架Apache Beam
【5月更文挑战第6天】Apache Beam是一个统一的编程模型,适用于批处理和流处理,主要支持Java和Python,但也提供实验性的Go SDK。Go SDK的基本概念包括`PTransform`、`PCollection`和`Pipeline`。在使用中,需注意类型转换、窗口和触发器配置、资源管理和错误处理。尽管Go SDK文档有限,生态系统尚不成熟,且性能可能不高,但它仍为分布式计算提供了可移植的解决方案。通过理解和掌握Beam模型,开发者能编写高效的数据处理程序。
134 1
|
7天前
|
缓存 测试技术 持续交付
Golang深入浅出之-Go语言中的持续集成与持续部署(CI/CD)
【5月更文挑战第5天】本文介绍了Go语言项目中的CI/CD实践,包括持续集成与持续部署的基础知识,常见问题及解决策略。测试覆盖不足、版本不一致和构建时间过长是主要问题,可通过全面测试、统一依赖管理和利用缓存优化。文中还提供了使用GitHub Actions进行自动化测试和部署的示例,强调了持续优化CI/CD流程以适应项目需求的重要性。
45 1
|
7天前
|
Kubernetes Cloud Native Go
Golang深入浅出之-Go语言中的云原生开发:Kubernetes与Docker
【5月更文挑战第5天】本文探讨了Go语言在云原生开发中的应用,特别是在Kubernetes和Docker中的使用。Docker利用Go语言的性能和跨平台能力编写Dockerfile和构建镜像。Kubernetes,主要由Go语言编写,提供了方便的客户端库与集群交互。文章列举了Dockerfile编写、Kubernetes资源定义和服务发现的常见问题及解决方案,并给出了Go语言构建Docker镜像和与Kubernetes交互的代码示例。通过掌握这些技巧,开发者能更高效地进行云原生应用开发。
49 1
|
7天前
|
负载均衡 监控 Go
Golang深入浅出之-Go语言中的服务网格(Service Mesh)原理与应用
【5月更文挑战第5天】服务网格是处理服务间通信的基础设施层,常由数据平面(代理,如Envoy)和控制平面(管理配置)组成。本文讨论了服务发现、负载均衡和追踪等常见问题及其解决方案,并展示了使用Go语言实现Envoy sidecar配置的例子,强调Go语言在构建服务网格中的优势。服务网格能提升微服务的管理和可观测性,正确应对问题能构建更健壮的分布式系统。
27 1
|
8天前
|
消息中间件 Go API
Golang深入浅出之-Go语言中的微服务架构设计与实践
【5月更文挑战第4天】本文探讨了Go语言在微服务架构中的应用,强调了单一职责、标准化API、服务自治和容错设计等原则。同时,指出了过度拆分、服务通信复杂性、数据一致性和部署复杂性等常见问题,并提出了DDD拆分、使用成熟框架、事件驱动和配置管理与CI/CD的解决方案。文中还提供了使用Gin构建HTTP服务和gRPC进行服务间通信的示例。
23 0
|
8天前
|
Prometheus 监控 Cloud Native
Golang深入浅出之-Go语言中的分布式追踪与监控系统集成
【5月更文挑战第4天】本文探讨了Go语言中分布式追踪与监控的重要性,包括追踪的三个核心组件和监控系统集成。常见问题有追踪数据丢失、性能开销和监控指标不当。解决策略涉及使用OpenTracing或OpenTelemetry协议、采样策略以及聚焦关键指标。文中提供了OpenTelemetry和Prometheus的Go代码示例,强调全面可观测性对微服务架构的意义,并提示选择合适工具和策略以确保系统稳定高效。
33 5
|
8天前
|
负载均衡 算法 Go
Golang深入浅出之-Go语言中的服务注册与发现机制
【5月更文挑战第4天】本文探讨了Go语言中服务注册与发现的关键原理和实践,包括服务注册、心跳机制、一致性问题和负载均衡策略。示例代码演示了使用Consul进行服务注册和客户端发现服务的实现。在实际应用中,需要解决心跳失效、注册信息一致性和服务负载均衡等问题,以确保微服务架构的稳定性和效率。
19 3