《電子技術應用》
您所在的位置:首頁 > 通信與網絡 > 業界動態 > 為什么學計算機的學生應該向開源項目做貢獻?

為什么學計算機的學生應該向開源項目做貢獻?

2021-07-10
來源:CSDN
關鍵詞: 開源 編程

編程是所有計算機科學、信息學、軟件工程和計算機工程專業的必修課。幾十年來,這項技能成為了區分計算機專業的畢業生與其他學科的同齡人的關鍵。我認為21世紀,編程的熟練程度本身既不能代表市場對計算機畢業生的技術水平要求,也不能成為有分量的資格證書。因此,我建議應該鼓勵計算機專業的學生通過課程活動為開源軟件項目貢獻代碼。

微信圖片_20210710162842.jpg

我在軟件工程課程中實踐這種方法已經有15年了,向開源項目貢獻代碼是必做的作業。本文中將根據個人的經驗,說明為什么向開源項目貢獻代碼能夠體現出學生對編程技巧的掌握情況,學生可以從這些活動中學到什么,如何將向開源項目貢獻代碼嵌入到課程中,以及如何幫助學生完成這份作業。

  向開源項目貢獻代碼是編程的新概念

  如今,編程只是軟件開發人員必須掌握技能之一。出現這種情況的原因有兩個:

  首先,編程實踐的發展遠遠超出了Fred Brooks于20世紀70年代推廣的首席程序員模型,系統的規模擴大了幾個數量級、工具更加先進、流程的自動化也得到了普及,還有團隊合作、工作流程以及管理的日益復雜化。

  其次,行業最佳實踐與大型成功的開源軟件項目所遵循的實踐已經趨同。各個企業都吸收并貢獻了許多開源開發實踐。因此,相應的知識和技術力在志愿者項目與企業項目之間是通用的。

  因此,我們的教學必須從課程的教育實驗室走向實際的組織環境。學生可以通過為開源項目做貢獻,在實踐中獲得了廣泛的技能、知識和經驗,使他們成長為全面發展的現代開發人員,而不是好萊塢影片中的獨狼程序員。傳統的編程作業最難獲得的技能是以下社交與組織能力:

  熟悉背景:了解項目范圍、使命、合作開發團隊以及新的領導形式下實際的開發工作狀況;

  與項目的全球及多元化社區互動;

  協商功能的請求、要求以及實現方法;

  處理溝通問題,例如無人響應,這在志愿者運營的項目中很常見;

  通過問題分類和發布計劃等實踐,認識作為產品的軟件;

  接收、討論和處理代碼審查意見。

  與技術相關的學習成果包括分析、評估、應用和創建等,具體內容如下:

  瀏覽項目的資產,例如軟件代碼、議題、文檔和拉取請求;

  快速評估軟件系統或組件的產品和流程質量,這在現代軟件的重用中經常需要;

  配置、構建、運行和調試第三方代碼;

  設置和運行包含不同軟件和硬件要求的軟件密集型系統。我開設的課程中包含手機、汽車電子、應用服務器、數據庫、容器、物聯網設備和嵌入式設備;

  選擇實際的貢獻目標。(學生往往會在初期階段高估他們為項目做貢獻的能力。)這是敏捷開發沖刺中的一項關鍵活動;

  閱讀第三方代碼,找出需要添加的功能或修復的問題;

  通過添加新功能或修復錯誤來修改大型第三方系統;

  編寫測試來證明自己貢獻的代碼無論在當下還是將來都能夠按預期工作;

  學習使用多種編程語言和工具開發的軟件系統。學生經常驚訝地發現,掌握集成開發環境 (IDE) 的知識遠遠不足以為項目做貢獻;

  記錄自己的工作,一般都會使用聲明式標記語言,例如 Markdown 或文檔生成器代碼注釋;

  遵循復雜的配置管理(版本控制)工作流程,例如處理問題分支和重新提交代碼;

  通過預提交和持續集成的檢查和測試。

  從這些實踐中獲得的社交經驗和技術經驗都是現代辦公環境所必須的,這些超出了ACM/IEEE 提出的軟件工程課程大綱。同時,課程的實踐也與ACM/IEEE課程大綱中的許多內容息息相關。這主要包括:鍛煉個人技能,例如批判性判斷、有效溝通和認識到自己的局限;培養自主學習的技能;了解解決軟件工程問題的多個維度;使用適當的最新工具;建立現實世界的基礎;并通過各種教學和學習方法推進教育。

  在軟件工程課程中嵌入開源開發

  這門把“向開源軟件做貢獻”作為必做作業的課程名為“實踐中的軟件工程”,是大三課程的一部分。(該課程在 2019 年獲得了管理學院的卓越教學獎。)每年我們都會向20~50名雅典經濟與商業大學管理科學與技術系軟件和數據分析技術專業的學生教授這門課程。這門課程也是該大學信息學系的推薦選修課。

  該課程在某種程度上顛覆了傳統的課堂教學方法,最后的成績完全由課程作業決定。向開源軟件的貢獻度占總分的50%。學生可以單獨或結對完成作業。結對的目的是幫助沒有安全感的學生,但要求結對完成的工作量必須多于個人,而且貢獻必須來自個人的GitHub賬號。

  我們根據學生提供的在線開源項目工作(代碼提交和交互)、他們的最終書面報告以及課堂演示來評估學生的表現。一共需要三場演講,分別在第 4 周(描述所選項目)、第 8 周(概述提議的貢獻)和第 14 周(總結貢獻的實現)。貢獻的代碼是否被接受并不會作為作業的評判標準,但會得到積極的評估。其他評估要素包括,學生對自己選擇的項目的理解和文檔、貢獻的廣度、實現的質量、代碼與項目的集成、測試實施、與項目開發團隊的合作、口頭陳述、書面報告的質量,以及他們在版本控制、代碼審查、議題管理和文檔等活動中使用的工具。

  理論上,他們可以作弊(通過復制項目分支的貢獻等),這可能會成為一個問題,但我們要求學生在課堂上展示他們的成果,而且我們會讓學生們明白,他們貢獻的代碼會成為個人的一項戰績,而且將來還會被潛在雇主的詢問,這些措施可以杜絕作弊。

  成功地向開源項目做貢獻

  剛開始接觸這門課程的時候,學生們都懷著惶恐的心情,但在完成后都會非常高興。為了確保學生能夠為開源項目做出有意義的貢獻,我們需要考慮到他們的經驗不足與現代開源軟件開發的快節奏與復雜性。

  這些年來,通過我分配的作業可以看出,為開源項目做貢獻的難度越來越低。各個項目變得更具包容性。許多項目簡化了新手入門指導,團隊更加多樣化(包括女性領導),公開聯系方式很常見,回復通常都很有禮貌,而且支持Windows 構建(盡管一些學生采用 Linux 以避免出現故障)。由于拉取請求工作流程中的手動控制、持續集成的廣泛采用、多樣化的代碼檢查機器人、友好的代碼審查流程以及拉取請求草案的使用,做貢獻的難度已降低。

  盡管如此,學生們接觸的開源項目環境與傳統學術作業環境的體驗仍然相去甚遠。因此,小規模的貢獻才是比較現實的目標。為了讓這門課程的作業發揮作用,關鍵在于降低對學生所做貢獻度的期望。對于一個本科生來說,為開源做貢獻的門檻非常高,即便是向一個大型項目貢獻20行代碼也是值得慶賀的成就。我們給學生選擇項目的建議可以總結如下:

  選擇一個有多位活躍貢獻者的項目,這樣就有一個社區來指導并回答你的問題。

  選擇一個相對流行的項目(獲得了一些GitHub給星),證明這個項目提供了有用的功能,并且以相對合理的方式開發。你應該避免上傳到GitHub已久的廢棄論文項目。

  避免過于受歡迎的項目,因為你的貢獻會被其他競爭者、噪音和官僚主義淹沒。(盡管如此,我們的一些學生還是參與了轟動一時的項目,例如 Tensorflow 和 Visual Studio Code。)

  確認可以在自己的計算機上構建和運行項目。

  確保項目定期接受來自外部的拉取請求,保證自己也有機會。

  嘗試提供一個簡單的bug修復,作為熱身練習,測試一下自己是否有能力嚴格遵守項目的工作流程。

  查找帶有“Good first issue”標記的議題,這表明該項目對新貢獻者很友好。

  至于選擇貢獻怎樣的代碼,則完全由學生自己決定。他們可以從項目的議題列表中選擇一個開放的任務,或者提出自己的增強或修復意見。學生在與項目的核心團隊互動后也會經常改變策略。盡管讓他們自由選擇自己的貢獻似乎讓這個作業變得很容易,但我發現大約一半學生貢獻的代碼都被采納了。

  學生在作業中面臨的最常見問題包括無法構建項目(通常是由于缺乏經驗和平臺不兼容),以及項目團隊缺乏溝通(學生會過分焦慮,認為他們貢獻的代碼必須被采納)。另一方面,學生們最大的快樂在于,發現自己的代碼被某個全世界都在使用的生產軟件所采納。在課程評估中,學生都很開心,他們表示自己在向開源軟件做貢獻的過程中獲得了許多實踐技能,同時也更自信了。




