Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • World
  • Users
  • Groups
Skins
  • Light
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (Darkly)
  • No Skin
Collapse

Chebucto Regional Softball Club

  1. Home
  2. Uncategorized
  3. Wanted: Advice from CS teachers
A forum for discussing and organizing recreational softball and baseball games and leagues in the greater Halifax area.

Wanted: Advice from CS teachers

Scheduled Pinned Locked Moved Uncategorized
233 Posts 143 Posters 0 Views
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • Deborah Preuss, pcc 🇨🇦D Deborah Preuss, pcc 🇨🇦

    @futurebird @ShaulaEvans yes! The constructive value of "I don't know" lies sitting with (using) the discomfort, and daring to try something that may not work (yet). I was a great debugger, if I say so myself 🤭.

    Deborah Preuss, pcc 🇨🇦D This user is from outside of this forum
    Deborah Preuss, pcc 🇨🇦D This user is from outside of this forum
    Deborah Preuss, pcc 🇨🇦
    wrote last edited by
    #145

    @futurebird @ShaulaEvans https://mastodon.social/@dahukanna/115873119314743574

    1 Reply Last reply
    0
    • jmhtJ jmht

      @futurebird There's always the classic return: "Why?"

      myrmepropagandistF This user is from outside of this forum
      myrmepropagandistF This user is from outside of this forum
      myrmepropagandist
      wrote last edited by
      #146

      @jmht

      Why what?

      jmhtJ 1 Reply Last reply
      0
      • myrmepropagandistF myrmepropagandist

        Wanted: Advice from CS teachers

        When teaching a group of students new to coding I've noticed that my students who are normally very good about not calling out during class will shout "it's not working!" the moment their code hits an error and fails to run. They want me to fix it right away. This makes for too many interruptions since I'm easy to nerd snipe in this way.

        I think I need to let them know that fixing errors that keep the code from running is literally what I'm trying to teach.

        TheFwGuy 🇪🇺🇮🇹🇺🇸🖖T This user is from outside of this forum
        TheFwGuy 🇪🇺🇮🇹🇺🇸🖖T This user is from outside of this forum
        TheFwGuy 🇪🇺🇮🇹🇺🇸🖖
        wrote last edited by
        #147

        @futurebird First of all, amazing somebody still teach programming.
        40+ years experience in SW/FW developing here and the simple truth is that not everybody is cut to program computer.
        Is not only matter of knowledge, is matter about how a person think and is curious about the world and things working.
        Every single one person who interrupt and ask, will end up using google and AI to write a program.
        No personal ideas, no spending hours trying to understand the problem and the nature of errors.
        In my career I saw "new" generations of developers knowing less and less. Almost nobody of new generations knows what a computer is and how is working. It seems a useless information but is exactly what make you understand the errors.
        Errors exists all along the "chain", from your code to code you are using (compiler/OS/drivers/etc.) up to the electronic.
        Maybe the way you and others teach programming should change, making more like a mystery hour 🤔

        1 Reply Last reply
        0
        • myrmepropagandistF myrmepropagandist

          @jmht

          Why what?

          jmhtJ This user is from outside of this forum
          jmhtJ This user is from outside of this forum
          jmht
          wrote last edited by
          #148

          @futurebird "My code isn't working!" "Why?"

          I realize that's a flip response to your inquiry, but, ultimately it is what you're looking to enable your students to do, right? They should be able to say more than "it isn't working" which is uninformative. So, it isn't working .. what else can you say about what is - or isn't - happening and what hypothesis can you give as to why? And if you have a hypothesis, how can you test it?

          1 Reply Last reply
          0
          • myrmepropagandistF myrmepropagandist

            Things to Try:
            * look for typos
            * look at what the error message indicates.

            If these don't work consider reverting your last changes to the last working version of your code. Then try making the changes again, but be more careful.

            If you can't revert the changes, start removing bits of the code systematically. Remove the things you think might cause the error and run the code again. Isolate the change or code that causes the problem.

            You can be a great programmer.

            2/2

            The Human CapybaraA This user is from outside of this forum
            The Human CapybaraA This user is from outside of this forum
            The Human Capybara
            wrote last edited by
            #149

            @futurebird Just an idea but what about "switching" students around so they have to check someone else's code?

            I used to do that with my students, asking them to "grade" each other papers.
            It's always easier to see others' mistakes and it flatters their ego... I mean, self-confidence.

            Also it's a sneaky way to make them realize that teaching is NOT easy.😉

            1 Reply Last reply
            0
            • myrmepropagandistF myrmepropagandist

              My students aren't lazy, but they *can* be a little perfectionist: scared to take risks or sit with not having the answer right away.

              They are really upset when their code won't run... but staying calm and *systematically* looking for the cause of the problem, knowing that if you just work through the tree of possible causes you will find it is not something they are good at.

              I think I need to teach this.

              Maybe I will give them some broken code and we will find the errors together.

              Emily BeasleyB This user is from outside of this forum
              Emily BeasleyB This user is from outside of this forum
              Emily Beasley
              wrote last edited by
              #150

              @futurebird I taught an Intro to R for Biologists course a few years ago and my students had the same problem... and the solution was exactly this, giving students a list of the most common errors for reference & fixing some broken code together.

              More than anything it helped my students' confidence- I think a lot of them just needed a place to start. After a week or two they weren't even using the list I gave them and fixed errors on their own

              1 Reply Last reply
              0
              • myrmepropagandistF myrmepropagandist

                Example of the problem:

                Me: "OK everyone. Next we'll make this into a function so we can simply call it each time-"

                Student 1: "It won't work." (student who wouldn't interrupt like this normally)

                Student 2: "Mine's broken too!"

                Student 3: "It says error. I have the EXACT same thing as you but it's not working."

                This makes me feel overloaded and grouchy. Too many questions at once. What I want them to do is wait until the explanation is done and ask when I'm walking around.

                Ken MilmoreK This user is from outside of this forum
                Ken MilmoreK This user is from outside of this forum
                Ken Milmore
                wrote last edited by
                #151

                @futurebird I have on occasion worked with software professionals who behave much the same way. 😒

                myrmepropagandistF 1 Reply Last reply
                0
                • myrmepropagandistF myrmepropagandist

                  So Your Code Won't Run

                  1. There *is* an error in your code. It's probably just a typo. You can find it by looking for it in a calm, systematic way.

                  2. The error will make sense. It's not random. The computer does not "just hate you"

                  3. Read the error message. The error message *tries* to help you, but it's just a computer so YOUR HUMAN INTELLIGENCE may be needed to find the real source of error.

                  4. Every programmer makes errors. Great programmers can find and fix them.

                  1/

                  ? Offline
                  ? Offline
                  Guest
                  wrote last edited by
                  #152

                  @futurebird this is a great outline for a “debug” lesson. I try to scaffold up to writing their own code over the semester:
                  Assignment 1 Read code: give them working code and they add comments.
                  Assignment 2 Debug code: give them broken code WITH comments of what it’s SUPPOSED to do and see if they can fix it. Both typos and logic errors. But I give this assignment after teaching about break points and other debugging tools.
                  Only after that are they allowed to start writing code. After that they tend to bug me less in class with their errors (pun intended 😜).

                  1 Reply Last reply
                  0
                  • myrmepropagandistF myrmepropagandist

                    Wanted: Advice from CS teachers

                    When teaching a group of students new to coding I've noticed that my students who are normally very good about not calling out during class will shout "it's not working!" the moment their code hits an error and fails to run. They want me to fix it right away. This makes for too many interruptions since I'm easy to nerd snipe in this way.

                    I think I need to let them know that fixing errors that keep the code from running is literally what I'm trying to teach.

                    felix (grayscale) 🐺G This user is from outside of this forum
                    felix (grayscale) 🐺G This user is from outside of this forum
                    felix (grayscale) 🐺
                    wrote last edited by
                    #153

                    @futurebird I've never taught a class, but my first thought is to try starting with a live-coding session where I make mistakes myself

                    1 Reply Last reply
                    0
                    • Ken MilmoreK Ken Milmore

                      @futurebird I have on occasion worked with software professionals who behave much the same way. 😒

                      myrmepropagandistF This user is from outside of this forum
                      myrmepropagandistF This user is from outside of this forum
                      myrmepropagandist
                      wrote last edited by
                      #154

                      @kbm0

                      Well perhaps they have nostalgia for those responsibility-free middle school days.

                      1 Reply Last reply
                      0
                      • myrmepropagandistF myrmepropagandist

                        Example of the problem:

                        Me: "OK everyone. Next we'll make this into a function so we can simply call it each time-"

                        Student 1: "It won't work." (student who wouldn't interrupt like this normally)

                        Student 2: "Mine's broken too!"

                        Student 3: "It says error. I have the EXACT same thing as you but it's not working."

                        This makes me feel overloaded and grouchy. Too many questions at once. What I want them to do is wait until the explanation is done and ask when I'm walking around.

                        MC FolschetteM This user is from outside of this forum
                        MC FolschetteM This user is from outside of this forum
                        MC Folschette
                        wrote last edited by
                        #155

                        @futurebird I try to separate clearly the moments when they code and the moments when I explain stuff. When I explain, they have to listen (not look at their computers). They naturally tend to not interrupt with “it doesn't work” comments, and usually ask interesting questions. For this to work, I always promise that I will share with them the code I typed I front of them (for that, I use my institution's platform).

                        MC FolschetteM 1 Reply Last reply
                        0
                        • myrmepropagandistF myrmepropagandist

                          Sometimes I have them write the code on paper with the computers closed. And this is fine, but I'd rather have them using the IDE or textedit and there is a limit to how much fun you can have with code on paper.

                          And it does tend to be the weaker students who are almost happy to find something to stop the onslaught of information "see it doesn't work! we can't go on!" and that obviously makes me very grouchy.

                          I need them to see this is like saying "Teacher my pencil broke! Stop the lesson!"

                          Francis CookD This user is from outside of this forum
                          Francis CookD This user is from outside of this forum
                          Francis Cook
                          wrote last edited by
                          #156

                          @futurebird can I ask : is this a “recent” phenomenon? I don’t really recall this behaviour except as an outlier when I did CS (which was a while ago…)

                          myrmepropagandistF 1 Reply Last reply
                          0
                          • Francis CookD Francis Cook

                            @futurebird can I ask : is this a “recent” phenomenon? I don’t really recall this behaviour except as an outlier when I did CS (which was a while ago…)

                            myrmepropagandistF This user is from outside of this forum
                            myrmepropagandistF This user is from outside of this forum
                            myrmepropagandist
                            wrote last edited by
                            #157

                            @dianshuo

                            It's always been a thing though I do think it's been getting a little better.

                            1 Reply Last reply
                            0
                            • myrmepropagandistF myrmepropagandist

                              Example of the problem:

                              Me: "OK everyone. Next we'll make this into a function so we can simply call it each time-"

                              Student 1: "It won't work." (student who wouldn't interrupt like this normally)

                              Student 2: "Mine's broken too!"

                              Student 3: "It says error. I have the EXACT same thing as you but it's not working."

                              This makes me feel overloaded and grouchy. Too many questions at once. What I want them to do is wait until the explanation is done and ask when I'm walking around.

                              Doug WadeD This user is from outside of this forum
                              Doug WadeD This user is from outside of this forum
                              Doug Wade
                              wrote last edited by
                              #158

                              @futurebird I’ve mostly taught adults, so this might not work for you, but I would try explaining that at the end of the lecture, you don’t need them to have working code, you need them to have a working understanding. They’re missing the important part of class, the learning, to focus on an unimportant part of class, producing a working program. If it’s not working, focus up and wait until we have a pause. To me, this sounds more like an etiquette question than a programming one.

                              Doug WadeD 1 Reply Last reply
                              0
                              • MC FolschetteM MC Folschette

                                @futurebird I try to separate clearly the moments when they code and the moments when I explain stuff. When I explain, they have to listen (not look at their computers). They naturally tend to not interrupt with “it doesn't work” comments, and usually ask interesting questions. For this to work, I always promise that I will share with them the code I typed I front of them (for that, I use my institution's platform).

                                MC FolschetteM This user is from outside of this forum
                                MC FolschetteM This user is from outside of this forum
                                MC Folschette
                                wrote last edited by
                                #159

                                @futurebird Another problem is explaining to them that errors are good and that the compiler is their friend, as you already explained. It's not easy with C, for instance, where the compiler spits very obscure error messages.

                                Good luck!

                                1 Reply Last reply
                                0
                                • Doug WadeD Doug Wade

                                  @futurebird I’ve mostly taught adults, so this might not work for you, but I would try explaining that at the end of the lecture, you don’t need them to have working code, you need them to have a working understanding. They’re missing the important part of class, the learning, to focus on an unimportant part of class, producing a working program. If it’s not working, focus up and wait until we have a pause. To me, this sounds more like an etiquette question than a programming one.

                                  Doug WadeD This user is from outside of this forum
                                  Doug WadeD This user is from outside of this forum
                                  Doug Wade
                                  wrote last edited by
                                  #160

                                  @futurebird maybe even just a “it doesn’t need to compile right now, we’re focused on <concept>” and leaving the compiler angry

                                  1 Reply Last reply
                                  0
                                  • myrmepropagandistF myrmepropagandist

                                    Wanted: Advice from CS teachers

                                    When teaching a group of students new to coding I've noticed that my students who are normally very good about not calling out during class will shout "it's not working!" the moment their code hits an error and fails to run. They want me to fix it right away. This makes for too many interruptions since I'm easy to nerd snipe in this way.

                                    I think I need to let them know that fixing errors that keep the code from running is literally what I'm trying to teach.

                                    CatC This user is from outside of this forum
                                    CatC This user is from outside of this forum
                                    Cat
                                    wrote last edited by
                                    #161

                                    @futurebird That does sound frustrating, especially if you have a good flow with the lesson and then have to stop suddenly. I'm not a school teacher, but I mentor a robotics team, and we always code in pairs with one student "driving" and the other just observing for errors. It means we stop less for small silly things like typos, but also enforces the idea that there *will* be errors, it's just how coding works. I'll say, "it takes four eyeballs," and then they don't feel too bad about messing up. Usually then the students can check in with their partner first if something is wrong, and not just immediately call an adult over. I don't know how this would translate to a classroom setting though, might get loud.

                                    1 Reply Last reply
                                    0
                                    • myrmepropagandistF myrmepropagandist

                                      Wanted: Advice from CS teachers

                                      When teaching a group of students new to coding I've noticed that my students who are normally very good about not calling out during class will shout "it's not working!" the moment their code hits an error and fails to run. They want me to fix it right away. This makes for too many interruptions since I'm easy to nerd snipe in this way.

                                      I think I need to let them know that fixing errors that keep the code from running is literally what I'm trying to teach.

                                      ? Offline
                                      ? Offline
                                      Guest
                                      wrote last edited by
                                      #162

                                      @futurebird Do they work in groups? And ask them to consult with other groups . Record that plays "It isn't broken, the code is doing exactly what you asked it to do" on loop.

                                      1 Reply Last reply
                                      0
                                      • myrmepropagandistF myrmepropagandist

                                        Example of the problem:

                                        Me: "OK everyone. Next we'll make this into a function so we can simply call it each time-"

                                        Student 1: "It won't work." (student who wouldn't interrupt like this normally)

                                        Student 2: "Mine's broken too!"

                                        Student 3: "It says error. I have the EXACT same thing as you but it's not working."

                                        This makes me feel overloaded and grouchy. Too many questions at once. What I want them to do is wait until the explanation is done and ask when I'm walking around.

                                        David Chisnall (*Now with 50% more sarcasm!*)D This user is from outside of this forum
                                        David Chisnall (*Now with 50% more sarcasm!*)D This user is from outside of this forum
                                        David Chisnall (*Now with 50% more sarcasm!*)
                                        wrote last edited by
                                        #163

                                        @futurebird

                                        I’ve taught programming like this, but I’m an increasingly huge fan of the debugging-first approach that a few people have been trying more recently. In this model, you don’t teach people to write code first, you teach them to fix code first.

                                        I’ve seen a bunch of variations of this. If you have some kind of IDE (Smalltalk is beautiful for this, but other languages usually have the minimum requirements) then you can start with some working code and have them single-step through it and inspect variables to see if the behaviour reflects their intuition. Then you can give them nearly correct code and have them use that tool to fix the issues.

                                        Only once they’re comfortable with that do you have them start writing code.

                                        Otherwise it’s like teaching them to write an essay without first teaching them how to erase and redraft. If you teach people to get stuck before teaching them how to unstick themselves, it’s not surprising that they stop and give up at that point.

                                        myrmepropagandistF ? fraggleF 3 Replies Last reply
                                        0
                                        • Linus GasserL Linus Gasser

                                          @futurebird I usually have clear me/them speaking parts in the course. While I speak, they listen, which I enforce up to the last whisper.

                                          Also, the "me" parts only take 15-20 minutes each, then it's time for questions, https://github.com/ineiti/livequiz, or other interactions.

                                          For the exercise sections, the "me" parts are of course much shorter.

                                          ? Offline
                                          ? Offline
                                          Guest
                                          wrote last edited by
                                          #164

                                          @ligasser @futurebird I'm stealing this just so I can start saying, "You're interrupting my me time." Thanks. 🙂

                                          1 Reply Last reply
                                          0

                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          • 1
                                          • 2
                                          • 3
                                          • 4
                                          • 5
                                          • 6
                                          • 7
                                          • 11
                                          • 12
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          Powered by NodeBB Contributors
                                          • First post
                                            Last post
                                          0
                                          • Categories
                                          • Recent
                                          • Tags
                                          • Popular
                                          • World
                                          • Users
                                          • Groups