Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
skip to main content
10.1145/3631802.3631812acmotherconferencesArticle/Chapter ViewAbstractPublication Pageskoli-callingConference Proceedingsconference-collections
short-paper

Some thoughts on teaching introductory programming and the first language dilemma (Discussion Paper)

Published: 06 February 2024 Publication History

Abstract

There is a consensus among computer education experts and practitioners that teaching introductory programming is intrinsically hard. In particular, the choice of the first programming language to support learning the fundamentals of problem solving and algorithmic reasoning is a hot issue that is driving a lot of attention within the last few decades. As a side effect, the computing education community has been long divided between supporters of industrial relevance and advocates of educational benefits as the prominent grounds on which a first programming language should be elected. While the former seem to have the wind in their sails, with popular-in-industry languages such as Java, C and C++ being still widely used to teach introductory programming, the case is far from being closed. In this paper, we propose to analyze the first language choice dilemma in the light of a number of rigorous studies carried out within and outside of the computing education community. We show that, in the light of these studies, we can efficiently question our choices as educators and stimulate objective discussions toward reconciling our views regarding the first language choice. Mainly, we devise a number of criteria, all backed up with scientific findings from different communities, according to which a first language should be evaluated. Our conclusions converge toward a justified concern vis-à-vis the use of languages such as Java and C to teach introductory programming, and the pressing need for a better compromise between industrial popularity and educational advantages. To meet that need, our position gravitates around two major opinions stemming from our cross-disciplinary analysis: (i) Java, C and C++ should not be used to teach introductory programming and should rather be saved for more advanced programming courses and (ii) while the recent trend of choosing Python is justified, it is still debatable and therefore other candidates, among which we propose a couple, should also be seriously considered. Besides arguing in favor of these opinions, the primary aim of our analysis is to trigger fruitful discussions on the subject fuelled by cross-disciplinary research findings rather than personal opinions.

References

