查看原文
其他

如何在码云上展开程序类课程教学 | 码云高校版最佳实践

郑如滨 Gitee 2021-05-26

码云高校版,是开源中国和国防科技大学Trustie团队深度合作推出的教学实践环境,该平台融入Trustie群体化方法与技术的重要成果,为高校软件工程人才培养赋能助力。



码云 主要提供了源代码管理(Git/SVN)功能,最近又推出了高校版让普通老师也能利用起来以供教学使用。学生与老师不仅能利用其管理代码,更重要的是我们的程序教学能通过对 Git 的使用来引入业界流行的软件开发方式。


经过摸索,大概有几个可以利用的场景。


学生代码管理


以前学生在实验室编写好代码带回宿舍,通常使用U盘拷贝或者QQ邮箱的方式。麻烦不说,最关键的是不够专业!作为计算机专业的学生应该对这种不专业的行为,果断说不。


可以使用码云提供的 Git 服务来管理我们的代码。Git 最常用的当然是命令行版本,当然对初学者来说还是有一定的难度(很多同学连dircd命令都不知道)。我们一开始作为过渡,可以先使用网页版。


1

最简单的入门(创建项目)


步骤很简单,只需3步:


  1. 申请账号。

  2. 新建项目。注意:选择正确类型,比如管理 Java 项目,尽量选择 Java 的模板。

  3. 在项目中直接新建、上传、删除文件、文件夹。


进入项目后的大概界面如下:



先熟悉如下功能。


  • 代码:你的代码都在这里。可以在这里上传、删除、修改代码。

  • Issues:别人可以对你的代码提出问题,当然也可以当做论坛来用。

  • 管理:可以删除项目、基本项目设置、项目成员管理(可以把你的团队成员加进来一同编写代码)。


然而这样建立的项目是学生自己的项目,不方便老师查看代码。我们可以利用码云上 Git 的 Fork + Pull 模式 来实现教师对学生代码的统一管理。


2

Fork + Pull 构建统一的学生代码仓库


使用这种模式管理学生代码可以让学生在提交代码的过程中学习到业界最流行的分布式开发技术。具体步骤如下:


  1. 教师新建一个代码库项目,如上图所示。代码库可以是空的项目,然后将项目地址发给学生。

  2. 学生点击右上角的 Forked,将教师的代码库 Fork 到自己的账号下。

  3. 学生在该项目下建立自己学号命名的目录,然后将代码放入该目录。

  4. 学生点击该项目的 Pull Requests,然后点击+新建 Pull Request。提出请求,将自己的代码合并到老师建立的代码库项目中。

  5. 教师端点击 Pull Request,可以查看学生提交的 Pull Request。然后根据需要决定是否接受该学生的合并请求。主项目截图如下。



可以看到学生的代码都被放到主项目中,教师需要的时候可以查看每个学生的提交情况。


这种模式有几个特点要注意:


  • 合并到主项目的所有代码都可以被项目成员看到。所以要小心学生作业代码泄露问题。我利用这个功能主要是为了让学生学会使用git、熟悉"Fork + Pull**模式,至于抄袭问题我会使用别的工具来解决。当然也期望码云会推出相关功能。[2018/09/20更新],码云现在已经增加了相关功能解决了该问题,见这篇参考文章 开启 Pull Requests 显示权限

  • 如果一个班级的人数太多,让每个学生发起 Pull Request,老师一一审核。那无疑对老师发起了DDOS pull request 共计。老师一个一个确认到手段。对于这个问题,教师可以将审核任务委派给班级的学习委员。这个功能具体操作可以参见官方文章:码云上线 Pull Requests 多人代码审核功能


相关参考文章:Fork + Pull 模式


3

Git 命令模式或 IDE 管理源代码


可以参考如下文章:官方帮助-提交第一行代码


我的其他原创文章:



教师项目模板与项目代码质量检查


1

教师项目模板


老师布置程序项目类作业的时候,即使再三强调要按照规范来建立项目目录结构。然而最终提交结果依然不尽如人意。每个人似乎都有自己的一套项目结构,并且这个结构通常是惨不忍睹的,比如一包流,所有代码均放到一个包中。


教师完全可以规划好一个项目的标准目录结构,然后让学生 Fork 或 clone 下来,这样就无痛的规范了所有学生的项目目录结构。实际上这也是业界流行的一种方式。学生可以参考我的这个专门用于 Java 教学的一个项目 OnlineShop,该项目包含一个可供参考的标准项目目录结构。


2

项目代码质量检查


学生的代码即使按照目录规范要求提交上来,但是很多时候代码质量惨不忍睹。比如变量命名、对 null 的处理。让老师一一检查,这可是要了老师的命。码云项目中提供了项目代码质量检查,让学生交给老师审查之前先自查一下。如下图所示:



3

真正的让团队合作开发实施起来


传统的程序项目作业,名义上是小组合作完成,然而,实际上由于缺乏工具的支持,很难真正的实现分布式开发。到最后甚至演变成,1拖n(1个组长搞定全部)的现象。


通过码云的 Git 服务可以真正让分布式开发真正实现,教师可以通过观察项目的提交记录,来确认每个人的是否真正完成了自己的任务。一个课程设计作业提交记录如下图:



老师可以大概判断一下该项目是否真正的实现了分布式开发,开发的工作进度是如何的。


其他几点期望


在教学方面还希望码云能提供如下几个功能:


  • 通过提交记录来判定学生项目推进情况的工具。

  • 更完善的学生提交数据。比如学生每周提交数、代码行数。不仅是每个学生,而且要有所有学生的总体情况。最好以图形化的方式展示。

  • 更多可以通过提交相关数据来辅助教学的工具。


/

REVIEW

往期精彩


码云如何保护你的数据——内部安全治理篇

如何打造高效 DevOps 工具链 | 码云周刊第 82 期

U盘或邮件审核代码作业太繁琐?你该试试 Git 分支  | 码云高校版最佳实践

【文末有彩蛋】程序员的标准生活

    您可能也对以下帖子感兴趣

    文章有问题?点此查看未经处理的缓存