TE
科技回声
首页24小时热榜最新最佳问答展示工作
GitHubTwitter
首页

科技回声

基于 Next.js 构建的科技新闻平台,提供全球科技新闻和讨论内容。

GitHubTwitter

首页

首页最新最佳问答展示工作

资源链接

HackerNews API原版 HackerNewsNext.js

© 2025 科技回声. 版权所有。

The Practice is not the Performance: Why project-based learning fails

241 点作者 nancyhua大约 7 年前

50 条评论

slm_HN大约 7 年前
This reads like a very thinly veiled ad for the author&#x27;s $500 Software Design web class.<p>Project based learning won&#x27;t work, traditional learning won&#x27;t work, only my class will work. In fact the source he quotes (himself) claims he can give you a year&#x27;s worth of experience in an hour.<p>But why doesn&#x27;t project based learning fail? Well, in his example Bob, who wants to learn network programming, pairs with Alice, who somehow mysteriously takes over the entire project and does all the networking code so Bob learns nothing. That&#x27;s sort of like arguing that you can&#x27;t learn guitar from a teacher because a velociraptor might stroll by and eat the teacher.<p>I don&#x27;t know what type of learning is best, but I know you need a little more evidence then that for a post titled &quot;Why project-based learning fails&quot;.
评论 #16452332 未加载
评论 #16454176 未加载
评论 #16454641 未加载
评论 #16452344 未加载
评论 #16453654 未加载
schoosi大约 7 年前
I attended a university with a strong co-op program, and I personally believe it is the best possible solution. Classes were focused on theory and my three 6-month co-ops were spent working on meaningful software projects at real companies. As a result, I was able to build up a solid background in Computer Science theory, didn&#x27;t have to deal with the shortcomings of group class projects, and learned how to ship production-worthy code under the mentorship of real, senior engineers (and got paid to boot).<p>Why more universities don&#x27;t leverage co-op programs, especially given the exorbitant and rising cost of college tuition in the US, is beyond me.
评论 #16452448 未加载
评论 #16452600 未加载
评论 #16452227 未加载
avmich大约 7 年前
&gt; So, for programming, we need to (1) figure out the core concepts to teach, and (2) pick languages that make the concepts readily available.<p>James, the main argument for project-based learning is ability to make learning interesting. Considering that students aren&#x27;t vessels that need to be filled, but torches which need to be lit, this can trump other approaches. Importance of being interested in the material can be hard to overestimate.<p>You may still be right, but I was surprised to see the arguments for project missing this one.
评论 #16452016 未加载
评论 #16452316 未加载
评论 #16452343 未加载
评论 #16451999 未加载
eksemplar大约 7 年前
In Denmark we have a two universities that almost exclusively do project based learning. Basically students are put in groups and attached a mentor who is responsible for teaching them CS.<p>To this is coupled traditional courses in basic math&#x2F;algorithms&#x2F;scientific theory.<p>These lines produce candidates that are wasted supperior to our traditional universities. Well, if you need them to actually work with CS in the real world, I’m an employeer not a scientist, so I have no idea if they produce better candidates for research. But for real world jobs, these kinds of candidates are the only ones coming out of the universities that I can safely put in a position and expect to see them become productive after 1-3 months.<p>Traditional candidates take 6 months of mentoring before they start earning their salaries. They’ve often never even deployed a project in anything resembling a real world project. They’ve never worked in teams, and simply don’t know how to do so. They don’t know how to communicate with non-IT people. And so on.<p>As I said, project based teaching may not produce better CS candidates in terms of how good they are at CS, but it does produce candidates that can deliver a finished quality product on time.
评论 #16452290 未加载
评论 #16453289 未加载
评论 #16452239 未加载
评论 #16452520 未加载
Everlag大约 7 年前
As someone at the end of their undergrad, I have to agree that group based projects trend towards being unpleasant. The article describes the distribution of work harming full understanding of the content when all people contribute, however that&#x27;s usually the best case.<p>Most students are oversubscribed with four or five classes. There tends to always be some portion of a group which contributes trivially or simply doesn&#x27;t. When you&#x27;ve got a group of five, one is typically unreachable, apathetic, or just exhausted. Pairs are a gamble, a bad partner being a massive workload. When you&#x27;re the person who&#x27;s carrying the group, you usually end up grokking everything in the project because you touched all of it. However, since you touched all of it, you&#x27;re exhausted and likely pissed.<p>What I&#x27;ve found works is individual work sample projects, particularly those timeboxed to &#x27;hopefully a lab period but you have a week&#x27;. The GPGPU course at my school has labs which are &#x27;fill in the blanks&#x27; for cuda code. As the course goes on, those blanks get progressively more complex and make you flex your core understanding of the course. For more theory driven courses, the standard set of assignments works nicely.<p>As an aside, group projects seem to be partially motivated by the TAs and profs trying to deal with larger class sizes. Taking a senior level graphics class with 30 people lets you write 4 gnarly opengl projects which the TA marks in depth; a software engineering course with 200 people, a weekly deliverable, and 5 TAs? Dividing that by 5 is more realistic.<p>(For context I go to a school not known for their undergrad CS program; experiences may differ in other institutions)
评论 #16452498 未加载
评论 #16452067 未加载
cthalupa大约 7 年前
What a bizarre article. While the whole &quot;Learning Styles&quot; stuff is largely debunked by scientific research, we do know that different things motivate different people.<p>I would argue that motivation is the single most important aspect of learning - if you&#x27;re not motivated to learn something, you&#x27;re not going to do it. I tried to learn programming skills on and off all through my teenage years and early 20s, but it always petered out because I never had anything I really wanted to do in specific with them. I lacked the motivation to just learn the theory without having a project to work on.<p>When I finally found a project that excited me and could be broken down into manageable pieces to learn, I made infinitely more progress.<p>Recently I&#x27;ve been going back and learning actual computer science concepts. I&#x27;ve got enough programming knowledge that the computer science things actually interests me now, and I have the motivation to spend time on theory and exercise that I can&#x27;t immediately apply to a project.<p>But I never would have gotten to that point without project based learning to begin with, because I never would have been able to stick with it. I wouldn&#x27;t have cared enough.<p>Jimmy might be motivated enough by learning the theory that it works for him. But it doesn&#x27;t work for everyone, and trying to act like there&#x27;s any one single right way to educate people, when people are so massively different in so many different ways, seems to be fairly arrogant.
评论 #16454842 未加载
评论 #16453471 未加载
simplify大约 7 年前
The author is not criticizing project-based learning in general, but instead how some curriculum (I wonder who&#x27;s?) uses <i>group projects</i> as the <i>only</i> form of learning.<p>This feels a bit like a strawman. I agree group projects are not the best way to teach individual concepts. However, they&#x27;re the best way to put what you&#x27;ve learned <i>into practice</i>. To use the author&#x27;s martial arts analogy, group projects are like sparring in a safe environment.<p>Group projects are also the best way to practice your group communication skills, something isolated exercises cannot help with.
评论 #16452112 未加载
fishtoaster大约 7 年前
I think this has some good points, but ultimately comes to the wrong conclusion. The key idea, from my reading, was &quot;isolate subskills and drill them.&quot;<p>I don&#x27;t think that&#x27;s necessarily separate from project-based learning.<p>To steal an example from another commenter, I&#x27;m actually nearing the end of a figure drawing course at a local community college (because, you know, sometimes I want to not be coding :) ). The three components of drawing (as described by this professor) are line, value (shading) and gesture (shape&#x2F;flow).<p>One way you could teach that class would be: - Drill line. You&#x27;re gonna straight lines, curve lines, squiggly lines until you can draw any arbitrary bezier curve you want. - Drill value. Just draw a metric ton of gradients. - Drill gesture. Draw lots of figure shapes without every really worrying about filling them in. - In the final class, try to put it all together and draw a whole person.<p>A much better way to teach it would be: - Draw a whole person, but don&#x27;t worry too much about value and gesture- just try to get the line right. - Draw a whole person, but don&#x27;t worry too much about line and gesture- just try to get the value right. - Draw a whole person, but don&#x27;t worry too much about value and line- just try to get the gesture right. - Draw a whole person at the end using everything you&#x27;ve learned.<p>The latter way &quot;drills&quot; subskills, but it also practices the overall skill of &quot;drawing a person.&quot;<p>In the same way, I&#x27;d strongly advocate project-based &quot;drilling.&quot; Build an app to learn guis. Build an api-consuming cli to learn about apis. Build a chat app to learn networking. And if you want students to learn about networking, either assign it as an individual project or make sure all students work on the networking code (his chat app example was just a poorly-implemented assignment, not a problem with project-based learning).<p>Overall, it&#x27;s hard to argue that someone who&#x27;s spent most of their time building projects won&#x27;t be better at building projects than someone who has not.
heisenbit大约 7 年前
Let&#x27;s be clear here: An academic is writing about project based learning. Of course concepts are important. But then according to Edison Genius and many would argue Innovation is 1% inspiration and 99% perspiration.<p>Academic success or conceptual understanding alone are not good indicators of professional success. Perseverance and collaborations are at least as important as is the ability to sell. Also let&#x27;s not forget: The market is usually buying experience and not conceptual knowledge with unproven track record for application.<p>Projects may not be the best way to learn in depth about an isolated aspect if the project is end to end. But that is setting up a straw-man to be torched. A proper way to learn about networking e.g. would be measuring TCP performance and experimenting with the ramp-up. Or writing a protocol decoder for something non-trivial.
mlazos大约 7 年前
I disagree with this article for the most part, it doesn’t make sense to say that just because some group projects are not optimal implies all project based learning is bad. I think doing projects individually is hugely important both from learning theory and also learning software design. In college we had group projects and individual projects going on simultaneously, one of which was building google maps for a US state given only some location data. This project simultaneously taught me about various data structures and algos (Kd-tree, graph search, autocorrect) and we later extended it to use networking in a client server architecture. I think it’s invaluable to have students do many parts of a project individually and then come together to build larger projects and this addresses the concerns of the author.
评论 #16452544 未加载
PeterStuer大约 7 年前
The &#x27;in industry&#x27; equivalent is &#x27;on-the-job-training&#x27;. Employers love the idea that a software professional instead of taking a few days to acquire a new skill or technology, can just do it by using said skill on a client&#x27;s project without preparation and learn as you go along.<p>This always fails as there is never time budgeted for this in the schedule, so the software professional is not just facing the traditional underestimated deadline, but is now faced so doing with partially unknown tools and under intense pressure to just cut every corner and rush the first ting that doesn&#x27;t blow up completely. Next project, the &#x27;new tech&#x27; is now considered &#x27;known&#x27; and so the kludges become practice and decent learning never occurs.
sitkack大约 7 年前
Ironic that this [0] is the top story at the same time as this article is on the front page.<p>How can an academic be arguably arguing against Constructivist Learning Theory [1] without mentioning Piaget [2] or Papert [3], from the birthplace of Scratch [4] no less.<p>The author recommends, &quot;design drills for it&quot; but at the same time deriding project-based learning as simulating work. I cannot think of a better way to encourage stimulus-response coding than, &quot;doing drills&quot;. Projects provide context, which provide anchors for knowledge. Projects provide a constant stream of problems with a motivation to solve them, the teacher should be there to guide the student towards the knowledge and skills to solve the problems as they arise.<p>[0] <a href="https:&#x2F;&#x2F;news.ycombinator.com&#x2F;item?id=16453192" rel="nofollow">https:&#x2F;&#x2F;news.ycombinator.com&#x2F;item?id=16453192</a><p>[1] <a href="https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Constructivism_(philosophy_of_education)" rel="nofollow">https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Constructivism_(philosophy_of_...</a><p>[2] <a href="https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Jean_Piaget" rel="nofollow">https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Jean_Piaget</a><p>[3] <a href="https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Seymour_Papert" rel="nofollow">https:&#x2F;&#x2F;en.wikipedia.org&#x2F;wiki&#x2F;Seymour_Papert</a><p>[4] <a href="https:&#x2F;&#x2F;scratch.mit.edu&#x2F;" rel="nofollow">https:&#x2F;&#x2F;scratch.mit.edu&#x2F;</a>
评论 #16454829 未加载
nickjj大约 7 年前
Project based learning works really well for me and it seems to work well for the 20,000+ people who have taken one of my courses (based on feedback I&#x27;ve gotten over the years).<p>For example, in 10 hours of time I went from 0 knowledge about Elixir &#x2F; Phoenix (or functional programming) to having my own Phoenix app up and running with multi-login passwordless token based auth, webpack integration, etc, etc.. I now feel like I have a really good handle on how an Elixir app can be set up with Phoenix and how all of the front end aspects of a web app fall together with it (routes, templates, views, endpoints, plugs, etc.).<p>I spent the least amount of time possible just looking at Elixir&#x27;s beginner guide to get a feel for the syntax and then I started my own app and just looked up stuff as I needed it. Nearly all of that time was spent doing &quot;feature based development&quot; on the app.<p>&quot;I need to add a &#x2F;faq page, ok, how do I generate a controller and hook up a new route, let me check the docs.&quot;<p>&quot;My app layout is getting a little gnarly, how can I use template includes to split out my navigation, let me check the docs.&quot;<p>This style of learning is how I teach my <a href="https:&#x2F;&#x2F;buildasaasappwithflask.com" rel="nofollow">https:&#x2F;&#x2F;buildasaasappwithflask.com</a> course too. We cover over 50 general web development topics, but topics are went over in the context of building a real world app, implementing features as we go. Then there&#x27;s self guided homework assignments to implement even more features into the app.<p>How do you prefer learning?
PeterStuer大约 7 年前
I agree in general with the argument put forward. However:<p>While it is true that principles of programming are better taught in environments that are more suited to that (in my days that meant Modula2 and Common Lisp), one should not just assume that those skill acquired can be transferred by students unaided to different contexts. As a TA later I watched in horror how students that did perfectly well in programming classes reverted to the bad habits they had thought themselves in hobby programming before college, once they were asked to do a project in the &#x27;industrial&#x27; IDE&#x27;s an languages they were used to back then.<p>Our &#x27;learning&#x27; is far more contextualized than we believe and transfer is hard, not automatic.
muzani大约 7 年前
That&#x27;s funny. I came to the same conclusion as this article after reading The Art of Learning, by Josh Waitzkin, which the writer also mentions.<p>Project based learning is inefficient because you repeat things you know lots of times. The repetitions are spread out too far to be burned into memory.<p>I find that even after 6 years of experience, I still have to Google to convert an int array to string array. I&#x27;ve done dozens of projects, but this thing was never optimized for. It works fine to complete a project, but becomes a drag when trying to implement more complex code.<p>The ideal would be to internalize as a kind of instinct. When something is instinct, the subconscious can calculate it and work out solutions.<p>I think the best kind of learning would be to a kind of coding dojo, where they repeat similar routines until it becomes a part of their instincts.
madsbuch大约 7 年前
Hmm, I would say that the key is figuring out what the project should be and how it should be carried out. That&#x27;s where you need somebody mentoring.<p>You really don&#x27;t learn network programming from programming a a chat app. That project is broken for that learning outcome. If you asked a network expert he would probably suggest to implementthe OSI model as a C library or something like that.<p>I would also be very cautious about the group aspect of project work. And again, you would need somebody with experience in the field to help you divide the tasks, if you insist on doing group work. Another suggestion would be to do it alone, and get to communal experience into the project in other ways, maybe through reading groups with people doing similar projects.
KirinDave大约 7 年前
Project based learning is not inherently better at teaching a given subject. But it&#x27;s a superior method for teaching how to write computer software because it&#x27;s an opportunity to motivate, train, discuss and drill on core software developer tools.<p>#1 problem with folks out of college? They have no idea how to start or maintain a basic workflow. Project based learning provides space for this.
blairanderson大约 7 年前
If two people were racing to &quot;learn&quot; a programming language then yes, project based learning would fail.<p>This dude doesn&#x27;t recognize the audience that most blog posts target.<p>Most people reading blog posts about learning code are NOT in college and ARE NOT employed by colleges.<p>So the challenge for learning is more about motivation and projects tend to help you stay motivated more easily that little learning lectures and components.
评论 #16452130 未加载
quadcore大约 7 年前
It&#x27;s an interesting article. I&#x27;m not sure I agree with everything though, but maybe I do. Let me explain.<p>Let&#x27;s compare <i>programming</i> to <i>figure drawing</i> for a minute. What you could do to learn for example is, you could learn the details of some part of the figure, like the eye. Well, that&#x27;s cool but it&#x27;s not gonna teach you. That&#x27;s because the hard part in drawing the figure is dynamic, balance and proportions. It&#x27;s not so much that the details are &quot;easy&quot; and that they don&#x27;t require to be learnt, it&#x27;s that, if your dynamic, balance and proportions are off, the details will be too.
评论 #16452183 未加载
akritrime大约 7 年前
Well, I am self-taught. Actually, I am still learning, I just started a year back. And IMO, project-based learning has been really beneficial in my case. In school, I always grew up knowing I am a bad student, I don&#x27;t learn anything because I am too stupid to learn. Now, after my attempt at learning to program, I understand that it is not my inability to learn but more my inability to enjoy learning just for the sake of knowledge. When I learn something I need to know where I need it, where it fits into the bigger problem. And this is where a project-based learning has been helpful, what I know about topics like formal grammars, parsing, concurrency, distributed consensus, which data structure to use for a particular use case, basics of cryptography, sockets and protocols etc. is mostly because I took up projects that I found interesting and these projects needed me to have an idea about these things. And this is also project-based learnings biggest disadvantage. Whatever I learn, I learn from googling and reading the top few links. This leaves with serious gaps in my knowledge until I come across another article or resource that explains the gap or someone in some forum points it out to me. Learning in a formal setting is pre-emptive, but this also means there is an authoritative figure who gives you a structure that you follow to gain a thorough understanding of the topic. So I guess rather than saying one is superior to the other, attempts should be made to mix and match the good things from both styles.
bluehat大约 7 年前
A really core question(&#x2F;assumption in many comments) is &quot;is a computer science education only for SV job prep?&quot; As usual, we could stand to remember that the world doesn&#x27;t revolve around us. People learn to program for a lot of other reasons too.<p>If you want the quickest path to a SV job, you learn the most modern frameworks and drill them until you scrawl the boiler plate in your sleep. Project-based learning is extremely appropriate for this. You absolutely don&#x27;t need four years of education to crank out a comfortable 6 figure salary off this knowledge. (In fact, it might be a liability if your pet framework ages out). You only have to be able to fill a need (even one will do) which a lot of companies have.<p>If you&#x27;re looking for anything else, a diet of only back-to-back projects might not be the best way. If you&#x27;re jumping head first from javascript into kernel modules you might consider a book. If you&#x27;re looking to automate some bio or physics lab equipment, you can&#x27;t expect getting good at a few popular frameworks to carry you. If you&#x27;re learning math there are advantages to having people grade your work and offer office hours.<p>And if we&#x27;re being really honest, this non-project-based stuff is pretty useful as SV job prep too. Not knowing things like linear algebra, statistics, and discrete math can be career limiting. I mean, how many of us are really ready to jump the gap to doing serious ML work?
tomxor大约 7 年前
&gt; After finishing his first two Android apps<p>I think this guy&#x27;s definition of project based learning is &quot;large finished project&quot;.<p>My idea of project based learning (which as a self learner I use quite a lot), is very _very_ small examples, try to make those examples work in the most unpolished way from a user perspective (focus on the core functionality) and explore the different ways in which they can work as a way to explore the topic or idea that you are interested in. _not_ &quot;try to make some end product based on this idea&quot;, that&#x27;s a whole different venture.<p>In his example of making a chat app to learn about networking:<p>&gt; Over the next three weeks, Bob spends a lot of time building the GUI for the app, which he already knows how to do, and only a couple hours implementing the client protocol.<p>If he wanted to learn about MVCs and GUIs this is indeed a good project. If he really wanted to learn about networking from the perspective of chat, he should have either avoided the GUI and come up with the simplest possible CLI based interface... or avoid the interface all together and just experiment with the core networking code and send hardcoded strings or pipe in some text without a nice CLI. I mean this smartphone chat app is really a strawman IMO.<p>Disclaimer: I&#x27;ve read nothing about project based learning, I only recognise it as a concept that has emerged in my own personal learning strategies as I am sure it has in many others.
评论 #16453255 未加载
nadam大约 7 年前
The problem with teaching programming in functional languages is that those languages use a different PARADIGM than imperative languages. Learning the functional paradigm is very useful, but it cannot replace programming in like C. They are different. They teach you different things. For my taste and my carrier as mostly a performance &#x2F; graphics programmer reading the source code of DOOM was a much better, interesting, and inspiring school than learning to program in SML in a university course.
xupybd大约 7 年前
Yeah but the problem with the current method is introducing solutions before the problem. Learning a tool is way easier if you see the value of that tool. I had assignments writing XML schema. No idea why but we had to write them. I didn’t retain any of that but found them very valuable to define interfaces later on. If I’d known the use I’d have been more motivated to learn how to create them.
closed大约 7 年前
I agree that small exercises are good for teaching individual skills (e.g. a chess player practicing with only a few pieces on the board), but projects put the reason you are practicing into context. It&#x27;s a motivator to practice. It shows smaller skills combined to produce some desired behavior.<p>I think a critical piece left out of the article is the role of emotional affect. Many people are learning because they want to produce a big, realistic set of behaviors (a project), so a good learning curriculum will motivate through a project and drill through small, independent exercises.<p>Another example, the article mentions Haskell being more useful for teaching cs concepts compared to node, or piano for teaching musical theory. While this might be true, we also need learn how motivated students will be to use these tools over others. At the end of the day, the usefulness of a tool for teaching concepts will be (its effectiveness when used)*(how motivated people are to use it).
sagefy大约 7 年前
The author suggests there&#x27;s a choice between scaffolding and project-based learning. There isn&#x27;t. Scaffolding -- or breaking things down, and &#x27;putting on training wheels&#x27; so the learner doesn&#x27;t get overwhelmed -- is an established successful teaching strategy with plenty of research to defend the technique. Project-based learning lends to the idea that making things real, instead of just drills, leads to better learner motivation and retention. Project-based learning also has evidence-based support. The idea that these two learning strategies in are opposition is false. You can absolutely break down activities in components, teach those first, and then do integration practice -- all while doing project-based learning. Think &#x27;mini-projects&#x27;.<p>Disclaimer: I&#x27;m working on <a href="https:&#x2F;&#x2F;sagefy.org&#x2F;" rel="nofollow">https:&#x2F;&#x2F;sagefy.org&#x2F;</a>
greysonp大约 7 年前
I think you need a mix. When I was in high school, I taught myself how to program through making games. Progress was slow, and I wrote bad code, but I had fun, and it&#x27;s the reason I&#x27;m a programmer today.<p>Then I went to college and learned the fundamentals. I started doing projects in my spare time (often by attending hackathons), and now those projects were getting a lot better. The academics were crucial. However, I had friends that never did projects outside of class, and as a result it hurt their learning.<p>Then, fast-forward to my first job, and I learned just as much in my first year there as I did during my entire time in college.<p>So IMO, project-based learning without fundamentals (which is what I was doing in high school) ends up being really slow can produce poor results. But just learning fundamentals can be equally as bad. You need both!
natecavanaugh大约 7 年前
This article reads to me like someone arguing whether it&#x27;s better to learn by reading or watching videos. Maybe both? Neither?<p>For me, what good is it to learn all of the fundamentals if I&#x27;m not sure those fundamentals are getting me closer to my goal? Especially in the world of tech, there is no short supply of &quot;critical fundamentals&quot;, but woefully less in actual implementation.<p>And in the tech world, there&#x27;s a lot of implementation that lacks even a cursory understanding of fundamentals.<p>IMO, this isn&#x27;t a problem in the approach of learning, but the learner stopping at a superficial understanding on either side.<p>Some people don&#x27;t like to jump into new endeavors without understanding the concepts. And others don&#x27;t want to be bothered with abstracts until they can see the results.<p>Good students beat bad ones, regardless of the journey that took them there.
RandomCSGeek大约 7 年前
I think the author has confused engineering and science.<p>For example, for learning Web Development, I&#x27;d prefer a project based model where I learn concepts and apply them to my project side by side. This way, although the end result would be mess and likely incomplete, I get to learn a lot from the mistakes and issues that come in the way.<p>On the other hand, for learning about compilers, a tradional semester-based course, with 2-3 lectures&#x2F;week, and maybe an coding assignment&#x2F;week that can be completed in an hour or two would work best. In this case, while I don&#x27;t have any real project at the end, I do learn the core concepts.
red_admiral大约 7 年前
My own experience both as a learner and teacher is that project-based learning works great once you know the fundamentals and terribly otherwise.<p>Imagine you want to teach a cohort of incoming CS students to build simple web-server-with-database applications.<p>The &quot;traditional&quot; way to do this is to first teach them classes on web dev, OOP, and databases. Afterwards, you give them a software project.<p>I agree with &quot;modernists&quot; that if you just teach the three classes, but don&#x27;t set a project at the end that integrates the knowledge, you end up with people who are really good at passing whatever style of exam you set them but can still be poor at actually building applications. That&#x27;s one reason why recruiters care about your portfolio as well as your CV, I guess. It&#x27;s also why universities, since time immemorial, have required individual projects and dissertations to get a degree - after teaching you the classes, for your &quot;masterpiece&quot; you work on a project.<p>The problem with making everything a project and assuming they&#x27;ll learn or teach themselves the basics as and when they need them, is that without some understanding of what the building blocks are to build an application you end up bogged down in the details and developing by trial and error.<p>Real examples I&#x27;ve seen: spending the best part of a week on code to manually parse incoming HTTP headers (missing the fact that the server library already does that for you); writing custom code to serialise lists into a database field because you don&#x27;t understand foreign keys (and of course breaking 1NF in the process); loading individual items for which you have an &quot;id&quot; by &quot;SELECT *&quot; on the whole table and then doing the filtering on the server, in O(N); and of course writing code that&#x27;s vulnerable to both XSS and SQL injection left right and centre.<p>Even in a project unit where every student has a slightly different and very open-ended project, there&#x27;s some common ground, e.g. &quot;using prepared statements&quot; for which there is such thing as a &quot;one right way to do it&quot; and my experience is that actually teaching this kind of thing in isolation is the only way that works.
dwaltrip大约 7 年前
The nice thing about project-based learning is that it is well grounded, by definition. Theory is useless without some form of grounding.<p>Group projects... well, that is a another thing entirely.
评论 #16452385 未加载
Sytten大约 7 年前
I study computer eng. with a projects based approach (teams of 2, 2 weeks projects) and I believe that it is much better than regular classes. Yes you miss theory, yes you don&#x27;t go into the details of everything, but you get more real-world experience and you actually need to work by yourself to learn something. In regular classes, you can be passive and just listen, but with projects you have to research, talk with people, try (and fail). If you have great mentorship, you will gain more during those &quot;sprints&quot;.<p>We also have a co-op program which is the best thing in the world really. I simply don&#x27;t understand why most universities don&#x27;t have one. We do 4 months of school then 4 months of work in a company (then repeat). 5 internships during a 4 years bachelor give you almost 2 years of experience when you get out of university. Since they are paid internships, you can live well during school semesters and you don&#x27;t have to work while studying. In addition, you know way more what type of job you want to do since you tried so many different companies. I personally know that I like smaller companies that operate in the fintech market and that I like backend more than anything else I tried.
njstraub608大约 7 年前
The author argues against project-based learning but then states his &quot;5-minute attempt to come up with an alternative way to teach these skills&quot; which are, effectively, all projects or pieces of a project. Ultimately it doesn&#x27;t boil down to project-based learning being ineffective, but lack of teaching for communication in engineering teams. If a student&#x27;s goal is to learn network programming, then they should speak up that they want to focus on that aspect of the project. I took a few CS course post-grad after already beginning my programming journey and found the methods of teaching to be highly ineffective (the practice problems were too abstract and most students couldn&#x27;t draw the connection to real-life problems - this is at a uni with a top CS program). Upper level courses should definitely keep focus on the complexities of theory, but entry-level CS courses would serve students better by fostering their interest in a topic and showing what it&#x27;s like in the work force, and then if it&#x27;s still something they want to pursue then teaching the theory makes sense as it&#x27;s something they would end up trying to learn about on their own anyway.
shawnee_大约 7 年前
It&#x27;s hard for me to agree with much of anything the author states here. This snippet is why:<p>&gt; I don’t teach network programming and haven’t tested these specific ideas. But, in my specialty of software design and code quality, I use exercises built on similar principles all the time.<p>In the real world, learners do not come packaged with all the tools and links and resources they need to hammer out their solutions. Classrooms are great when you can have a textbook and pre-defined problems and such, but that is not now it works outside of the classroom (or the virtual classroom, as the case may be).<p>&quot;Software design&quot; is not an isolated component from network programming. It is that bridge between big data always getting piped in to (app &#x2F; product &#x2F; website) from the network, and how to help ( user &#x2F; customer &#x2F; other developer) where most engineers are hired to create value.<p>It is a good idea to attempt to design software with &quot;code quality&quot;; conceptually that sounds like a fantastic idea. But it is impossible to do without also factoring in a predictive element of how it will be used or accessed or even discovered over networks, stores, whatever.
nathan_f77大约 7 年前
I think the author misses one major point: doing lessons and homework is boring. Building real apps and making things is fun and exciting. I started teaching myself Chinese when I was a teenager, and I decided to study it at school. As soon as it turned into a routine with lessons and homework, I lost all interest.<p>Project-based learning is an awesome way to learn a new framework or language, especially if you already have a lot of experience. I also learn very well from tutorials when I&#x27;m a beginner at something. For instance, I followed some Blender tutorials to learn 3D modeling, and I think that&#x27;s the only way I could learn. The Blender UI is far too complex to just click around and figure things out.<p>However, there are cases where you really do need to study a book and sit exams. I have many years of experience with AWS, but I&#x27;m not an expert and have lots of gaps in my knowledge. I&#x27;ve been thinking about getting an AWS certification, so that I can deeply understand all of their services.
anonytrary大约 7 年前
&gt; I do want to dispel the idea that everything would be better if only we switched to project-based learning. The opposite is closer to true.<p>Both of these maximalist notions are so far from true, it&#x27;s not even worth asking which one is closer.<p>&gt; Project-based learning is the most inefficient form of learning that still works.<p>Where it lacks efficiency in learning, it boasts incredible precision in application. Project-based learning is practical, if not fundamental. You will learn to do something tangible, but of course this may not be the most efficient way to teach conceptual lessons. Concepts and understanding (aka &quot;the math&quot;) will be required to decrease learning curves for future applications.<p>So yes, both project-based and course-based learning are important, it isn&#x27;t useful to completely eliminate one or the other, but I do feel the world is currently partial towards course-based learning.
mgeorgoulo大约 7 年前
It fails to address an important aspect of learning by projects: Being exposed to the problems. You are <i>orders of magnitude</i> more productive when learning the solutions to problems you have encountered before. This kind of motivation can only be achieved if you really do stuff.
starky大约 7 年前
I attended a program that had a program that was built around Team Based Learning (TBL) and projects. The program was very well designed around ensuring that you kept up with the course, and put the topics into practice in realistic situations (projects) as both an individual and then as a team.<p>This is incredibly effective because it reinforces your individual learning with the knowledge of your peers and provides a feedback loop to the professor who would tailor lessons based on what the class was having difficulties with.<p>TBL is not an easy program to run though, and requires a lot more forethought and time from the professor that is running it for it to be effective. There are some courses where it is a huge improvement over traditional teaching methods and some where I would argue it isn&#x27;t.
stephen大约 7 年前
Seems like having to choose only one learning&#x2F;teaching style is a false dicotomy.<p>E.g. I&#x27;ve been doing software a long time, so like the github guy in OP who liked project based learning, that works really well for me when I basically already know what I&#x27;m doing. E.g. I know C-based languages really well, put me on a project with a new language, and I&#x27;ll pick it up, np. Learning a new language by drilling would be very boring for me.<p>But if I&#x27;m learning something truly new&#x2F;novel to me, e.g. machine learning or Haskell, where I have zero existing intuition for how it works, then drilling constitute parts is very useful.
forkLding大约 7 年前
I think whatever learning method depends on your goals, are you trying to get immediate deep experience that a general (still quick-feedback) but intense brushover of all the fundamentals can not provide, then project-based learning is good for you, but if you&#x27;re looking to not only master the fundamentals but also advance in terms of being able to offer more on the fundamentals, then traditional course-based learning is good for you.<p>I don&#x27;t think there is a real good or bad but rather depends on your goal and motivations. Depending on the goal, some people might learn more from projects than course content and vice versa.
ergothus大约 7 年前
I do a little teaching on the side. My primary objection to common (can&#x27;t say if it is traditional) programming instruction is not theory vs practice, it is &quot;of what&quot;<p>Most of my time coding is spent pouring through code that i didnt write (at least not recently), building the design in my mind, finding the spot to change, and then making that change.<p>In contrast, most school coding assignments are write-from-scratch one-offs, usually involving only one students&#x27; code.
websitescenes大约 7 年前
CS grads are so insecure when it comes to this subject. Truth is most schools burry you in theory and barely teach you anything that is used in the field. A motivated self starter can easily surpass someone that went the traditional route. I only recommend school if it’s free. If you have to take loans or go in debt, don’t do it. That money would be far better used to start your own venture and learn on the job.
taurath大约 7 年前
I think the author is totally wrong and is just trying to sell some classes. I learned 3&#x2F;4 of my skill set by coming up against examples when joining a work project or coming upon problems when trying to fix things. There is no functional difference between practice and performance when it comes to writing software, only the goals of the exercise.
Joboman555大约 7 年前
I think this is missing the main point of Project Based Learning: you choose what you want to learn. You cannot treat motivation as a constant when comparing educational methods. Students get much more from their learning when it is intrinsic and specific to their interests, as is the case when doing a project.
brooklyn_ashey大约 7 年前
Some great point in OP&#x27;s critique. But CS isn&#x27;t music theory. Music theory is not really known well by most musicians who are excellent players. Theory is for theorists. I&#x27;m not saying that most musicians know zero theory-- they know what key they are in--but seriously, that only happens after they can play lots of concertos. Pianists tend to know more, but that&#x27;s because it&#x27;s staring them in the face every time they play. (speaking as a career musician: performer, composer, teacher of performance and theory) Yes, musicians drill lots of different things, but honestly, it depends what it&#x27;s for. If practicing improv withchord changes, one needs to know those changes inside and out, but that is truly just one way-- if one is improvising freely, one needs to practice by doing. It really is the only way. Improv is the creative aspect-- classical is the perfect reproduction aspect. I&#x27;m thinking software development is a kind of hybrid. Also-- there isn&#x27;t a pro music job on earth that anyone could learn well enough in a bootcamp for even six months with no prior experience, so the good news is-- no software engineer is regularaly competing with Horowitz yet. Sure, there are virtuosos in programming, but as a musician, you are surrounded by them and are already one yourself as an undergrad-- at least! This is good news for creativity in teaching programming. In terms of motivation of students: from what I have experienced as a programming student in several programs and as an observer-- the material studied is not inspiring. In music, we study Mozart and Thelonious Monk. Puccini and Stravinsky. Reich and Cage. In programming, we studied models and diagrams. We never looked at &quot;great code&quot;. When I asked if there was indpiring code to see, my teacher guided me to online lessons made by the school. I asked if there was. jupiter Symphony of code somewhere, desperately looking for a way to be indpired as I am with great writers and composers. My teacher treated me like I was &quot;being difficult&quot;. I dropped out of this program and learned on my own. This was one of the tippy top bootcamps in NYC. I was hoping it would be there for me in these ways-- it wasn&#x27;t. I&#x27;m left with this: I can&#x27;t imagine any musician getting hired to teach with such low level understanding of ... the world of interesting examples- even a beginning music professor can direct students to inspiring examples of greatness in the field. Teachers need to be paid well for the time it takes to develop interesting methods of teaching. Teaching is a complex hybrid science and art. Like all of these, it requires time and mastery, but most important: innovation!
评论 #16453717 未加载
cbhl大约 7 年前
If you&#x27;re interested in going through the literature about learning, I recommend starting with <i>Learning and Motivation in the Postsecondary Classroom</i> by Marilla D. Svinicki.
seangrogg大约 7 年前
I feel like articles are just stumbling onto the reason why many sciences have coursework and labwork as part of the curriculum.
tebugst大约 7 年前
Your actions are recognized as skill only if they are useful in real life.
osteele大约 7 年前
PBL works best in the presence of learning objectives, such that the project has domain deliverables, but is also explicitly designed to lead to learning outcomes. (In a team project, these objectives are mostly defined at the level of the student, not the team.) Ideally, these learning objectives are shared with, and maybe even, in a college course and maybe earlier, co-developed with the student.<p>“5 PBL Pitfalls to Avoid” [^1] may not be the final or best word on PBL, and it focuses more on PBL in primary education, but it&#x27;s relevant and I was able to find it in ten seconds via Google. ([^2], which links to this, is the top hit for “project based learning”.) “The Practice is not the Performance” would be a stronger article if it either (1) responded to PBL as it&#x27;s actually used (in my understanding and experience) in schools, or (2) argued that, and why, college-level applications typically stumble into the pitfalls in [^1]. (Which may indeed be true, but I&#x27;m not prepared on the content of “The Practice” to weight the authors claims over my own experience.)<p>The author&#x27;s other point is around isolation practice. Well, yes. Olin&#x27;s current Software Design course (intro to Python and programming, typically taken in the second semester) takes a textbook approach[^3] to the basic concepts of programming and computational thinking, and introduces projects as concurrent stream. But also — musicians, athletes, and other performance practitioners are often advised not to perform isolations to the exclusion of longer phrases or entire pieces, lest (1) they forget how to combine the elements into a fluid whole, or (2) they remove the feedback loops that tell them what areas of weakness to isolate. The software analogue of (1) might be design principles and practices that don&#x27;t appear with isolated elements or at small scale. The software analogue of using isolations within a project context might include discovering that you don&#x27;t understand a language feature well enough to use it or debug it, taking time out to explore it by reading or experimentation, and then returning to the project. This doesn&#x27;t downplay the importance of isolations, but it uses them as a complement to PBL, not a substitute.<p>I think there&#x27;s a lot to be learned about software engineering (which I think is what the author means when he refers to “CS”) from instruction in music and in studio arts, but it&#x27;s better learned from a deeper look at both formal and informal instruction in these areas.<p>There are some open questions, not (I believe) mentioned in the article but raised in some of the comments here:<p>* <i>Who</i> is PBL appropriate for? For example, Olin College uses PBL — mostly within the context of Team-Based Learning (TBL) — extensively. However, the Olin admissions process[^4] evaluates candidates within the context of a group activity, which overlaps substantially with PBL and TBL, and provides not only information about the candidates to the students, faculty, staff, and alumni on the team, but also provides a taste of the TBL&#x2F;PBL experience to prospective students, that they can use to self-select prior to matriculation.<p>* <i>In what domains</i> is PBL applicable? It seems to me a clear win for many engineering, design, and entrepreneurship topics. Olin&#x27;s Quantitative Engineering Analysis[^5][^6] is a multi-year experiment in applying PBL to introductory-college-level math and physics.<p>[^1]: Frank McKay, “5 PBL Pitfalls to Avoid”. <a href="https:&#x2F;&#x2F;www.edutopia.org&#x2F;article&#x2F;5-pbl-pitfalls-avoid" rel="nofollow">https:&#x2F;&#x2F;www.edutopia.org&#x2F;article&#x2F;5-pbl-pitfalls-avoid</a><p>[^2]: Edutopia, “Project-Based Learning”. <a href="https:&#x2F;&#x2F;www.edutopia.org&#x2F;project-based-learning?gclid=CjwKCAiAt8TUBRAKEiwAOI9pAA3kmvdJzyt_GGWPL9YsLIZd_ZNqJbAkmHTSWpbW1b62GL8bYwbf2hoCH4QQAvD_BwE" rel="nofollow">https:&#x2F;&#x2F;www.edutopia.org&#x2F;project-based-learning?gclid=CjwKCA...</a><p>[^3]: Literally. Allen Downey, who designed an early version of the course and is on the faculty, wrote the textbook: _Think Python_. <a href="http:&#x2F;&#x2F;greenteapress.com&#x2F;wp&#x2F;think-python-2e&#x2F;" rel="nofollow">http:&#x2F;&#x2F;greenteapress.com&#x2F;wp&#x2F;think-python-2e&#x2F;</a><p>[^4]: Olin College, “Candidates Weekends”. <a href="http:&#x2F;&#x2F;www.olin.edu&#x2F;admission&#x2F;candidates-weekends&#x2F;" rel="nofollow">http:&#x2F;&#x2F;www.olin.edu&#x2F;admission&#x2F;candidates-weekends&#x2F;</a><p>[^5]: Olin College, “QEA”. <a href="http:&#x2F;&#x2F;meet.olin.edu&#x2F;olin-isms&#x2F;quantitative-engineering-analysis-qea" rel="nofollow">http:&#x2F;&#x2F;meet.olin.edu&#x2F;olin-isms&#x2F;quantitative-engineering-anal...</a><p>[^6]: Olin College, “Changing Course”. <a href="http:&#x2F;&#x2F;www.olin.edu&#x2F;the-wire&#x2F;2016&#x2F;changing-course&#x2F;" rel="nofollow">http:&#x2F;&#x2F;www.olin.edu&#x2F;the-wire&#x2F;2016&#x2F;changing-course&#x2F;</a>
jasonlotito大约 7 年前
tl;dr: If you only do one type of X-based learning, it will fail to teach you everything you need to know. This is literally covered last in the disclaimer.<p>The author never talked about whether this was actually a problem.<p>And frankly, it&#x27;s a shameless plug for a course that literally uses project-based learning in it.