[1]
2018. Assessing and responding to the growth of computer science undergraduate enrollments. National Academies Press.
[2]
Wolfgang Ahrendt, Thomas Baar, Bernhard Beckert, Richard Bubel, Martin Giese, Reiner Hähnle, 2005. The key tool. Software & Systems Modeling 4, 1 (2005), 32–54.
[3]
Amjad Altadmri and Neil CC Brown. 2015. 37 million compilations: Investigating novice programming mistakes in large-scale student data. In SIGCSE Technical Symposium. 522–527.
[4]
Miguel Muñoz Arancón, Malte Wirkus, Killian Hoeflinger, Nikolaos Tsiogkas, Saddek Bensalem, Olli Rantanen, Daniel Silveira, 2019. ESROCOS: Development and Validation of a Space Robotics Framework. In Symposium on Advanced Space Technologies in Robotics and Automation (ASTRA).
[5]
Nikolaos Avouris. 2018. Introduction to computing: a survey of courses in Greek higher education institutions. In Pan-Hellenic Conference on Informatics. 64–69.
[6]
John Gilbert Presslie Barnes. 2003. High integrity software: the SPARK approach to safety and security. Pearson Education.
[7]
Brett A Becker. 2019. A survey of introductory programming courses in Ireland. In Annual Conference on Innovation and Technology in Computer Science Education (ITiCSE). 58–64.
[8]
Jens Bennedsen and Michael E Caspersen. 2019. Failure rates in introductory programming: 12 years later. ACM Inroads 10, 2 (2019), 30–36.
[9]
László Böszörményi. 1998. Why Java is not my favorite first-course language. Software-Concepts & Tools 19, 3 (1998), 141–145.
[10]
Susan S Brilliant and Timothy R Wiseman. 1996. The first programming paradigm and language dilemma. In SIGCSE technical symposium on Computer science education. 338–342.
[11]
Neil CC Brown and Greg Wilson. 2018. Ten quick tips for teaching programming. PLoS computational biology 14, 4 (2018), e1006023.
[12]
Shyamal Suhana Chandra and Kailash Chandra. 2005. A comparison of Java and C#. Journal of Computing Sciences in Colleges 20, 3 (2005), 238–254.
[13]
Michael Clancy. 2004. Misconceptions and attitudes that interfere with learning to program. Computer science education research (2004), 85–100.
[14]
Stephen Davies, Jennifer A Polack-Wahl, and Karen Anewalt. 2011. A snapshot of current practices in teaching the introductory programming sequence. In SIGCSE Technical Symposium. ACM, 625–630.
[15]
Michael De Raadt, Richard Watson, and Mark Toleman. 2003. Language tug-of-war: industry demand and academic choice. In Australasian Computing Education Conference. Australian Computer Society Inc., 137–142.
[16]
Roger Duke, Eric Salzman, Jay Burmeister, Josiah Poon, and Leesa Murray. 2000. Teaching programming to beginners - choosing the language is just the first step. In Australasian conference on Computing education. ACM, 79–86.
[17]
Marco Eilers and Peter Müller. 2018. Nagini: a static verifier for Python. In International Conference on Computer Aided Verification (CAV). Springer, 596–603.
[18]
Thomas S Frank and James F Smith. 1990. Ada as a CS1-CS2 language. ACM SIGCSE Bulletin 22, 2 (1990), 47–51.
[19]
Linda Weiser Friedman. 1992. From Babbage to Babel and beyond: A brief history of programming languages. Computer Languages 17, 1 (1992), 1–17.
[20]
Anabela Gomes and António José Mendes. 2007. Learning to program - difficulties and solutions. In International Conference on Engineering Education (ICEE).
[21]
Matthew Hertz. 2010. What do “CS1” and “CS2” mean? Investigating differences in the early courses. In SIGCSE Technical Symposium. 199–203.
[22]
Tony Jenkins. 2001. The motivation of students of programming. Master’s Thesis.
[23]
Tony Jenkins. 2002. On the difficulty of learning to program. In Ann. Conf. of LTSN Centre for Inf. and Comp. Sc., Vol. 4. Citeseer, 53–58.
[24]
Tony Jenkins. 2004. The first language - a case for Python?Innovation in Teaching and Learning in Information and Computer Sciences 3 (2004), 1–9. Issue 2.
[25]
Theodora Koulouri, Stanislao Lauria, and Robert D Macredie. 2014. Teaching introductory programming: A quantitative evaluation of different approaches. ACM Transactions on Computing Education 14, 4 (2014), 1–28.
[26]
Scott Leutenegger and Jeffrey Edgington. 2007. A games first approach to teaching introductory programming. In SiGCSE Bull., Vol. 39. 115–118.
[27]
Kenneth Magel. 2017. Revisiting the Impact of the Ada Programming Language. Computer 50, 9 (2017), 10–11.
[28]
Linda Mannila and Michael de Raadt. 2006. An objective comparison of languages for teaching introductory programming. In Koli Calling International Conference on Computing Education Research (Koli Calling). 32–37.
[29]
Raina Mason, Graham Cooper, and Michael de Raadt. 2012. Trends in introductory programming courses in Australian universities: languages, environments and pedagogy. In Australasian Computing Education Conference. 33–42.
[30]
Raina Mason, Tom Crick, James H Davenport, and Ellen Murphy. 2018. Language choice in introductory programming courses at Australasian and UK universities. In SIGCSE Technical Symposium. 852–857.
[31]
Linda McIver and Damian Conway. 1996. Seven deadly sins of introductory programming language design. In International Conference on Software Engineering - Software Engineering in Practice (ICSE-SEIP). IEEE, 309–316.
[32]
Bertrand Meyer. 2003. The outside-in method of teaching introductory programming. In International Andrei Ershov Memorial Conference on Perspectives of System Informatics. Springer, 66–78.
[33]
Iain Milne and Glenn Rowe. 2002. Difficulties in learning and teaching programming. Education and Information technologies 7, 1 (2002), 55–66.
[34]
IT Chan Mow. 2008. Issues and difficulties in teaching novice computer programming. In Innovative techniques in instruction technology, e-learning, e-assessment, and education. Springer, 199–204.
[35]
Jorge Ocón, Iulia Dragomir, Andrew Coles, A Green, L Kunze, R Marc, CJ Perez, 2020. ADE: Autonomous DEcision making in very long traverses. In International Symposium on Artificial Intelligence, Robotics and Automation in Space (i-SAIRAS). Lunar and Planetary Institute.
[36]
Victor Oliveira, Leopoldo Teixeira, and Felipe Ebert. 2020. On the adoption of kotlin on android development: A triangulation study. In International Conference on Software Analysis, Evolution and Reengineering (SANER). IEEE, 206–216.
[37]
Arnold Pears, Stephen Seidman, Lauri Malmi, Linda Mannila, Elizabeth Adams, Jens Bennedsen, Marie Devlin, and James Paterson. 2007. A survey of literature on the teaching of introductory programming. Working group reports on ITiCSE on Innovation and technology in computer science education (2007), 204–223.
[38]
Maxime Perrotin, Eric Conquet, Julien Delange, AndrÚ Schiele, and Thanassis Tsiodras. 2011. TASTE: A real-time software engineering tool-chain overview, status, and future. In International SDL Forum. Springer, 26–37.
[39]
Yizhou Qian and James Lehman. 2017. Students’ misconceptions and other difficulties in introductory programming: A literature review. ACM Transactions on Computing Education 18, 1 (2017), 1–24.
[40]
R Rahul, Ashwin Whitchurch, and Madhav Rao. 2014. An open source graphical robot programming environment in introductory programming curriculum for undergraduates. In International Conference on MOOC, Innovation and Technology in Education (MITE). IEEE, 96–100.
[41]
Anthony Robins, Janet Rountree, and Nathan Rountree. 2003. Learning and teaching programming: A review and discussion. Computer science education 13, 2 (2003), 137–172.
[42]
Sónia Rolland Sobral. 2021. The old question: which programming language should we choose to teach to program?. In International Conference on Advances in Digital Science. Springer, 351–364.
[43]
Andreas Stefik and Susanna Siebert. 2013. An empirical investigation into programming language syntax. ACM Trans. on Comp. Ed. 13, 4 (2013), 1–40.
[44]
Christopher Watson and Frederick WB Li. 2014. Failure rates in introductory programming revisited. In Annual Conference on Innovation and Technology in Computer Science Education (ITiCSE). 39–44.
[45]
Leon E Winslow and Joseph E Lang. 1989. Ada in CS1. In SIGCSE Technical Symposium. 209–212.

