Should First-Year Programming Students Be Taught With Python and Java? (huntnewsnu.com)
- Reference: 0175833737
- News link: https://developers.slashdot.org/story/25/01/05/1853210/should-first-year-programming-students-be-taught-with-python-and-java
- Source link: https://huntnewsnu.com/82511/editorial/op-eds/op-ed-northeasterns-redesign-of-the-khoury-curriculum-abandons-the-fundamentals-of-computer-science/
> In an Op-ed for
>> The Huntington News
> , fourth year Northeastern University CS student Derek Kaplan [2]argues that real pedagogical merit is what should count when deciding which language to use to teach CS fundamentals (aka 'Fundies'). He makes the case for Northeastern to reconsider its decision to move from [3]Racket to [4]Python and [5]Java later this year in an [6]overhaul of its first-year curriculum .
>
> "Students will get extensive training in Python, which is currently the most requested language by co-op employers," Northeastern explains (some two decades after a Slashdot commenter made the same [7]Hot Languages = Jobs observation in a spirited 2001 debate on [8]Java as a CS introductory language )...
>
> "I have often heard computer science students complain that Fundies 1 teaches Racket instead of a 'useful language' like Python," Kaplan writes. "But the point of Fundies is not to teach Racket — it is to teach program design skills that can be applied using any programming language. Racket is just the tool it uses to do so. A student who does well in Fundies will have no difficulty applying the same skills to Python or any other language. And with how fast the tech industry changes, is it really worth having a course that teaches just Python when tomorrow, some other language might dominate the industry? Our current curriculum focuses on timeless principles rather than fleeting trends."
>
> Also [9]expressing concerns about the selection of suitable languages for novice programming is King's College CS Prof Michael Kölling, who explains, "One of the drivers is the perceived usefulness of the language in a real-world context. Students (and their parents) often have opinions which language is 'better' to learn. In forming these opinions, the definition of 'better' can often be vague and driven by limited insight. One strong aspect commonly cited is the perceived usefulness of a language in the 'real world.' If a language is widely used in industry, it is more likely to be seen as a useful language to learn." Kölling's recommendation? "We need a new language for teaching novices at secondary school and introductory university level," Kölling concludes. "This language should be designed explicitly for teaching [...] Maintenance and adaptation of this language should be driven by pedagogical considerations, not by industry needs."
>
> While noble in intent, one suspects Kaplan and Kölling may be on a quixotic quest in a [10]money wins world, outgunned by the demands, resources, and influence of tech giants like Amazon — the [11]top employer of Northeastern MSCS program grads — who pushed back against [12]NSF advice to deemphasize Java in high school CS and [13]dropped $15 million to have [14]tech-backed nonprofit Code.org develop and push a new Java-based, powered-by-AWS CS curriculum into high schools with the support of a [15]consortium of politicians, educators, and tech companies . Echoing Northeastern, an [16]Amazon press release argued the new Java-based curriculum "best prepares students for the next step in their education and careers."
[1] https://www.slashdot.org/~theodp
[2] https://huntnewsnu.com/82511/editorial/op-eds/op-ed-northeasterns-redesign-of-the-khoury-curriculum-abandons-the-fundamentals-of-computer-science/
[3] https://en.wikipedia.org/wiki/Racket_(programming_language)
[4] https://en.wikipedia.org/wiki/Python_(programming_language)
[5] https://en.wikipedia.org/wiki/Java_(programming_language)
[6] https://www.khoury.northeastern.edu/qa-what-to-expect-from-khoury-colleges-upcoming-intro-course-changes/
[7] https://developers.slashdot.org/comments.pl?cid=153927&sid=12731&tid=116
[8] https://developers.slashdot.org/story/01/06/11/2021220/java-as-a-cs-introductory-language
[9] https://infedu.vu.lt/journal/INFEDU/article/797/info
[10] https://www.theringer.com/2019/09/09/tv/succession-tern-haven-roys-versus-pierces
[11] https://graduate.northeastern.edu/program/master-of-science-in-computer-science-boston-5238/
[12] https://www.umsl.edu/~sauterv/women/17comp.html
[13] https://developers.slashdot.org/story/21/02/25/2056233/amazon-gives-codeorg-15-million-to-reimagine-advanced-placement-csa
[14] https://code.org/about/supporters
[15] https://developers.slashdot.org/story/21/04/22/194236/tech-giants-support-codeorgs-amazon-bankrolled-java-based-ap-cs-curriculum
[16] https://press.aboutamazon.com/2021/2/amazon-donates-15-million-to-code-org-to-create-new-equity-minded-advanced-placement-computer-science-curriculum-to-help-high-school-students-in-underserved-communities-excel-in-tech
Variety of languages (Score:4, Insightful)
I rather wish intro programs would show a number of different languages and weight the pros and cons of each. Then students can get into learning specific languages after that.
I love python for my own programming, I can throw together prototypes much faster than other languages and even advanced programs work pretty well. I do not like how python can produce both simple scripts and classes, and does not enforce private variables. They say C/C++ are languages that give you rope to hang yourself with, and it is true that those languages can produce some horrible code with bad memory bugs, but I feel python can also produce some horrible and unreadable code if a developer does not have the discipline to write good code.
I'm glad I started with Java and was pushed heavy into proper class design and encapsulation. It has helped me to follow good design approaches and produce good maintainable code. However outside of college, I've never used Java. Most of my code has been in C/C++, Ada and Fortran, as well as now a lot of python.
I see benefits to all languages and understanding where one is good vs other languages.
Re: (Score:2)
"...it is true that those languages can produce some horrible code..."
Languages do not produce code. Any python cannot do what C/C++ can do, that's why Python has interfaces to C/C++.
"... I feel python can also produce some horrible and unreadable code if a developer does not have the discipline to write good code."
Python also does not produce code, and any developer that lacks "discipline" is likely to produce bad code in any language.
"...was pushed heavy into proper class design and encapsulation."
A stro
Re: (Score:2)
> Languages do not produce code.
Yes, and also no. One of the primary purposes of a programming language is to define not only the set of supported constructs that a programmer can easily express, but also the set of deliberately unsupported mechanisms that a programmer cannot easily express.
That sounds Orwellian (and perhaps it is) but the fact is that programmers want a language that makes it easy for them to write a useful program, and hard for them to write a useless program. So, for example, a language that makes it hard to write a
Re: (Score:2)
c++ templates begs to disagree
Re: (Score:3)
I rather wish intro programs would show a number of different languages and weight the pros and cons of each.
I agree with the first bit but disagree with the second. I think maybe two to three choices would be best. For example, python as a solid high level language, assembly language (such as a PIC micro controller) for low level and something more mathematical like Haskell.
The purpose isn't to weigh the pros and cons: you can only do that later when you can understand the pros and cons. The purpose I thi
Re:Variety of languages (Score:4, Insightful)
If the question is "which language should we teach our CS students" then you're doing it wrong. Learning multiple languages absolutely should be part of a decent CS degree, to the point where learning a new one isn't much of a hassle.
Re: Variety of languages (Score:2)
More importantly, the course should use whatever language is most appropriate to describe the topic at hand (data structures, object orientation, embedded and realtime systems, operating systems, whatever). Bonus points if the language is otherwise useless.
That said, this is more of a CS perspective than âoeprogrammingâ thing. The point of a good CS degree isis for the students to learn the concepts and understand the topic. Itâ(TM)s not to teach them to program.
I did Computer Engineering mys
Re: (Score:2)
Back in the day, no two courses in my Computer Engineering degree used the same programming language and platform. Assembly, C, C++, Fortran, Pascal, compilers (Yacc, Lex, Flex, Bison), embedded languages galore, Scheme, pretty much everything. We covered a ton of different computer architectures and programming concepts too.
The interesting bit was the response of the hiring managers. The strategy was that the chemical engineering grads were hired to do mainframe programming, because the chemical engine
Language should not matter (Score:3)
Fundamentals are more important than syntax. That being said, keeping it mainstream with an OO language like Java, C++, or C# .NET and a scripting language of choice probably gives the graduates the best opportunities for general placement.
Re:Language should not matter (Score:4, Insightful)
Totally agree. Who cares what language you use?
Unless we are hiring for C++, I've never worked for an employer who hired based on language. If you code mostly C#, we ask you C# questions. If you code mostly in Java, we ask you Java questions. If you've never looked at Python and we are using Python, smart programmers will be just fine. Total non-issue.
It would be really weird to hire someone who doesn't have a firm grasp on pointers... Even if we aren't using C/C++. That would be like hiring someone who doesn't understand the very basics of how a computer works.
Related note: Students should be required to demonstrate mastery of a functional programming language to graduate.
Re: (Score:1)
I don't know about that. Yes pointers is a number that refers to a memory location. I just got soured on programming after working at National Instruments. I saw a lot of fools in my humble opinion, who chewed me up and spit me out. I am a talented software, and hardware person, I think, but working for a corporation is difficult. People are assholes. Software is an art, I agree, but corporations are assholes, again, in my humble opinion.
Re: (Score:2)
It shouldn't matter, but the language should also not get in the way of learning fundamentals. In this case "Racket" (a LISP derivative) is pretty awkward to code in and the skills used in it aren't really applicable to the rest of the degree. It's mostly a functional language which is great for teaching functional programming but is also used for OO where it's really awkward compared to a language like Python or Java.
Also since it's a relatively obscure language used only for teaching, there aren't many
Prompt Engineers ... (Score:5, Insightful)
> Should First-Year Programming Students Be Taught With Python and Java?
The point of learning programming is to learn patterns and programming methods like OOP that are pretty independent from what language you are using. How to break a problem down into manageable chunks that make logical sense and result in code modules that can preferably be re-used in multiple places in your project. What programming language you used to do that is rather of secondary as far as I'm concerned. I've written software in a dozen different languages and the basics are usually the same. Not, that any of this matters anyway. I have it on good authority, from a number of unbounded AI company CEO geniuses, that all programmers will have been replaced by prompt engineers by 2030 who'll write complex software using AI in plain English so I think it would be a good idea for anybody studying to be a 'programmer' to instantly change his major to 'prompt engineering' with a second degree in English.
Re: (Score:2)
> How to break a problem down into manageable chunks that make logical sense and result in code modules that can preferably be re-used in multiple places in your project.
In fact, that process is a fundamental that should be taught regardless of whether the kid has or will ever write even a single line of code
Your very first exposure to programming doesn't need to involve coding at all. Basic project management is the real first course.
Divide and Conquer (Score:2)
Every complex effort ever, becomes manageable when one heeds this. Found in every endeavour, from Roman politics to optimisation and good software (and hardware) design
Re: (Score:1)
> I have it on good authority, from a number of unbounded AI company CEO geniuses
Keep delivering the hype and return almost nothing. Those "geniuses" can't turn off the VC money. Turn the AI hype machine up to 11!!!
Re: (Score:2)
I was taught software languages are like tools in the tool box. I agree what they really should start with is things like software patterns and object oriented vs functional, etc. Give a 10000 foot view and then work into the details. If you just jump into one language then that is how those folks will try and approach every problem. When all you have is a hammer, everything looks like a nail.
who is this "one" and why is he such an asshole? (Score:3)
"While noble in intent, one suspects Kaplan and Kölling may be on a quixotic quest in a money wins world..."
Sure, a "quixotic quest", educators should be criticized by capitalists for being concerned about how best to educate students.
Low-level first (Score:3)
Knowing low-level stuff first makes it much easier to understand high-level concepts otherwise everything turns into rote memorization and cargo-cult.
Start with C (without the oddities) and computer architecture. Throw in some assembly to bridge the understanding between comp arch and C.
Then learn higher level abstractions through an imperative and a functional language. A "computer languages" course helps to bridge the syntactic sugar/high-level abstractions with low-level C.
The rest is operating systems, networks, advanced algorithms and data structures.
Re: Low-level first (Score:1)
That describes my CS curriculum as was taught back in the 80â(TM)s. Programming language coursework was offered later.
Re: Low-level first (Score:2)
Dont forget your compiler, as well as EE classes.
Re: (Score:2)
What are EE students learning lately? It seems like AI stuff to me. That breaks my brain, I'm not sure if they know how a transistor works anymore.
Re: (Score:2)
Ideally, yes. I designed my own Z80 computer, built it with a friend, and put an OS on it in the 80's that I wrote. Man, other people seem stupid to me. They do stupid things. Asking most people to be smart seems like a fools errand to me.
Re: (Score:2)
...which low level stuff though?
I suspect what you mean is how things may be (and probably are) accomplished on an abstract memory machine (regular old ansi C)
importantly the necessary ramifications of any other languages abstractions are revealed when you try to enforce the same thing within just a memory machine context ,, you can do OOP in C (you can even do OOP in assembly) and by doing so you see in what ways it could be implemented, and when you look deeper at other languages you see that yes, the
Re: (Score:2)
C always looked like assembly language to me. OOP is not that, I think.
Yes (Score:2)
This way they can all experience [1]this type of joy [imgur.com].
[1] https://i.imgur.com/X7dOc9S.jpeg
It doesn't matter (Score:2)
Beginners can start with any language
After becoming familiar with it, a proper education should include multiple languages
C and assembler to get insight into how stuff really works
Python, Java, C++ and Javascript, because they are widely used
lisp, smalltalk, haskell, etc to see some variety
Learning programming is a lot more than learning one language. A competent programmer should be able to learn languages as needed by the project
Re: (Score:2)
I would argue that the very first things students should be touching is shader coding within a prearranged environment such as shadertoy.
Write a program to color a pixel.
The color should be White if.....
Variety is good (Score:3)
Most introductory languages start with "Hello World" (printing to the screen), then move on to simple variables and arithmetic, then slowly gets more specialized with more algorithms and API usage. The language isn't really that important, it's the program flow that is cross language that people need to learn, which gets more abstract and the individual languages are just syntactic sugar. The compiler/interpreter still does the heavy lifting.
Re: (Score:2)
I still like LabVIEW. It is an expensive space to get into, used to be. I guess it can be got for free now for individuals. I can see how it compiles into C, and then into Assembly. It is abstract, and brilliant, I think. I have a personal grudge against National Instruments, and they sold themselves to Emerson Electronics recently, I guess, but it is what it is. It is a graphical language that has no "gotos", it is about data flow that EEs can easily understand. It is brilliant in my humble opi
For Whom? (Score:2)
The answer is different depending on career track.
I can point to ways most of the popular languages suck for teaching.
If it's a social sciences student just teach them R.
Maybe CSE should start with assembly.
Consistency (Score:2)
Not all institutions have the same initial programming pathway, but it seems like a lot of US institutions (according to a CS professor friend of mine) do three foundational courses: CS 0 (Introduction to Programming), CS 1 (Object-Oriented Programming), and CS 2 (Data Structures). CS 0 is often a general education course designed for non-majors that majors with HS experience skip over. That one can be taught in any language and probably Python makes the most sense. I do think it is helpful if CS 1 and C
Different career paths (Score:2)
Learning an immediately employable language like python makes sense for some career choices. Learning more programming theory and fundamentals, then moving on to more specialized types of developing is a different career path. Both should be available.
Here is a revolutionary concept ⦠(Score:1)
Teach Software Engineering, not Computer Science.
Most graduates will end up working as âoesoftware engineersâ not scientists.
Managing teams, projects, risks is more useful than the math behind sorting algorithmsâ¦
No, absolutely not. (Score:4, Interesting)
First year CS should be about understanding algorithms, logic, and correctness. As such, I'd say SPARK (the Ada derivative that allows you to prove that the code in each function has certain properties).
Getting programs right, at the start, is far more important than learning a popular language. Languages change, but the need to be right does not.
No (Score:3)
The object oriented nature of Java teaches an extraoridinary of dangerously bad habits in what has become a deprecated language.
Re: (Score:2)
Java is still the top language used by companies. Even if it sucks there's a large market for developers in it.
I would say the functional programming of Racket hits the other extreme while being less useful
Not sure it matters which (Score:3)
My first language was RATFOR in college. The course was more about algorithms and logic and structure. It could have been any structured language. I've used the language precisely 0 times since the class. Others have mentioned using diversity of languages as a first course. While I agree that is an important course, I don't think a good first course. I think it was maybe my 3rd or 4th. That course was more about how languages differ focusing on things like call by value vs call by reference and how it might trip you up if you did not understand it. The course also clustered languages into categories like algol based, lisp based, etc. One language covered in the course was snobol, another language I've never used again, but awk/sed/grep have some similarities so learning snobol had value. I think that kind of course requires the fundamentals of a good algol like language foundation though.
Oddly, C, which I've used for literally millions of lines of code at this point in my life was one of the last languages I learned. It was taught by the EE dept, which is my major. Back then, code was just starting to really be a part of the EE curriculum, almost all my programming classes came from the CS dept.
Today's college incoming class may have already had the structured language class in HS, and so maybe college now needs to take more of tiered approach to the first class and have a class for newbies and a different class for the more advanced kid. I took a fortran class in HS, and that in part was the reason I was allowed to even take a CS class freshman year. I also had advanced chem/math in HS so was taking 2nd year math, which was somewhat common and 2nd semester chem, which was less common. Both were tiers determined by tests done by the uni.
Who is still entering first year programming? (Score:2)
Seems like the industry changes mean we'll have a glut of experienced people for decades. A new grad hoping to enter the market is likely a fool.
Python = cool things faster (Score:1)
Python lets them make some cool and pretty complex stuff ( web servers, GUIs, DB access ) quickly.
Java takes more work to implement those things and needs much more boilerplate typing.
eh, why not LabVIEW? (Score:2)
It is a language based on graphics, mostly mouse clicks. No typing involved. I think anybody can download and try it from the National Instruments website. It is very powerful. I think anything you can do in C or assembly, you can do in LabVIEW. I enjoy programming with it, it does provide quick results.
Racket because the quality of the texbooks (Score:3)
The best first book on programing is [1]https://htdp.org/ [htdp.org] Its "sequel" is Structure and Interpretation of Computer Programs which is in Scheme from which Racket was derived. Other languages simply don't have educational material that good.
[1] https://htdp.org/
Don't teach Esperanto before real foreign language (Score:3)
There are only so many hours in an undergrad education. Time spent learning the syntax of a language used only in education is time *not* spent getting familiar with a language with real-world value. It'd be like saying, "Before we teach you German or Chinese or French, first we're going to spend a year introducing concepts of language in Esperanto. Which you will never use after this course."
I'd rather hire someone with 3 years of Python or Java experience than someone with a year of Racket and 2 years of Python or Java.
If there's an area where one real-world language is weak, that's a great opportunity to introduce a second real-world language which is better at that aspect. (So, if you start in Python and want to teach strongly-typed interfaces, introduce Java. Or Rust.)
python is already designed for this (Score:2)
I agree that CS students should be exposed to different languages. For a true introductory class where the student are not expected to have programmed before you want a language that minimizes boiler plate and which is easy to read and understand.
Python was designed for this purpose by Guido and works well in this context. It has the additional advantage of a good standard library and broad ecosystem so that it is fun and rewarding for newbies. It is easy to introduce different paradigms and data structures
Personal Perspective (Score:2)
Personally, I would have loved to have learned Python first. As far as I'm concerned, get me up and running as fast as possible, being able to do something useful and I'd be excited to expand on that on my own.
Back in high school the first language we learned was Pascal.
As soon as we learned basic loops and text printing I started figuring out how to add color to the text and making UIs for programs that solved problems outside of the class.
We only learned Assembly after we already knew how to implement ele
Re: (Score:2)
LabVIEW man. just saying. Check it out. It is a "brain buster", I know.. to just use a mouse and graphics to write software. I think it is super cool.
Churn 'em out, burn 'em up (Score:2)
More grist for the mill! That seems to be the philosophy of industry. They don't want to spend anything training anyone because that expertise can be (and often is) poached.
AI is going to undercut all entry level jobs (particularly in coding but not limited to) and cause a severe seed corn problem soon enough. Once the skill gap is allowed to open up because AI is "good enough", you cut off almost all of the flow of new minds into the field and within half a decade the AI becomes indispensable to the proces
Re: (Score:2)
Is this a horse vs car problem? or a permanent social problem where most people will never be able to get good employment any more? In your opinion?
Re: (Score:2)
Seems like you are advocating for liberal arts. we come full circle I guess. I agree with you, and not trying to troll you... I'm just talking out loud.
Let's compare with other fields (Score:2)
You want to be a car mechanic but instead of using car engines in the classes they use engines from oil rigs or some other shit. Sure, the basics should be the same and the experience somewhat valuable but I would consider that a monumental waste of time. Unless you convince me that Racket is much better than Python for that task.
Re: (Score:2)
sorry op, but your words look like a salad to me. would you try to be more precise? make a point?
Python is Peaking (Score:2)
Yes, my subject line is clickbait. But, hear me out.
After a massive surge, Python is peaking. The next great thing is soon at hand. So, they are late to the party in changing their language.
YES! They should have dropped Racket forever ago. Who uses that shit? I'd never even heard of it before this article. It's as useless or more than Roblox or Scratch or whatever the children are using now.
The university should be more current in its teachings. Python is great today, but could be "legacy" next year. It als
Betteridge (Score:2)
I can't be the first to mention Betteridge on this thread?
Python: Yes. Java: No. (Score:2)
Java is something that is slowly on its way out.
But for Python, make sure to also teach C and teach embedding (both ways). That would be a topic for the second half of the course. Do not coddle CS students by not teaching them how things work on the low level. That would be a bad mistake.
What's the point? (Score:2)
I'd agree with industry but there doesn't seem to be any reason to teach any language if these companies will only hire foreign students/H1B workers.
We should sanction them into oblivion and fund let experienced American talent [including last weeks H1Bs] build America first alternatives that blow them out of the water. As a bonus they can pick up gear at the former tech company bankruptcy fire sales.
Why not Javascript? (Score:2)
I'm only half-serious here, but if you're going to choose a language based solely on popularity/wide use, why not? There are about as many JavaScript jobs as there are Python (meh) or Java (ick) jobs. Indeed.com currently has 17,000+ results for "Java developer", 18,000+ results for "Python developer", and 16,000+ for "Javascript developer"
I'm not disputing that JS has a ton of crap in it, but sticking to "the good parts" should be doable. Plus JS has some other advantages: closures, first-class functions a
BASIC (Score:2)
I mean, why not? The point isn't teaching the language of the week.
Re:BASIC (Score:5, Insightful)
Which is why they should first be taught in C. Fundamentals is important.
Re:BASIC (Score:5, Insightful)
They should be taught how to solve hard problems, and exercise those skills a lot in their assignments.
If they are taught this, the language doesn't matter at all. If they are not taught this, the language doesn't matter at all.
But teaching this scares a lot of students away, and colleges have a direct financial incentive to avoid scaring students away.
Re: (Score:2)
C is advanced, in my humble opinion. As an old programmer, I see how C is adapted to machine language, I can almost see in my mind how it will be converted to machine language. BASIC is a language that is adapted to human type thinking.
Re: (Score:2)
> BASIC is a language that is adapted to human type thinking.
BASIC was invented to be something like COBOL for college students - easy enough for non-coders to code something useful. Humans adapt to programming languages, not the other way 'round (with a few exceptions like Lisp, where the language can change to become the program). I don't think BASIC is any closer to "human type thinking" than COBOL is and I wish I'd never learned either of them.
Anything interpreted is good so that early students don't have to think about compiling and linking. Anything with a REPL
Re: (Score:3)
Fundamentals are important. First they should learn formal logic, algorithms, take a some other decent math courses, and about transistors. Then they can build a gate, then an ALU, a processor, and finally a computer. At the same time they can be learning assembly so when they've built their computer they can write an assembler for it, and a compiled language so they can write a compiler. An interpreted language is a good idea too, preferably one that works well with the compiled language.
Re: (Score:2)
> Which is why they should first be taught in C. Fundamentals is important.
One of the most fundamental things they should be taught is that due to advancements in language design over the last 50 years, as well as ever-increasing threat environments, C is no longer suitable for use in production environments.
Re: BASIC (Score:2)
Or they could just make it suitable again by teaching them about pitfalls in memory management.
Re: (Score:2)
They should be taught Haskell. Fundamentals is important.
Re: (Score:2)
Because Basic is a hack, it is not designed to teach students skills.
There are languages specifically designed for teaching.
Re: (Score:2)
Yes BASIC is a hack, and it is an acronym. Never spell it "Basic", it is not that.
Re: (Score:2)
BASIC was designed to teach everything. The "All-Purpose" part of its very name. The problem is that "purpose" back then meant interaction with connected hardware, not coexisting within software or user ecosystems. Those things didnt exists yet.
peek and poke, in and out, IOCTL....
In modern times, no language, not even assembly, is a simple tool for manipulating the hardware. The legendary EGA/VGA Programmers Reference is neigh on useless under any modern operating system (master control program), nor co
Re:BASIC (Score:5, Interesting)
> I mean, why not? The point isn't teaching the language of the week.
BASIC lacks fundamental constructs (such as closures, anonymous functions, higher-order functions, and most versions don't have objects or even structs, among other things). In that respect, Python is a much better choice.
Racket is arguably better than Python for similar reasons. It is descended from Scheme (a Lisp) that was the gold standard for teaching computer science for several decades. A programmer who learns using Racket should have no problem becoming professionally fluent in Python within a couple of weeks. In general, someone with this kind of background in the fundamentals will have no problem learning *any* programming language extremely quickly, as they will be familiar with all the concepts.
Students in many fields need to be able to do a little programming. And they should definitely learn Python, because it is so popular. There should be three courses available:
(1) Intro to practical and simple programming for non-programmers, using Python.
(2) Getting the most out of Python (follow-on to the above), for STEM non-programmers.
(3) Professional Programming for computer science students. This would be engineering exercises, in the vein of comparative languages, after completing the Racket courses. It assumes they have already done the non-programmer Python courses, too. It would cover Python, Java and C#, Javascript, C and Rust, and a type-based language like OCaml or something. Probably two semesters in which you learn the adaptation of the core concepts you learned with Racket, the syntax, and something of the libraries. This allows you to hit the ground running. But is all based on what you learned with Racket.
As has been emphasized many times: the point of learning with Racket is not that you are learning Racket. It's that it is a clean platform on which to learn fundamental concepts and algorithms. And how to think about thinking about programming. Computer "science" is not the same as "programming in some language so you can get a job".
Re: (Score:2)
I know BASIC through and through. I dipped my toes in Python, and I find it similar, however with much greater capabilities... it seems to me. I would endorse Python as a beginners software language. As for C though, people have to know what integers are, bytes, for loops, memory spaces. That can come later.
Re: (Score:2)
GOTO... I kind of find it funny now, but back in the day it made sense to me. It takes time.
Re: (Score:2)
> GOTO... I kind of find it funny now, but back in the day it made sense to me. It takes time.
So you're saying BASIC was your GOTO language?
Re: (Score:2)
I have this vain, stupid habit of posting on other social media sites, and I know this is not like them. I am just saying that I wish that I could post a giggling emoji in response to you.
Re:BASIC (Score:4, Insightful)
> The point isn't teaching the language of the week.
While I agree - why not teach them the fundamentals using a language that's currently in widespread use? Seems like it'd be a more useful approach for both the short- and longer-term.
Re: (Score:2)
Seems to me that AI will replace a lot of programmers anyway. I find it a very useful tool. I describe in English what I want done, and it gives me the code. My only "additive" skill right now is to find the little bug inside what it gives me.
Re: (Score:2)
Because they suck!
Also CS isn't "programming" so you don't even have to teach any language in year 1.
Pseudo-assembler for the first month (Score:2)
Teach pseudo-assembler for the first month. For this purpose MIXX would work well, though I started on 7094 assembler. After they learn the real basics, switch to either C or Python, depending on whether you're trying to teach engineers or mathematicians/chemists/physicists/etc. If you're trying to teach programmers, follow the assembler with a month of C, then a month of Python, then a month of Erlang, then perhaps a month of Forth. (I don't think LISP/Scheme is reasonable anymore, and C++ is too comp