江南+王春枝+康瑞華
摘 要:針對計算機專業(yè)程序設(shè)計語言類課程體系設(shè)置單一、教學(xué)過程較為僵化、重技能而輕計算思維等問題,提出增加函數(shù)式編程語言課程、適當(dāng)調(diào)整課程內(nèi)容的講授次序、積極引導(dǎo)學(xué)生深入理解程序設(shè)計語言等措施。
關(guān)鍵詞:程序設(shè)計語言;課程體系;教學(xué)過程;計算思維
文章編號:1672-5913(2017)05-0042-03
中圖分類號:G642
1 程序設(shè)計語言類課程的教學(xué)現(xiàn)狀及問題
計算機學(xué)科知識結(jié)構(gòu)更新快,其中,程序設(shè)計語言在短短的幾十年間經(jīng)歷了較大變化。語言類課程是計算機學(xué)科的專業(yè)基礎(chǔ)課程,其學(xué)習(xí)效果直接影響其他后續(xù)課程。當(dāng)前語言類課程教學(xué)主要面臨以下問題。
1.1 課程體系設(shè)置單一
國內(nèi)高校計算機專業(yè)的程序設(shè)計語言類課程大多是過程式或者面向?qū)ο蟮拿钍骄幊陶Z言,課程體系設(shè)置單一。不可否認(rèn),這類語言無論是從學(xué)科性還是有用性上講,都是合適的。然而,程序設(shè)計語言不僅僅是這類命令式語言,它還包括如ML、Haskell這樣經(jīng)典的函數(shù)式編程語言,或者如兼顧面向?qū)ο蠛秃瘮?shù)式的Scala語言等。從某種意義上講,函數(shù)式編程能夠更大程度地鍛煉計算思維[1]。在多核并行程序設(shè)計已經(jīng)被推到前沿的今天,命令式編程語言天生的缺陷使得構(gòu)造并行編程模型變得非常復(fù)雜,而函數(shù)式編程在經(jīng)歷數(shù)十年的發(fā)展之后,終于不再局限于實驗室的理論研究。事實上,如果不懂得函數(shù)式編程,Google不可能創(chuàng)造出MapReduce。
1.2 教學(xué)過程僵化
程序設(shè)計語言類課程的傳統(tǒng)講授是按照編程語言類教材的典型撰寫次序,先講常量、變量、數(shù)據(jù)類型等,再講表達式、語句等,再比較復(fù)雜的語言特點,這些花費了較多時間,最后可能不再有多余的時間剖析該語言的內(nèi)建庫函數(shù)或者類,更少涉及該門課程與后續(xù)課程的銜接關(guān)系。這種傳統(tǒng)的講授方式針對第一門程序設(shè)計語言課程的教學(xué),特別對那些沒有接觸過編程語言的學(xué)生來講,可能是一種較好的方式[2]。然而,對于第二門程序設(shè)計語言的授課,按照這種按部就班的教學(xué)過程推進教學(xué)進度時,由于在較長一段教學(xué)活動中所講授的都是孤立的語法點,學(xué)生看不到一個較為完整的應(yīng)用實例,也不了解這門課程與其他課程之間的貫通,容易產(chǎn)生厭學(xué)的心理,也很難體會程序語言的設(shè)計藝術(shù)。
1.3 重編程技能,輕計算思維
針對程序設(shè)計語言類課程實踐性特別強的特點,許多教改措施都是針對如何提高學(xué)生的工程應(yīng)用實踐技能的[2-3],如采用案例化、任務(wù)驅(qū)動、項目驅(qū)動等方式。編程技術(shù)固然重要,然而計算思維比單純技術(shù)更加重要。培養(yǎng)學(xué)生以計算機的方式進行思考和解決問題,讓他們認(rèn)識到程序是思想的表現(xiàn)形式,最終能夠通過語言來表達思考與設(shè)計,并能理解這門語言設(shè)計和實現(xiàn)的長處、不足、限制等。為了達到這個目標(biāo),需要引導(dǎo)學(xué)生深入理解編程語言本身。
2 教學(xué)改革措施
2.1 增設(shè)函數(shù)式編程語言課程
函數(shù)式編程模型早在面向?qū)ο蟾拍畛霈F(xiàn)之前就已經(jīng)存在了,它的核心是lambda演算。由于其語法不如命令式語言的語法直觀易懂,許多初次接觸函數(shù)式編程的人常常不知所措,會覺得難以理解。然而,這種難以理解性與熟悉程度相關(guān)。近20年的課程改革中,因為種種原因,程序設(shè)計語言類課程體系幾乎完全拋棄了函數(shù)式程序設(shè)計語言。如今,多核時代的興起,函數(shù)式程序代碼的簡潔性使得它在并發(fā)應(yīng)用領(lǐng)域綻放光彩。雖然實用性是我們應(yīng)當(dāng)考慮的一個方面,但是從培養(yǎng)學(xué)生計算思維以及從編程語言本身的研究方面,增設(shè)函數(shù)式編程語言課程是很有必要的。
常用的函數(shù)式編程語言或者具備函數(shù)式編程語言特點的編程語言包括Haskell、ML、OCaml 、Scala等。依據(jù)需要可以選擇不同的函數(shù)式編程語言:如果傾向于編程語言本身的理解,可以選擇純函數(shù)式的ML、Haskell,或者OCaml;如果傾向于并行分布式程序的開發(fā),可以選擇結(jié)合了面向?qū)ο蠛秃瘮?shù)式特點的Scala語言,它兼容Java。此外,Java 8的lambda表達式也是一個不錯的學(xué)習(xí)函數(shù)式編程的選擇。
2.2 適當(dāng)調(diào)整講授內(nèi)容的次序
以Java程序設(shè)計語言的教學(xué)為例,按照常規(guī)教材的編寫次序,Java的教學(xué)內(nèi)容通常是先講變量、類型、表達式和語句,然后是數(shù)組,接著是類和對象、繼承等。在實踐中我們對講授內(nèi)容的次序進行了調(diào)整:在對Java語言作了初步介紹之后,緊接著講解對象的創(chuàng)建和使用,見表1。表1第2行的內(nèi)容不再放在講解了類的定義之后。這個調(diào)整出于兩方面的考慮:一方面,讓學(xué)生盡快建立對象的概念,知道怎么使用對象;另一方面,數(shù)組在Java程序設(shè)計語言中視為對象,因此,講解了如何使用對象之后有利于數(shù)組的講解。而類的定義涉及較多語法知識,在講解了如何使用對象、變量、類型、表達式和語句之后,引導(dǎo)學(xué)生考慮這個問題——我們能不能按照自己的設(shè)計來創(chuàng)建對象呢,于是開始講解類的定義,見表1第5行。
為了講解如何使用對象,首先選擇兩個常用的Java內(nèi)建類——字符串String和System,針對已經(jīng)學(xué)習(xí)了C語言程序設(shè)計的學(xué)生,從教學(xué)效果上看,盡管學(xué)生還沒有接觸到Java的各種語法規(guī)則,但是他們?nèi)匀唤邮芰恕皩ο蟆边@個知識點的講授。更重要的是,他們建立了對象的初步印象,了解了Java與C的不同,并在一定程度上激發(fā)了學(xué)生的學(xué)習(xí)興趣。
由于Java程序需要使用標(biāo)準(zhǔn)輸出流的方法System.out.print()用于輸出程序的運行結(jié)果,學(xué)生就問:Java程序怎么輸入呢?此時,對輸入輸出流進行較為完整的講解顯然不合適,在講解使用對象時,我們進一步講解如何使用Java的字符緩沖輸入流類BufferedReader,直接給出如下板書:
BufferedReader br = new BufferedReader(
//BufferedReader需要一個Reader類型的參數(shù)
//InputStreamReader就是一個Reader
new InputStreamReader(
//InputStreamReader需要一個InputStream類型的參//數(shù),System.in就是一個InputStream
System.in));// System.in用于接受鍵盤的輸入
br.readLine(); //BufferedReader的readLine
//方法讀入一行
以上這段代碼稍顯復(fù)雜,學(xué)生在課余可以仔細(xì)研究并進行試驗。實踐表明,這些Java常用內(nèi)建類的使用在教學(xué)初期給出時,不但沒有造成學(xué)生的困惑和畏懼,反而提升了學(xué)生的學(xué)習(xí)熱情。
2.3 引導(dǎo)學(xué)生深入理解程序設(shè)計語言
程序設(shè)計語言類課程對于培養(yǎng)學(xué)生的計算思維非常重要,需要學(xué)生深入理解程序設(shè)計語言本身的設(shè)計與實現(xiàn),而不僅僅是學(xué)習(xí)單純的語法。
通常學(xué)生因其視野的局限性和課時的限制,無法深入學(xué)習(xí)一門程序設(shè)計語言。教師在授課時應(yīng)該找機會引導(dǎo)學(xué)生去深入理解。通常,語言設(shè)計和實現(xiàn)者提供了API文檔和源碼,這些是深入理解一門編程語言最直接也是非常好的參考資料。如果學(xué)生能夠養(yǎng)成查看API的習(xí)慣,無疑能夠促進對語言的認(rèn)識和理解。以引用類型變量的講解為例,假設(shè)變量p引用的是一個Person類型的對象,變量s引用的是一個String字符串對象。System.out.print(p)輸出結(jié)果是代表對象地址的哈希碼,而System.out.print(s)輸出了一個字符串。這是為什么呢?同時,有學(xué)生就會提出疑問:System.out.print(p)是否可以直接輸出p所引用的Person對象的成員值,如姓名和年齡等,而System.out.print(s)是否可以輸出這個字符串對象的地址哈希值?在這個過程中,可以引導(dǎo)學(xué)生逐步查找對應(yīng)的API,如圖1所示。最后可以進一步查看Object類和String類對應(yīng)方法的實現(xiàn)源碼。知道了這個思路后,學(xué)生豁然開朗,開始著手解決問題。
在教學(xué)實踐中,我們常常鼓勵學(xué)生按照這種方法去找解決思路,而不是直接給出答案。得益于Java的開源,在Java程序設(shè)計語言的教學(xué)活動中,我們也鼓勵學(xué)生查看javac編譯器或者JVM的即時編譯器的實現(xiàn)源碼。學(xué)生通過這種學(xué)習(xí)方式,在長期使用一門程序設(shè)計語言后,最終能夠駕馭語言,表達類似計算機方式的思考與設(shè)計。
3 結(jié) 語
在兼顧學(xué)科性和社會有用性方面,我們一直致力于計算機專業(yè)程序設(shè)計語言類課程的教學(xué)改革。結(jié)合教學(xué)實踐以及對計算機專業(yè)程序設(shè)計語言類課程如何開展教學(xué)的長期思考,我們針對存在的問題,給出了相應(yīng)的解決辦法,并作了初步嘗試,取得了一定的效果。程序設(shè)計語言類課程的教學(xué)任重道遠(yuǎn),我們應(yīng)該投入熱情,積極摸索和實踐,總結(jié)經(jīng)驗教訓(xùn),使程序設(shè)計語言類課程體系更趨于合理,不斷提高教學(xué)質(zhì)量。
參考文獻:
[1] 車萬翔, 蘇小紅, 袁永峰, 等. 計算機專業(yè)高級語言程序設(shè)計課程改革探索[J]. 計算機教育, 2014(7): 56-58.
[2] 李東明, 趙偉. Java語言課程實踐教學(xué)實踐[J]. 計算機教育, 2011(13): 122-125.
[3] 魯紅英, 肖思和, 孫淑霞.“C/C++語言程序設(shè)計”課程教學(xué)改革與實踐[J]. 計算機教育, 2013(7): 95-98.
[4] Igoe T. Stop teaching programming, start teaching computational thinking [EB/OL]. [2016-04-05]. http://makezine.com/2016/04/05/stop-teaching-programming-start-teaching-computational-thought/.
(編輯:彭遠(yuǎn)紅)