Index Terms

  1. Some thoughts on teaching introductory programming and the first language dilemma (Discussion Paper)

      Recommendations

      Comments

      Information & Contributors

      Information

      Published In

      cover image ACM Other conferences
      Koli Calling '23: Proceedings of the 23rd Koli Calling International Conference on Computing Education Research
      November 2023
      361 pages
      ISBN:9798400716539
      DOI:10.1145/3631802
      Permission to make digital or hard copies of all or part of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation on the first page. Copyrights for components of this work owned by others than the author(s) must be honored. Abstracting with credit is permitted. To copy otherwise, or republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. Request permissions from [email protected].

      Publisher

      Association for Computing Machinery

      New York, NY, United States

      Publication History

      Published: 06 February 2024

      Permissions

      Request permissions for this article.

      Check for updates

      Author Tags

      1. CS1 & CS2
      2. first programming language
      3. introductory programming

      Qualifiers

      • Short-paper
      • Research
      • Refereed limited

      Conference

      Koli Calling '23

      Acceptance Rates

      Overall Acceptance Rate 80 of 182 submissions, 44%

      Contributors

      Other Metrics

      Bibliometrics & Citations

      Bibliometrics

      Article Metrics

      • 0
        Total Citations
      • 59
        Total Downloads
      • Downloads (Last 12 months)59
      • Downloads (Last 6 weeks)6
      Reflects downloads up to 01 Jan 2025

      Other Metrics

      Citations

      View Options

      Login options

      View options

      PDF

      View or Download as a PDF file.

      PDF

      eReader

      View online with eReader.

      eReader

      HTML Format

      View this article in HTML Format.

      HTML Format

      Media

      Figures

      Other

      Tables

      Share

      Share

      Share this Publication link

      Share on social media