Should I teach students who doesn't know computer science C or JavaScript first?
from ghodawalaaman@programming.dev to programming@programming.dev on 24 Mar 06:48
https://programming.dev/post/47695080
from ghodawalaaman@programming.dev to programming@programming.dev on 24 Mar 06:48
https://programming.dev/post/47695080
Hello,
I am thinking about teaching my students JavaScript first so that they can start creating websites and make their career, what are your thoughts?
#programming
threaded - newest
Dont teach anyone javascript. periodt
@dadarobot @ghodawalaaman TypeScript is way more powerful than JavaScript. I recommend learning TypeScirpt, Kotlin, Python, C# and Java but not Rust
Sounds like you just listed your favorite languages. Why not Rust?
Typescript literally is JavaScript. Therefore it is not possible to be “way more powerful” than JavaScript.
Why not python? C needs constant memory management and JavaScript is too chaotic. Both seem to me a bit too complicated for someone just starting
The main reason to not including python is that students aren’t particularly in the CS field, they are learning it as their “augmented skill” (I don’t know what it’s called bad English). That’s why I don’t want to force them to learn CS concept which they might not even need.
I was thinking about C so that their fundamentals gets cleared but I think it will be too much for students who aren’t into CS. What do you think ?
@ghodawalaaman @greenashura C# can be challenging for new coders and junior devs C# is very like Java but many game companies prefer C#
If they’re not in the CS field, and you don’t want to teach them CS concepts that they don’t need, then you have eliminated C as an option by your own criteria.
With C, they’ll have to learn about compilers, build systems, memory management, and pointers at the very least.
Python allows you to focus on a single concept in isolation (building on what you’ve already learned, of course). JS has a bunch of other stuff mixed in. Like the DOM. Interacting with the DOM is necessary for any browser code. You can hide it with abstractions and boilerplate, but it’s always going to surface in error messages. Debugging JS can be quite a bit harder than other languages.
Caveat: beginner JS is many years behind me. It may not be as bad as corporate code full of react and angular and all kinds of requirements.
That’s an even better reason to pick Python, then.
Idk why you are discarding python for the reason that makes python the best option. If there is a programming language that a non-programmer should know, it’s python.
If you also plan on teaching html and css, than I’d go for js first. Having your code instantly response in a visual way, is super motivating for most students.
If you just want to tech programming concepts, i’d go for python.
If you want this to be the start of a complete cs study, than you can start with C
That makes sense, I am also teaching html amd css first so I think JavaScript makes sense to teach next.
I was thinking about C because that’s the first thing I learned in the college and that’s my favorite language till this day.
The problem with C as a language for learning is that the error messages are not very specific or descriptive and often you need extra context to understand what is happening. Messing up memory management can result in inconsistent gremlin-like behavior from your programs, it can get very tricky. I had a pretty difficult time when I got to classes that taught C compared to other languages, but the main thing was just that I needed someone to look over my work and explain things to me because unlike with other languages, the self-service ways of figuring it out were much more difficult and it’s easier to get stuck with no idea what to look into next. I ended up begging people online for help with understanding what was going wrong with my programs to supplement the limited amount of time the professor and TAs were available, really grateful to those guys as I probably would have failed it otherwise.
Anyway I would just say that if you do really want to go with C, I think you should be willing to put in more time to explain things to students one on one because many of them may need it.
Good call. At this point the jankyness of js doesn’t pose a problem and the ones that get enticed will learn about type safety, classes etc down the line.
If you teach them C, they will then be able to digest JS in an afternoon…
I would say C first. You need to learn the fundamentals:
Many devs don’t know it and they are honestly just clueless about anything they are doing. They just want to make it work.
JavaScript is just too high level, and makes you think you are immune to these low level concepts, but you are not.
And not only that, but also good practices, like:
Ah, thanks for reminding me about git. I almost forgot that it’s also a thing which new comers struggle with.
I wouldn’t say that pointers and memory allocation is a good thing to start with. I teach programming to students with no prior experience, and sometimes it’s hard to even get them to grasp basic programming in Python. At least in the beginning. You have to start slow.
I’ve been working as a software engineer for years and not once have those “fundamentals” been relevant to the work I do.
If I question their usefulness then I don’t think it’ll sit well with no experience at all.
If you’ve been working as a software engineer for years and things like error handling and data structures (let alone git and testing!) are not relevant to you, I fear for your employer’s codebase.
Hah! You picked the two of
yourthat list that I actually do care about.I don’t know what pointers are. I don’t care about memory allocation. Recursion rarely comes up.
That’s not the kind of codebase I work with. I guess I’m not a proper big-boy programmer 😢
Anyway, your snide remarks about my abilities aside, that doesn’t address my point at all.
First of all, it’s not my list. Check the usernames of the comments you’re replying to.
Second, you didn’t make any sort of distinction limiting which ones you were talking about before, which means that you expressed that none of them were relevant. You don’t get to move the goalposts and then pretend it doesn’t address your point because of that.
Third, that sloppiness and failure to pay attention is only reinforcing my initial impression.
Calling me out on a clarification when you’re banging on with ad hominem rubbish?
Respond to the point or bugger off. I’m not here to impress you, you’re not my dad.
A good engineer knows when the details matter and when it’s just wasting everyone’s time. Would you classify responding to someone being needlessly hostile as something other than a waste of time?
If anything you should be criticising me for choosing to spaff more time on this conversation.
You weren’t “clarifying;” you were backtracking and lying about it. That’s a detail that matters.
I did respond to the point, in my initial comment. Your lack of reading comprehension (and dishonesty!) is your own problem, not mine.
Your continuing inability to engage in an even remotely constructive way is really tragic.
Instead of seeing my response as “He takes my point and sees that his initial comment was too broad. We could have a conversation” it just ends up as an opportunity for you to make this community more hostile. That’s so sad.
Hopefully you’re just having a bad day.
Yeah, we could have had a nice conversation, if you had ended your initial reply to me a sentence earlier. But you didn’t, did you? No, instead, you tried to turn your failure to say what you meant around on me as if it were my fault, in an attempt to save face at my expense. Did you really think you weren’t going to get called out on it?
There is only one person “failing to engage in an even remotely constructive way,” and that’s you, not me.
You’re in a foul mood today, aren’t you? Okay, hope tomorrow is better. I’m not arguing with you about whatever this nonsense is.
I think JavaScript and web app development will be among the first programming jobs to be eaten by LLMs, and it’s already a crowded field. I’m skeptical of that being a wise career move for newcomers today.
@who @ghodawalaaman AI cannot comprehend Kotlin yet or TypeScript or C#
If you want to help people develop a fundamental understanding of IT concepts, teach them Python. C is very hard for beginners and will discourage most people. JavaScript is too inconsistent. Python will let people get results quickly and that way encourage them to carry on. Plus, it’s one of the most popular languages out there so Python skills are definitely useful in the labour market.
Yes, python is very easy language for begginers and they might need it to create backend however most students don’t even know the difference between frontend and backend. They just want to create few simple website. And even if I teach them python first to write APIs, I eventually have to teach them about html, css and js
You can use Flask. With that you’ll have your first website up and running in minutes. Then you can move on to templating in HTML and CSS.
You want them to create websites and consider C, but python is too much “back end”? My mate, you already decided what you want, no need for discussion (:
What level are your students (primary school, high school, technical college, university)?
You said it’s not a core skill, so what is their core skill? IT? Machinist? Electronics engineer?
C is an excellent “fundamentals” language that anyone with a software engineering and maybe computer science should have exposure too, but if their programming is purely practical (e.g. scripting for IT?) C is essentially irrelevant.
Javascript is very narrow in scope but if they’re web designers then it’s essential.
I’ll back the other commenters that if they need a language they can do useful things in (e.g. simple automations, calculations), Python is hard to pass over.
Go(lang)
I was taught a bit of C and still don’t understand why. I see the use of C but it feels much too low level to be useful for the kinds of things I might want to do.
Python and JS are much more relatable.
Edit: I’m getting a lot of hate for this “hot take” for some reason. I don’t know what to tell you, people learn this stuff differently. For me the “from first principles” approach framed programming as something I shouldn’t bother with because it’d be forever until I learned how to do anything useful with it.
To me C and C++ seem powerful but it feels like having to invent the universe before I can get anything done. I’m not working on embedded systems or something.
Ill counter that by saying that because you started with something more low level, the other stuff was easy (my belief).
Also, depending on what the students are actually studying, I think you need to give an introduction to low level stuff because while some will want to do web dev for example, others might want to do low level stuff. Obviously if its a web dev course you dont want to do that, but if its something like CompSci or Software Engineering then i think having a grasp of the fundamentals of low level stuff is necessary.
Lastly, if its a general introduction to programming course I think C has advantages over other languages since almost everything is done by you, instead of the compiler (for example iterating over an array - C: you need to do the for loop to manually handle the data depending on whatever type is stored in the array - Python: for x in y is sufficient). Im tutoring my little sister in programming because they have it in school, and they use python. Sure its easier to get things done, but its harder to learn/teach general programming with python in my opinion. C would have been my choice, especially since at that level its not like you need to teach/learn memory management, or complex data structures. Its the same concepts as with python (input, output, variables, conditionals, loops, functions) but the syntax just doesnt hide too much from you, unlike python, making it easier to understand whats actually going on
I didn’t find the difference in fundamentals between Python and C to be substantial. C felt similar but more unintuitive and more annoying to work with due to having to compile.
Understanding exactly how the sausage is made didn’t help me in the slightest. It was needless complexity when I already had a lot to digest.
I understand your perspective but for me it was like throwing up countless roadblocks to the point where I lost all enthusiasm for the subject.
It was many years before I tried again, this time with JS and Python.
These days I’m a professional software engineer.
JS for sure.
It has a reputation among programmers as being a bit of a mess, but I think the reasons behind that reputation are largely irrelevant to your use case.
Basically:
If there’s a need to introduce students to virtual DOM, I’d choose a library that doesn’t require language extensions or editor plugins, but allows to easily code with just the syntax of JS itself: properties as Plain Old JavaScript Objects, map/reduce with arrow functions, ternary operator, variables as usual, components as functions. Adding Mithril to existing WordPress websites for making dynamic parts such as calculators or quizzes was quite straightforward. On the other hand, its API is somewhat less convenient than what React offers.
After reading through some of the comments, here is my opinion.
C would be a good language IF you know your students plan to get into IT, specifically a sector where the low level knowledge is useful. Beyond that, I assume your students probably use windows and I personally always find it a pain to work with C on windows outside of full IDEs like jetbrains and Visual Studio. It’s also a lot more work till you get some results that you are happy about. Unless you start with an Arduino, which I find pretty nice to get students interested in embedded stuff.
I don’t like JavaScript because I find it a mess although it is very useful for anything web related.
Given you said in another comment that this is meant to be a general purpose skill for your students I would strongly recommend python. While I dislike the dynamic type system, it is a very powerful language to get stuff done. You can quickly get results that feel rewarding instead of running into hard to fix issues that turn your students off of programming in general. Also it’s very useful outside of IT as a scripting language for analyzing data in basically any field or for generating nice plots for some document
My university used gcc on WSL and it worked fine. VS Code integrates well with it so you can use your VS Code installation on Windows to your code editing.
Probably JS as the fact that every computer has by default everything you need to execute JS. But there is a bunch of browser stuff you have to worry about before you can do anything with it. I’m not sure how you learn JS before html.
With Python you can do simple command line stuff without having to really know anything else. You can learn one concept at a time.
That being said, people have a lot of familiarity with browsers and it might feel less abstract. JS might a better choice for demystifying coding. Python is probably a better choice for accomplishing anything useful.
Python. They’ll only learn bad patterns from JS. Please teach bottom-up knowledge, not top-down narrow scope.
I would go for something like Processing for students who are just trying to learn a bit of programming as an extra credit. The JS implementation is called p5.js. I would introduce a little bit of C later in the course once the students are familiar with basic programming concepts. That way you can show them what is happening behind the scenes without overwhelming them from the start.
Neither. Teach them Scheme. They need to start by building good habits (functional programming).
“Learn the rules like a pro, so you can break them like an artist.” ― Pablo Picasso
Yeah who teaches JS for compsci?? Scheme and Python are MIT-standards for a reason.
I don’t know how old your students are, but there is also MIT Scratch.
+1 to scratch, I’ve used it to both teach kids at one of those “stem summer camps” and adults who do recruiting for tech firms. Both groups were able to pick it up pretty quickly
No way it’s C. The average student will go home and find that they can’t do much of anything they like, with the level of C they know. Even printing a string is famously hard in C, they’ll hate it. Nothing drains their interest in programming faster than segfaults.
The average students wants to build games, websites, discord bots etc. Javascript makes it easy, none are easy in C.
printf(“hello world!”);If this is famously difficult to you, I don’t think computer science is your bag.
Javascript is a horrible language, but it is ubiquitous. You’ll want to spend a little time on html and css if you expect them to do more than print output.
You could focus on TypeScript, which will help them avoid some of the worst things, but then you spend more time on tooling and it won’t just run in the browser console.
Python is a reasonably popular language with a good standard library. It has fewer bizarre quirks like adding two lists of ints together to get a string.
I wouldn’t teach C to a general audience.
I would start with Python. It’s a fun language to learn, and generally recommended for beginners. Towards the end, I would spend a few sessions on c, not to teach them c but to give them an appreciation for what they get for free in higher level languages.
I’d start with logic, infrastructure and design first. Once that is locked in they can use any language to move forward as it’s only syntax you need to learn once your logic and design is solid. I’d offer them a choice of three different languages to achieve the same end result of the assignment. This shows them the importance of logic and design and the transference of skills.
Without knowing anything about your students, it’s hard to say. If I were the student I’d much prefer to be taught C, but that’s because I have an existing interest in computers and a desire to develop systems programming skills. I wouldn’t like to teach JS to anyone because it’s a bad language and I don’t want students to go away making more web 3 slop but if they actively are interested in making web 3 slop that’d be a case for teaching JS. I’m of the pedagogical school of teaching students what they are actually interested in learning. They might not know enough about programming to know which language they want to learn off the bat, but maybe ask them what sort of software they’re interested in making. If they want to make websites, you might want to teach them something like Python with Flask, as something less bad than JS as well as easy enough to learn.
Imo C is a good teaching language as it teaches you a lot about how computers work, as well as the fact that nearly everything runs on C. It is “harder” though, and imo is also for students who are actually interested.
My high school AP computer science course in the ealry aughts taught C first.
Depends in the goal.
If they are interested in Hardware, there is no better solution, than buying a hand full of cheap, “knock-off” Arduino Nano or RP2040 boards, a couple of LEDs and resistors and then let them Experiment with Arduino C, which teaches C programming in a fun and meaningful manner.
If they should get actual useful skill, start with Python. It’s easy to learn. It’s widely used for small, single-person projects, e.g. for gathering and analyzing data, running simulations, organizing something, interacting with APIs…
For any project, where I’d say, that it can be done quickly by a single person quickly on the side, Python is usually the best option. Even for experienced programmers. But especially for people that are new to programming or learning. It’s easy, approachable and (because everything is handled by some library) quite safe to work with.
It’s by far the most useful language for anyone that isn’t a full software developer. And it’s among the easiest to learn.
Also, when teaching Python, consider teaching with Jupyer documents. It immediately shows, what the short block of code is doing, instead of writing a huge and long script file, then executing it and struggling with debugging where students might not even know, how to start. An easy to host solution to supply Jupyer to a whole class is JupyterHub. If you aren’t concerned about your students data, Google Colab is a JupyterHub for free.
And now, finally, if you want a course that has some practical use (e.g. data analysis and math stuff) while also doing fun things and being incredibly interactive because of the use of hardware… Well… It’s python again.
Let them write a short branching story using Ren’Py. It’s easy and will get them engaged. Go on and switch to Jupyter/Colab and do a bit of data scraping, data analysis/math or image filters. Basically introduce numpy, then pandas, then scipy, beautiful soup or openCV. Pure hard skills, that are applicable in many jobs. But realistically, due to time constraints in normal courses, all you want to do here, is numpy to get into it and automate math homework, followed by pandas, to load and automate excel files. And finally, let them do something with hardware, by programming a RP2040 in microPython. It’s not as widely adopted as the Arduino ecosystem, but it’s good enough for the simple stuff students will be able to learn, and you don’t have to introduce a completely different language.
The fact that every computer has a browser where they can practice javascript probably makes it the better option. Python would probably require, on Windows, some setup that isn’t what you want to spend time on, and may be a barrier to them trying stuff on their own time at home.
Like a lot of people mentioned, there’s a few good things you could start with, but C is probably not one of them. At my old job I ran a course for software engineer 2s to go over C, and even they had some struggles with it. If professional engineers struggle with C, it’s maybe not the best starting point. Even C++ might be better, but still adds a lot of complexity that isn’t necessary to know as immediately as the beginning.
Whenever people ask me where to start, I say python. It gives you a relatively tame taste of environment setup, and can run code very easily and flexibly. Its type system is flexible enough to make a user aware of it, without it being as rigid as C or as vague as javascript. Because there’s enough libraries that are easy to pull in, even a beginner can start building useful programs without having to know how to build something equivalent to those libraries themselves.
Obviously if you want them to make websites, javascript will be necessary eventually, and isn’t a bad place to start. If you’re going purely for CS knowledge, I do think python is a little better; going from python to JS is probably easier than JS to python.