電子技術圖片.png

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
男人插女人欧美| 国产日韩一区欧美| 欧美一区二区三区婷婷月色| 一本色道久久综合亚洲精品不 | 亚洲免费一区二区| 在线视频一区二区| 一本色道久久综合狠狠躁篇怎么玩 | 久久美女性网| 久久偷看各类wc女厕嘘嘘偷窃| 欧美在线观看www| 欧美一区二区三区电影在线观看| 亚洲在线一区二区| 亚洲已满18点击进入久久| 在线视频精品一区| 亚洲一区二区精品视频| 亚洲中字在线| 欧美一区二区高清| 久久国产精品亚洲va麻豆| 久久精品国产第一区二区三区最新章节 | 一区三区视频| 在线观看中文字幕亚洲| 激情av一区| 亚洲高清视频中文字幕| 亚洲人成高清| 在线一区视频| 亚洲视频中文字幕| 午夜电影亚洲| 久久精品国产精品| 亚洲乱码精品一二三四区日韩在线| 亚洲精品老司机| 在线午夜精品自拍| 亚洲男人第一网站| 欧美在线亚洲| 六月婷婷一区| 欧美精品v日韩精品v韩国精品v| 欧美日韩免费视频| 国产精品久久一卡二卡| 国产亚洲精品v| 在线欧美小视频| 一区二区欧美日韩| 午夜精品影院在线观看| 久久精品视频亚洲| 在线一区观看| 久久av资源网| 欧美精品v国产精品v日韩精品| 国产精品电影网站| 激情欧美一区二区| 一本久道久久综合中文字幕| 欧美一区免费| 亚洲免费不卡| 欧美一区日韩一区| 免费观看成人鲁鲁鲁鲁鲁视频| 欧美日韩二区三区| 国产乱码精品一区二区三区av | 99亚洲一区二区| 欧美伊人久久久久久久久影院| 亚洲欧洲日产国码二区| 亚洲视频高清| 久久久久久久尹人综合网亚洲| 欧美精品自拍偷拍动漫精品| 国产伦精品一区二区三区视频孕妇| 1024国产精品| 亚洲综合色丁香婷婷六月图片| 亚洲国产毛片完整版 | 国产欧美日韩亚洲精品| 在线日韩av片| 亚洲制服丝袜在线| 亚洲人线精品午夜| 欧美在线免费观看| 欧美另类一区| 黄色免费成人| 亚洲欧美国产77777| 亚洲狼人综合| 久久精品夜色噜噜亚洲aⅴ| 欧美日韩国产在线播放| 红桃视频国产精品| 亚洲一区二区伦理| 亚洲精品在线免费| 久久久国产精品亚洲一区| 欧美午夜精品久久久久免费视| 在线国产欧美| 久久gogo国模裸体人体| 亚洲欧美日韩精品久久久| 欧美精品久久99| 雨宫琴音一区二区在线| 香蕉视频成人在线观看| 国产精品99久久久久久宅男| 欧美成人a∨高清免费观看| 国产在线观看91精品一区| 亚洲一卡久久| 亚洲无限av看| 欧美日韩精品不卡| 亚洲国产裸拍裸体视频在线观看乱了 | 久久久久中文| 国产麻豆午夜三级精品| 99精品热6080yy久久| 亚洲精品欧美日韩| 久久亚洲捆绑美女| 国产日韩精品视频一区二区三区| 夜夜爽av福利精品导航| 亚洲精品影视| 欧美r片在线| 在线观看亚洲一区| 亚洲国产日韩欧美综合久久| 久久久久九九九九| 国产婷婷色一区二区三区在线 | 夜夜嗨av一区二区三区四季av| 免费试看一区| 亚洲成人在线观看视频| 亚洲国产成人久久综合| 久久久欧美精品sm网站| 国产日韩欧美中文| 午夜精品成人在线视频| 欧美亚洲一区二区在线| 国产精品久久久久久影视| 在线亚洲自拍| 亚洲欧美日韩人成在线播放| 欧美视频观看一区| 一区二区高清视频在线观看| 亚洲一区3d动漫同人无遮挡| 欧美午夜精品久久久久免费视| 一本色道久久综合狠狠躁篇怎么玩| 亚洲视频一区二区在线观看 | 国产毛片一区二区| 午夜精品久久99蜜桃的功能介绍| 午夜精品美女自拍福到在线| 国产精品久久久免费| 亚洲一区欧美一区| 欧美在线综合| 国内外成人免费激情在线视频网站| 欧美在线电影| 老司机67194精品线观看| 在线看成人片| 99精品国产热久久91蜜凸| 欧美区一区二区三区| aa级大片欧美三级| 午夜精品福利一区二区三区av| 国产精品一区二区男女羞羞无遮挡| 欧美一区二区三区久久精品茉莉花| 久久国产乱子精品免费女 | 最新日韩av| 欧美巨乳在线观看| 中文日韩在线| 久久国产精品久久国产精品| 在线成人h网| 一卡二卡3卡四卡高清精品视频| 欧美日韩不卡视频| 亚洲一区二区综合| 久久只精品国产| 亚洲精品美女久久7777777| 亚洲图片欧洲图片av| 国产精品免费看片| 久久av免费一区| 欧美巨乳波霸| 亚洲综合日韩| 免费在线观看日韩欧美| 亚洲美女精品一区| 欧美一区二区视频网站| 在线精品福利| 亚洲欧美激情精品一区二区| 国产亚洲精品高潮| 亚洲精品视频在线观看网站| 国产精品久久福利| 久久精品一本| 欧美午夜片在线免费观看| 欧美一区二区私人影院日本| 欧美激情第10页| 亚洲欧美久久久久一区二区三区| 久久三级视频| 99这里只有久久精品视频| 久久久久久黄| 99精品免费网| 久久综合一区| 99在线精品视频| 麻豆精品视频在线观看| 亚洲天堂网在线观看| 每日更新成人在线视频| 中文亚洲欧美| 免费在线国产精品| 亚洲男女自偷自拍图片另类| 欧美国产日韩视频| 亚洲欧美日韩一区在线观看| 欧美电影在线观看完整版| 亚洲欧美日韩国产一区| 欧美激情一区二区在线| 欧美一级午夜免费电影| 欧美视频三区在线播放| 亚洲国产成人久久| 国产精品网曝门| 亚洲麻豆一区| 国产中文一区二区三区| 亚洲一级二级| 亚洲国产精品成人一区二区 | 亚洲视频日本| 欧美电影免费观看大全| 性欧美1819性猛交| 国产精品激情电影| 9国产精品视频| 亚洲二区在线视频| 久久久久久久尹人综合网亚洲|