Man! I´m 45... coding since 11. I can say that EVERY SINGLE WORD in this video is gold! I hope the aspiring and junior developers store this advice in the heart! Congratulations!
I really like how in your videos you don’t cut out or edit out the mistakes, the troubleshooting, and the debugging; it makes your teaching real world.
Man, I wanted to be a pilot myself. My country(not US) has a military university for that, so I applied. I passed the math and pa, but after an eye exam I was told, i wont ever be a pilot due to a poor sight. So under pressure from my parents I went to a law school. While working on my degree I took a side job as an business analyst. After the school I continued being an analyst, but i really loved the technical side of things. So I applied for analyst jobs in development. Few years later I became an developer (also made a second degree in computer science).
Merging the legal training and coding, that should open a huge marketing opportunity for you to sell yourself. Either developing apps for lawyers, legal areas of in working with code related law suites. What an amazing potential!
That part of your story with your boss and the vice president looking at you while you try to fix a production issue reminded me to my old job before becoming a software engineer. It was a literal production line and I had to fix a station that failed on my shift and it was a critical station, so the issue stopped completely the process and I was there without experience with my boss, the production manager, and other high charges looking at me and I had no idea what to do and somehow I ended up fixing it. Those are really funny memories now but the stress at the moment sure was high.
Thanks for sharing. I have been in that manager role looking on as others try to fix the problem. Honestly, you are just grateful for the folks working on the problem and worried about them stressing out.
Nice Video 👍👍👍 I would add two other Traits: 1) A productive form of Laziness - To find the shortest path or easiest way or to automate as much as possible you need the laziness to not want to repeat any task, because if you did it once, every repetition is just tedious😁 and because it motivates you to always reevaluate the things you do and get better or more efficient. Also it will lead you to build a ton of little helpers😀 2) A productive form of Stubbornness - Just because somebody says it is so, you do not / can not accept the common way without at least try to do it differently. As long as there is no absolute proof that the common way is the optimal way (and there are mathematical ways to do that) do not accept the common way or even your way from yesterday, always think about doing it differently. And to never accept a dictated way to use a program, a concept or tool, because there are always new or alternatives ways...
Thanks Tim. Agree with you, although not sure persistence, determination and focus aren't a single characteristic. I would perhaps add curiosity - sometimes what drives me to continue when everything seems impossible is simply the genuine desire to know how the problem will eventually be solved. That and the drive to learn more - building on what has come before not just heading on new paths. You are always inspiring .
Tim, I appreciate your honesty. I am 55 and have 25 years experience in development and I see I'm not the only old developer here. I think if we are all honest we have messed up at some point. Someone at some point will always find out that you messed something up. So it's better to be honest about it and make the best of it. Failing to do that can make a really bad situation way worse by trying to cover something up.
@@IAmTimCorey I wish that I worked with more developers like you in my career. I work with a guy right now it was a really great guy and a super talented developer who architected most of the software for the last 15 years at this company I'm working for. This guy is super humble and easily admits things that he's messed up before. You remind me of him and that's a major compliment.
Production environments are the best teacher. Once you have one of those "uh-oh" situations, you NEVER want to be in that position again. You learn to test the crap out of your code. Code in all the safeguards you can manage so you know WHEN it encounters something our of spec.
It's not enough only to see tutorials, practice is very important. For example if you see many videos of c#, pyhton, java script, etc, your could be lost. Focus is important, step by step.I'm 36 and all days I learned new things. Thanks Tim for sharing with all comunity.
I'm naturally curious about things and that propels me forward to solving problems. However, it also causes me to go on tangents. It's a constant battle to stay on task. I find it useful to keep a log of new projects with short descriptions in a Word file. That way, I won't forget them and can return to them when I complete my current project.
Hey Tim - I have been an Oracle back-end developer with a few stint roles as an Oracle Forms developer too. Lately started exploring web based programming and will surely learn C#. Back in the day (1999-2001) programmed on VB6 too. It was such an intuitive and beautiful tool to build RAD application. I can attest that the same cannot be said of Oracle Forms. It's so boring as an UI tool yet there are companies that still use it. W.R.T to front-end tool I think Microsoft beats Oracle in the way it is designed, built in debuggers etc., Anyways what I wanted to tell you is - you have certainly given valuable advise and that is: all that glitters is not gold. Focus on one thing and do it well. Thanks again!
All of us have bad days. Sometimes it is just easier to dump that negative attitude and energy on social sites like YT comments than face your issues. Lets hope its just a rare bad day. :-)
There was one experience I had on a job where I did almost get fired. What happened was I created an email system that was supposed to email each client their reports. However, somehow each client kept getting the emails from the previous client. I did not deny any problem. I was able to admit the problem. The strange thing is at that time, I was a beginner programmer. I was using a third party component for sending emails. I would put the email address then do a send. Since I did not understand how variables worked, I assumed that putting the new email address would be just sending to that person not realizing that the others was not cleared. I ended up fixing the problem by using one line of code (the clear method). In that case, somebody said I should have tested more. However, unfortunately, when it comes to emails, its impossible to test ahead of time though. That was in 1999. In that case, I was willing to be fired for it if it came to that point. The good news is based on that learning experience, at least it made it where I would not make that mistake with the emails again.
I once wrote a single line of code in Linux trying to echo the name of a process, but instead spawned a new version of the process. Took out our production server and took a LOT of guff for that.
3 ปีที่แล้ว
Great video as always! Thanks Tim. Regards from Serbia
Tim Corey: Learn one thing well, rather than know about four things Job posts: lists 200 things, 500 good to haves So how do u crack an interview and be the hero on job: learn one thing well AND know about four things. 😎 @TimCorey: awesome stuff. U r an inspiration
Determination is what made me came this far. And your admitting mistake, oh man, been there done that too, what an embarrassing but a great driving moment to keep humble & focus... :D
Great video Tim. What makes this really stand out as "Great Advice" is that, aside from explicit examples, you can pretty much change the term "Software Developer", with whatever profession, class, particular thing you are newly learning or struggling with.
6:46 I may be naive but personally, I would never stay at a company where this sort of finger pointing is going on. In my experience, it points to a very toxic environment when bosses start asking who broke it because in the end, we are all human, and we make mistakes. In my opinion, the correct questions are, how do we fix it which ideally we are doing as a collective and after we have it fixed, then we can jump into a retrospective where we can talk about why it broke and how we can keep it happening from going forward as a team. I think the overall question of how can we all improve upon our mistakes should highly out weigh, trying to point fingers and making people feel bad as it turns a negative situation into a positive one where developer can learn from each other. Its kind of sad that junior developers would even be put in that position. So ideally your not slamming other developers for there mistakes, but I would say its not entirely your fault as you were put in this awkward situation where you ended up having to find someone to blame.
Maybe the way it was handled wasn't the best, but at the end of the day it was something that needed to be figured out. We needed to identify where the problem was so that we could fix it. Each of us had code running in different parts. Until we found the problem, we couldn't start working on the solution. We couldn't fix it as a collective because my code was controlling one system, another guy's code was controlling the API, and a third guy's code was controlling the machines. None of us could work on the others' code. That's the nature of distributed systems, especially in a manufacturing environment. I'm not going to write ladder-logic code for the PLC, nor am I going to write in a legacy Delphi system (and I didn't even have permission to access it anyway). I was writing in VB6. Each of us could only speak for our own system and only fix our own system. Blame is going to happen because it is the truth and you have to embrace the truth. If I hadn't declared my code was fine, there wouldn't have been the level of frustration there was. Yes, my code would still have been to blame, and yes I would still have been the one on the hook to fix it. The issue was compounded, though, by my not accepting the truth.
If you hate being confused or if you don't like having to constantly learn new things, coding isn't for you. Also: This stuff will humble you. Do yourself a favor and always assume it's your fault if things don't work. Thanks for your vids, Tim. Even this old dog enjoys them. Oh: Read The Soul Gene. :)
Determination is the key. But just as important it NOT assuming that you are on the right path. When I am in unknown territory, sometimes I spend too much time chasing the wrong problem. Keeping an open mind when you're deep in the doodoo is probably my most important lesson. Always reset to the top of your problem and continue searching down until you hit what you did wrong. You did do something wrong. Every time.
That sounds a bit drastic, but I agree at least that your (my) part of the code could always be improved, even if it turns out to not be the root cause.
@@wayahedia9989 The phrase "You did do something wrong. Every time." In my experience, there was the internal code we wrote, there was vendor code and frameworks, there were interfaces, there was a network, multiple types of servers and lastly those unpredictable things called... users. Ultimately I or my team owned getting things working, but that did not mean WE did something wrong every time. (often, I admit, but not every time) :-)
Hi Tim, I have a question maybe for your next q & a. As an introduction: If I'm not mistaken ".net" was launched in 2016. Microsoft has been using buzz words like "Cross Platform" ever since, but after 7 years I still can't build a user interface that works on Windows / MacOS / Linux. If I'm not mistaken, I'm curious what you think about, how you comment and what work around can you propose... Thank you.
.NET Core came out then and yes, the goal was cross-platform development. We got that with all of the web projects, Worker Services, and Console apps. The cross-platform desktop apps are coming in .NET 6, which is coming out in November, 2021.
I am currently studying C# and C# with web dev in school right now, and I am at a point where I feel like I am behind, that I don't know much, but probably knows more then I am aware of. Either way, lately I have been going back to check on C# stuff since we have been learning HTML, CSS and JavaScript lately and I don't want to fall behind there too much. In August I am going out on internship for 12 weeks and I am a little worried but will hopefully be fine... Either way, what I want to ask is, if I watch a video of a topic, or learn it thru codacademy for example, what kind of practice "projects" should I do? let's say if I want to practice on Object oriented programming
Hey @IAmTimCorey short story i'm kinda in this situation in my career. We were close to launch and 80% of my code wasnt working, i could've fixed it but it would've taken time with my skill set so the Sn dev had to jump in. I thought i'd get fired but my boss and the client gave me second chance (i have no idea why) which i hope i dont screw up. I needed this video.
@@IAmTimCorey Me too. The missing knowledge gap is design patterns and principles as the breaking code was mostly due to poor code structuring. Learning to fix that from your videos.
A harsh truth about potential: although everyone can become a developer, not everyone can become as successful. Some people have the potential to become architects, others can't become more than regulars. However, here's some hope: the journey of finding out what you are, all the "blood, sweat and tears", the pursuit of your limits, is not only going to give you a great career and the opportunity for a better life, it is going to fill that life with meaning.
Wow, thanks for the encouragement. I thought I was going to be a developer, but I made my career more as a 'generalist'. I could code so I understood how to make things happen, how to solve problems, how to talk/understand the lingo, and found success as a team lead filling the gap between developers and coders. I encouraged them to talk to each other all the time but I could see the bigger picture and design the end-to-end solutions. I sort of made my own role, then fell into the 'product owner' role in agile. ...but I started as a developer.
can you make video comparison blazor(server/wasm) vs Next.js(React) for .NET Dev I am focusing on being an expert in .NET but I have gr8 skills in React Should I transition to blazor or I should stick with react and I you can make a video about the future of blazor and tnx a lot for you're work
Hang in there. Don't give up! Often times, its not just the developer skills but the combination of life experiences and programming skills that makes the difference.
@@IAmTimCorey Thank you for the reply, will check it out. My biggest issue is focus, as you said, watch 1 video, practice practice practice. Right now I flip flop across many videos and languages (C#, JS, etc).
Those simple mistakes can cause so much headache. Built my first Web Application, and I had gotten stuck in areas for hours or even days because of simple errors.
I think that is a bit short. There is a very small range for fighter pilots when it comes to height. Then there are all of the other requirements. It is definitely an elite club.
He knows not everybody can code, but when your livelihood depends on teaching this / selling courses, then ofc EVERYBODY CAN!!! Nothing against him, I think he is the best in this field, I am, just stating the obvious. Can you become an NBA player, can you cramm yourself into a cockpit? Yes. Does it come with risks? Yes. Will you be a good fit? Most probably not. If you CAN do something, it doesn't mean you SHOULD. Can everybody code? Short of a mental issue, yes, everybody can write a Hello World program. Can ANYBODY be a developer? I highly doubt, and its not based on IQ.
Well, I disagree. I know that I'm just some guy on the Internet, so trust is hard, so let me say something and then let me back it up. The statement: I don't say things to boost my course sales. The evidence: first, I avoid all sleezy sales tactics. I don't put teaser content here that forces you to buy the course to get the rest of the videos. I don't chase the latest clickbait headlines. I don't price my course at $2,000 but tell you that for a limited time, you can get it for $15. Second, I repeatedly say in my videos and in my comments here on TH-cam to try out a topic before you consider buying a course. I provide full training videos that will introduce a topic (for free, with no strings attached) to let you know if that topic is even for you. Only then do I even offer a paid course. For instance, the C# Projects site ( www.csharpprojects.com ) introduces you to each of the major C# project types and gives you a free intro video that shows you what the project type is, how to use it, and how to go deeper into it. Only then do I offer a course that will take you even deeper into the topic (or cover it as part of a larger whole). Third, I offer a 30-day money-back guarantee on all of my courses. That is plenty of time to try something out, find out you aren't cut out for it, and move on. Fourth, when people ask me about a course, I point them to a free TH-cam video first in most cases. OK, so that's out of the way, let's discuss the "everyone can be a developer" statement. Since I've (hopefully) proven that this statement isn't financially motivated, why do I say it? I say it because I've seen it. But first, let's discuss the term "developer". Does that only mean people who are mid-level developers and higher who are getting paid by companies? Does it mean any developer who makes money working as a developer? Does it include people who build software to sell but who aren't employed by a company? Does it include people who build application to make their lives easier, but who don't sell those applications? When you start looking at all the ways you can be a developer, it starts to get hard to define who is a "real" developer. If you say you have to make money with your work, that means that there are a lot of successful open-source developers who aren't "real" developers. My definition of developer is "anyone who writes code and who wants to claim that title". Yep, that means the person who writes a "Hello World" application could/should consider themselves a "real" developer. At first, that seems ridiculous. Just writing one sample application seems too little to consider yourself a developer, but then when you look at the list of questions above, you start to have a hard time defining what the line should be. Where I define it is a clear line. It is also one that does not exclude people. If you draw the line down the road, you start excluding people that shouldn't be excluded. So, by that definition, everyone can be a developer. But I think everyone can be more than that. I think every person could write code that had a meaningful impact on others. That might be a simple text-based game or it might be a NuGet package to make someone else's life easier. Not everyone is cut out to be a day-to-day developer, but everyone can be a developer that has an impact on the world, however small the impact might be. With that being said, not everyone WANTS to be a developer. That is perfectly ok. In fact, I encourage people to do what fits their personality and set of abilities best. But, just because not everyone wants to be a developer and not everyone is cut out to be a developer full-time doesn't mean they cannot be a developer. I taught C# in a college classroom for years. During that time, I encountered multiple students who had been told they could never be developers. They were told they weren't smart enough, they weren't cut out for it, or they didn't have the right skills to cut it. They all passed my class with flying colors. The ones who didn't pass in my class were the ones who didn't put in the effort. I had a student who was "learning-challenged" take my class and get a B. They put in the extra effort and worked to get it. I had another student who took my class after failing the same class twice before with other professors. They not only got an A in my class, they went on to become a successful, paid developer for a local company. The harm of excluding people who aren't "good enough" is real, and it causes people who have potential to turn aside. I would rather encourage a person and tell them they can do it if they want, especially since I fully believe it to be true.
you are great and these things you advice people with are really great but i really have a difficult problem and i wish if you could help with ...my focus is to be C# developer and i am practicing on it but my college makes me learning other things like C++ and Java and now i have to join a team who will build a web application with Laravel and JavaScript can you please just help me about how can i focus on C# well and how can i not be confused
My nephew is in the same position. My advice is focus on JAVA. You will get all the fundamentals to migrate to C# later and will perform well in the school with no stress.
not exactly agree on second point. imo its about a more general problem about getting sw developer, namely the question: where to start and whats important? and in that regard you can see 2 types of "shinies". "shinies" which will give you some more general understanding and solutions to some sets of problems, and "shinies" which are trying to sell you just an alternative to something you already have, in a different way. most alternative "shinies" are just time traps, which just promise you, that with them everything will be 1000 times better. but in reality its mostly not the case, or not in a scale that it would be worth the time. to see the difference you just need to use one of the most important sw dev skills: generalization. learn to see things by what they realy are, not by how they are called. come up with own names for this things and classes of this things in a specific context. for example the whole sw dev stuff can be seen like developing process description for programmable electronics namely for the cpu and additional utility mcs. that is the level of assembler. then you have C language as kind of macro assembler to do this stuff more comfortable by adding some abstractions. then you have everything on top of that like java, javascript, python, c++ as *_frameworks_* for C. so this are additional rules and abstractions to make the work more efficient. in that case it doesnt make much of a difference if you learn python, c++, java, javascript, lisp, c# or something else in some sense, because they are basicaly alternatives for the same level. but it would help to get more general understanding if you can java and learn c. if you get some additional information about how the OS and BIOS works, which are used by C to get things done, you will learn more about how and what happens inside jre and about java. if you learn a bit deeper, how the cpu and the utility mcus do work and how they are used by BIOS and OS, you will learn even more about java and about computer, OS and sw in general. same works for other "high lvl languages".
They would only be considered frameworks for C if you could drop down into C as well. You can't do that, though. These other languages are just that - languages. They have a higher level of abstraction, but that's a good thing. We don't all need to sit around inventing wheels when what we really need are vehicles. The wheel has been invented. Use it. That's what these higher-level languages provide us - wheels. Learning C can be interesting, but at the end of the day, unless you are going to be diving incredibly deep in an area, it just isn't necessary. That can be just as much of a shiny object (learning C) as anything else. Sure, you know some underpinnings, but that doesn't really affect the fact that you need to build a UI for a simple CRUD operation. It just distracts you from your objective.
@@IAmTimCorey sorry if I hit a nerve or someting. I hoped it is clear, that I talked not about learning C, but about getting deeper understanding about how BIOS and OS do work. and even better, to learn how a computer works. high level languages do hide this stuff a bit, but not always can they give a hint, which one of all possible abstract implementations is best for a specific case and what one should take into account to not produce bad product. and in that situations the only thing that can help, is to understanding of how everything works inside, or to ask someone who has this knowledge. in some countries every ingeneer, regardless what he will do later, *must* first work with his hands and simplest tools, to just know the realty, so that he has some basic deep understanding about stuff he will decide later. you will not get the permission for exams before you did this practical work and wrote corrensponding protocols. even if later he only works with some abstract tools, which do almost everything automated, and he just describes the requirements and signs the results. and, imo, thats the best way to do it. it rises the possible level of responsibility of this professional. and btw, even if it is offtopic, you always can fall back to C and with some things even back to asm and use the runtime of any langauge just as kind structure description and loader of implementation units.
About learning. “Start from c# or cli”. Actually I disagree because if person do not know low-level primitives - he do not go further with c# or cli. I preferred next approach: start from high-level programming to avoid loose motivation and dig into low-level from the top. It much simpler for people with high-level mindset.
Ah, key point, "...simpler for people with high-level mindset". Folks need to explore what works best for them based on their personalities and skills.
@@tomthelestaff-iamtimcorey7597 Absolutely agree. Also I think that your point about - "start from basics" is absolutely correct for people who already jumped into programming. But a bit different for newbies who just came (just IMHO). About the rest points - it's really useful, thanks!
@@IAmTimCorey Sir, every math lesson in my childhood was in Exercise. To practice. Where in Exercise for a good developer in every topic specially oops?
Almost everyone has more free time than they think. Look at how much time you spend online, on your phone, and watching TV. Actually add it up over the course of a week. It will be more than you think.
I can’t say I agree with your principle that anyone can be a software developer. In my 24 years of experience I’ve run across many in the range of 50% of people claiming that they’re software developers yet they don’t have the skills, experience, attitude or knowledge. I’ve seen people who were truck drivers, carpenters, paramedics etc. try to transition to being a software developer but failed not because they weren’t determined but because they weren’t qualified and after 5 years still couldn’t understand complex patterns, wanted to hack code in rather that have clean code. SCRUM is popular today and many people who aren’t developers are pushing that hard skills aren’t required and that anyone can be trained but behavior can’t be changed so skills aren’t important but behavior is. The bar is just lowered with this mentality. The inclusivity of being a software developer should depend on your skills, experience, attitude and knowledge for the level of software development your applying for. There truly are a lot of charlatans out here. There is an entire philosophy (Epistemology) which tries to determine how knowledge is best formed and everyone does not form the correct knowledge or quantity of knowledge. It depends on many factors not just dedication. My advice is to base your theory on facts that would actually make someone successful and actual criteria that could be measured, the same as you would for your software applications.
I do base my theories on facts. I think I just have seen a different set of possibilities than you. I taught in the classroom for five years at one college. In that time, I had a girl come to my class who had been told by well-meaning people that she was not cut out for programming. She had failed the class twice before coming to my version of the class. She was painfully introverted because she was afraid to fail once more, but thought that was all she could achieve (this is something she told me later). She passed my class with an A. She actually learned C# and she saw that she didn't have to be a failure. She went on to get her degree, then went back for another degree in mobile development. She is now employed full-time as a software developer and confident. She is extroverted and open. I almost didn't recognize her because she was so different. I was fortunate enough to be there to help stop that cycle of people telling her she wasn't cut out to be a developer. I had another student come to my class who was mentally challenged. No one expected him to accomplish anything. He struggled with the most basic of concepts at first. He was someone people thought was surely not cut out to be a developer. It took staying after class and additional work, but he graduated my class with a B+ and the ability to develop real applications that actually worked. There are enough people in this world telling potential developers that they aren't good enough, that they will never make it, that they just weren't cut out for this career. I won't be one of them. If you can build an application, even a little one, even a console app that says "Hello World", you are a developer. You might not be the next rockstar developer, but you can still be an effective developer. And I am going to be the one fighting to make sure every one of my students knows that.
why do you think that a 2 mt tall guy like you did not have the genetics to play NBA ( or high level basket anyhow ) but everybody can code? Could not it be that just like you said for coding you did not have the burning desire and determination to be a top level player? Becoming a great athlete is sure due to talent in part but there is a WHOLE LOT of determination and sacrifice and training as well... I don t think that softare dev is so muh differente than a sport. The are some "deal breaking" limitations, in basketball it is height, in software dev is a particular kind of mental attitude and way of seeing things.. there really are people who really "do not get code".... The only difference is that while you cannot train your way out of physical limitations like height we are stil very ignorant of what can be modified in our mind....
The difference is that being a software developer is not like being in the NBA. It isn’t an elite field where only 0.1% have a chance. You can be a hobby developer and be successful. You can be a low-skill developer and still get paid. You can even get paid by building something on your own. You don’t have to be a rockstar developer before you are a “real” developer. That’s the difference.
@@IAmTimCorey in fact I added "or play basketball at a high level". You can make a living with basket without being NBA just like you make a living with tennis without being an ATP player. And a 6,6+ height automatically puts anybody in you a very , very small percentage of "reasonable candidates". My point is that with athletics there are some kind of "hard limits" who cannot be pushed, but I do not think that in programming or other mental activities limits do no exist. You are just trying to bring back the "you can do anything if you really want" comforting lie for mental activities. The truth is though that to be a programmer you need the "material and potential" do be one. The only good news is that we still do not understand how much of that potential is pure genetics and how much is the result of your experiences and education, while phsycal trait like height are 99% genetics.
No, I'm not bringing back a comforting lie. I think you are just narrowing in too much on your definition of a programmer. This isn't about that level of skill or ability. This is about the ability to write code that accomplishes something. That's something that practically anyone who wants to do that will be able to do. I say practically because there are obviously some extreme outliers, but basically, if you want to do it you can. This isn't like playing basketball, it is like learning to read. It is a lot more inclusive.
@@IAmTimCorey , trust me, I teach programming for a living.. and there are way more "outliers" than you think. First there are quite a few who really do not ""get" coding, it s hard to explain but it is like their brain is not wired for that kind of thinking... so they hardly understand anything and what they understand they forget almost immediately. Then there are way more who "want to be a programmer because it is cool, or because it s easy to find a job" but having no real natural interest in it would lead a miserable life coding most of their time..
Well, some of this may come down to how you teach too. Trust me - I’ve taught in the classroom for years. For five years, I taught the “rejects”. People would go to my class after failing once (or more) from the “regular” course. Mostly, they would earn an A in my class. I had mentally-challenged students, students who were told they were stupid, students who thought they couldn’t do it and more succeed. The only people who weren’t able to make it were those who weren’t motivated to succeed. A lot of them took one on one help or extra practice but they got there. So when I say they can do it and to not write them off, I know what I am talking about. I hate to hear people writing others off, especially when I’ve seen that it usually isn’t true. More often it is a failure to teach well for the audience (which I know is tough, because not everyone learns the same, but that’s what you need to do).
Sorry but there definitely is a genetic component to coding. The good thing is that unless you're very low IQ you can still code it'll just take a lot more effort than someone who has a naturally very logical and problem solving mind.
Man! I´m 45... coding since 11. I can say that EVERY SINGLE WORD in this video is gold! I hope the aspiring and junior developers store this advice in the heart! Congratulations!
Thanks for re-enforcing the value of the message. You are right!
I am thanks for sharing
I really like how in your videos you don’t cut out or edit out the mistakes, the troubleshooting, and the debugging; it makes your teaching real world.
Thanks!
This serie is so cool. I can see that you have a podcast format of it, it will be awesome for it to be on Spotify, i wouldn't miss a single episode.
It is on Spotify.
I feel like I'm going to come back to this video every few months when I hit a breakpoint break point.
Me too. I needed this last night, in fact.
Man, I wanted to be a pilot myself. My country(not US) has a military university for that, so I applied. I passed the math and pa, but after an eye exam I was told, i wont ever be a pilot due to a poor sight. So under pressure from my parents I went to a law school. While working on my degree I took a side job as an business analyst. After the school I continued being an analyst, but i really loved the technical side of things. So I applied for analyst jobs in development. Few years later I became an developer (also made a second degree in computer science).
Merging the legal training and coding, that should open a huge marketing opportunity for you to sell yourself. Either developing apps for lawyers, legal areas of in working with code related law suites. What an amazing potential!
You are my guru Tim. Your pep talks, lesson videos have helped me so much. Thank you man. I really appreciate you.
Help Tim out by sharing this with others.
Thank you, your videos are really motivating and they always keep me going every time I faced tough time. FOCUS & DETERMINATION!!!
You are welcome.
That part of your story with your boss and the vice president looking at you while you try to fix a production issue reminded me to my old job before becoming a software engineer. It was a literal production line and I had to fix a station that failed on my shift and it was a critical station, so the issue stopped completely the process and I was there without experience with my boss, the production manager, and other high charges looking at me and I had no idea what to do and somehow I ended up fixing it. Those are really funny memories now but the stress at the moment sure was high.
Thanks for sharing. I have been in that manager role looking on as others try to fix the problem. Honestly, you are just grateful for the folks working on the problem and worried about them stressing out.
Nice Video 👍👍👍
I would add two other Traits:
1) A productive form of Laziness - To find the shortest path or easiest way or to automate as much as possible you need the laziness to not want to repeat any task, because if you did it once, every repetition is just tedious😁 and because it motivates you to always reevaluate the things you do and get better or more efficient. Also it will lead you to build a ton of little helpers😀
2) A productive form of Stubbornness - Just because somebody says it is so, you do not / can not accept the common way without at least try to do it differently. As long as there is no absolute proof that the common way is the optimal way (and there are mathematical ways to do that) do not accept the common way or even your way from yesterday, always think about doing it differently. And to never accept a dictated way to use a program, a concept or tool, because there are always new or alternatives ways...
Interesting points, thanks for sharing.
Thanks Tim. Agree with you, although not sure persistence, determination and focus aren't a single characteristic. I would perhaps add curiosity - sometimes what drives me to continue when everything seems impossible is simply the genuine desire to know how the problem will eventually be solved. That and the drive to learn more - building on what has come before not just heading on new paths. You are always inspiring .
Thank you for sharing that.
Tim, I appreciate your honesty. I am 55 and have 25 years experience in development and I see I'm not the only old developer here. I think if we are all honest we have messed up at some point. Someone at some point will always find out that you messed something up. So it's better to be honest about it and make the best of it. Failing to do that can make a really bad situation way worse by trying to cover something up.
Thanks!
@@IAmTimCorey I wish that I worked with more developers like you in my career. I work with a guy right now it was a really great guy and a super talented developer who architected most of the software for the last 15 years at this company I'm working for. This guy is super humble and easily admits things that he's messed up before. You remind me of him and that's a major compliment.
Production environments are the best teacher. Once you have one of those "uh-oh" situations, you NEVER want to be in that position again. You learn to test the crap out of your code. Code in all the safeguards you can manage so you know WHEN it encounters something our of spec.
Nothing is quite like the feeling of ice being dumped in your veins when something breaks in production.
It's not enough only to see tutorials, practice is very important. For example if you see many videos of c#, pyhton, java script, etc, your could be lost. Focus is important, step by step.I'm 36 and all days I learned new things. Thanks Tim for sharing with all comunity.
Preach it!! Watching without practicing only added limited value for most folks.
I'm naturally curious about things and that propels me forward to solving problems. However, it also causes me to go on tangents. It's a constant battle to stay on task. I find it useful to keep a log of new projects with short descriptions in a Word file. That way, I won't forget them and can return to them when I complete my current project.
I use OneNote for the same reason. It is FILLED with tangents that eventually become the main thing I'm working on.
Hey Tim - I have been an Oracle back-end developer with a few stint roles as an Oracle Forms developer too. Lately started exploring web based programming and will surely learn C#. Back in the day (1999-2001) programmed on VB6 too. It was such an intuitive and beautiful tool to build RAD application. I can attest that the same cannot be said of Oracle Forms. It's so boring as an UI tool yet there are companies that still use it. W.R.T to front-end tool I think Microsoft beats Oracle in the way it is designed, built in debuggers etc.,
Anyways what I wanted to tell you is - you have certainly given valuable advise and that is: all that glitters is not gold. Focus on one thing and do it well. Thanks again!
Thank God for you, Tim!
You helped me a lot. Not only now!
1000 thanks! 🙌🏼
Thank you for watching and sharing your thoughts.
At this point, I am convinced that there are people who go around youtube disliking videos.
Great content Tim. Enjoying from Nigeria.
All of us have bad days. Sometimes it is just easier to dump that negative attitude and energy on social sites like YT comments than face your issues. Lets hope its just a rare bad day. :-)
There was one experience I had on a job where I did almost get fired. What happened was I created an email system that was supposed to email each client their reports. However, somehow each client kept getting the emails from the previous client. I did not deny any problem. I was able to admit the problem. The strange thing is at that time, I was a beginner programmer. I was using a third party component for sending emails. I would put the email address then do a send. Since I did not understand how variables worked, I assumed that putting the new email address would be just sending to that person not realizing that the others was not cleared. I ended up fixing the problem by using one line of code (the clear method). In that case, somebody said I should have tested more. However, unfortunately, when it comes to emails, its impossible to test ahead of time though. That was in 1999. In that case, I was willing to be fired for it if it came to that point. The good news is based on that learning experience, at least it made it where I would not make that mistake with the emails again.
I once wrote a single line of code in Linux trying to echo the name of a process, but instead spawned a new version of the process. Took out our production server and took a LOT of guff for that.
Great video as always! Thanks Tim.
Regards from Serbia
Glad you enjoyed it!
as a self-taught, can't describe how much this video helps
Awesome! I am glad it was helpful.
Tim Corey: Learn one thing well, rather than know about four things
Job posts: lists 200 things, 500 good to haves
So how do u crack an interview and be the hero on job: learn one thing well AND know about four things. 😎
@TimCorey: awesome stuff. U r an inspiration
I agree.
"Focus and practice instead of moving on" Got it.
Great!
Liked, downloaded, re-watched. Thanks @Tim
You are welcome.
You are awesome!! Talks ground reality. Awesome
I am glad it was helpful.
Thank you Tim! I just needed this!
Thanks for watching
Thank you a million times Tim. 🇿🇦 I'll keep fighting 🙏
You are welcome.
Determination is what made me came this far. And your admitting mistake, oh man, been there done that too, what an embarrassing but a great driving moment to keep humble & focus... :D
Thanks!
Great video Tim. What makes this really stand out as "Great Advice" is that, aside from explicit examples, you can pretty much change the term "Software Developer", with whatever profession, class, particular thing you are newly learning or struggling with.
Thanks for pointing out that interesting application. Its a valuable insight most folks miss.
Thanks so much for your advice! So glad I discovered this channel :)
We are glad you did as well! Welcome
6:46 I may be naive but personally, I would never stay at a company where this sort of finger pointing is going on. In my experience, it points to a very toxic environment when bosses start asking who broke it because in the end, we are all human, and we make mistakes. In my opinion, the correct questions are, how do we fix it which ideally we are doing as a collective and after we have it fixed, then we can jump into a retrospective where we can talk about why it broke and how we can keep it happening from going forward as a team. I think the overall question of how can we all improve upon our mistakes should highly out weigh, trying to point fingers and making people feel bad as it turns a negative situation into a positive one where developer can learn from each other. Its kind of sad that junior developers would even be put in that position.
So ideally your not slamming other developers for there mistakes, but I would say its not entirely your fault as you were put in this awkward situation where you ended up having to find someone to blame.
Maybe the way it was handled wasn't the best, but at the end of the day it was something that needed to be figured out. We needed to identify where the problem was so that we could fix it. Each of us had code running in different parts. Until we found the problem, we couldn't start working on the solution. We couldn't fix it as a collective because my code was controlling one system, another guy's code was controlling the API, and a third guy's code was controlling the machines. None of us could work on the others' code. That's the nature of distributed systems, especially in a manufacturing environment. I'm not going to write ladder-logic code for the PLC, nor am I going to write in a legacy Delphi system (and I didn't even have permission to access it anyway). I was writing in VB6. Each of us could only speak for our own system and only fix our own system.
Blame is going to happen because it is the truth and you have to embrace the truth. If I hadn't declared my code was fine, there wouldn't have been the level of frustration there was. Yes, my code would still have been to blame, and yes I would still have been the one on the hook to fix it. The issue was compounded, though, by my not accepting the truth.
If you hate being confused or if you don't like having to constantly learn new things, coding isn't for you.
Also: This stuff will humble you. Do yourself a favor and always assume it's your fault if things don't work.
Thanks for your vids, Tim. Even this old dog enjoys them.
Oh: Read The Soul Gene. :)
You are welcome. Thanks for the recommendation.
Excellent sound advice thank you
You are welcome.
who needs motivational speakers when there is Tim Corey?
Thanks for trusting Tim
Determination is the key. But just as important it NOT assuming that you are on the right path. When I am in unknown territory, sometimes I spend too much time chasing the wrong problem. Keeping an open mind when you're deep in the doodoo is probably my most important lesson. Always reset to the top of your problem and continue searching down until you hit what you did wrong. You did do something wrong. Every time.
That sounds a bit drastic, but I agree at least that your (my) part of the code could always be improved, even if it turns out to not be the root cause.
@@tomthelestaff-iamtimcorey7597 I'm assuming your referencing "You did do something wrong" as being drastic.
@@wayahedia9989 The phrase "You did do something wrong. Every time." In my experience, there was the internal code we wrote, there was vendor code and frameworks, there were interfaces, there was a network, multiple types of servers and lastly those unpredictable things called... users. Ultimately I or my team owned getting things working, but that did not mean WE did something wrong every time. (often, I admit, but not every time) :-)
How is this not getting enough likes and views? Lets share and make sure everyone see it.
Hi Tim, I have a question maybe for your next q & a.
As an introduction: If I'm not mistaken ".net" was launched in 2016. Microsoft has been using buzz words like "Cross Platform" ever since, but after 7 years I still can't build a user interface that works on Windows / MacOS / Linux.
If I'm not mistaken, I'm curious what you think about, how you comment and what work around can you propose... Thank you.
.NET Core came out then and yes, the goal was cross-platform development. We got that with all of the web projects, Worker Services, and Console apps. The cross-platform desktop apps are coming in .NET 6, which is coming out in November, 2021.
I literally heard and visualized!
Deep!
Programming not just code.
We appreciate your watching.
I am currently studying C# and C# with web dev in school right now, and I am at a point where I feel like I am behind, that I don't know much, but probably knows more then I am aware of. Either way, lately I have been going back to check on C# stuff since we have been learning HTML, CSS and JavaScript lately and I don't want to fall behind there too much. In August I am going out on internship for 12 weeks and I am a little worried but will hopefully be fine...
Either way, what I want to ask is, if I watch a video of a topic, or learn it thru codacademy for example, what kind of practice "projects" should I do? let's say if I want to practice on Object oriented programming
I address that here - th-cam.com/video/viigJ9NwJ2o/w-d-xo.html
Gracias por compartir tu experiencia
You are welcome.
Hey @IAmTimCorey short story i'm kinda in this situation in my career. We were close to launch and 80% of my code wasnt working, i could've fixed it but it would've taken time with my skill set so the Sn dev had to jump in. I thought i'd get fired but my boss and the client gave me second chance (i have no idea why) which i hope i dont screw up. I needed this video.
I'm glad you got another chance.
@@IAmTimCorey Me too. The missing knowledge gap is design patterns and principles as the breaking code was mostly due to poor code structuring. Learning to fix that from your videos.
Thanks Tim!
You are welcome.
A harsh truth about potential: although everyone can become a developer, not everyone can become as successful. Some people have the potential to become architects, others can't become more than regulars.
However, here's some hope: the journey of finding out what you are, all the "blood, sweat and tears", the pursuit of your limits, is not only going to give you a great career and the opportunity for a better life, it is going to fill that life with meaning.
Wow, thanks for the encouragement. I thought I was going to be a developer, but I made my career more as a 'generalist'. I could code so I understood how to make things happen, how to solve problems, how to talk/understand the lingo, and found success as a team lead filling the gap between developers and coders. I encouraged them to talk to each other all the time but I could see the bigger picture and design the end-to-end solutions. I sort of made my own role, then fell into the 'product owner' role in agile. ...but I started as a developer.
can you make video comparison blazor(server/wasm) vs Next.js(React) for .NET Dev
I am focusing on being an expert in .NET but I have gr8 skills in React Should I transition to blazor or I should stick with react
and I you can make a video about the future of blazor
and tnx a lot for you're work
Thank you. I have added this to Tim's list of possible future topics.
Very valuable content!
Thanks for watching
I feel at 41, I am screwed, I got started way too late, on top of my ADHD which keeps kicking my butt.
Hang in there. Don't give up! Often times, its not just the developer skills but the combination of life experiences and programming skills that makes the difference.
You aren't. You can do this. Check out this video on age in development: th-cam.com/video/BaeHxxhc58A/w-d-xo.html
@@IAmTimCorey Thank you for the reply, will check it out. My biggest issue is focus, as you said, watch 1 video, practice practice practice. Right now I flip flop across many videos and languages (C#, JS, etc).
Those simple mistakes can cause so much headache. Built my first Web Application, and I had gotten stuck in areas for hours or even days because of simple errors.
I think most of us has been there too.
@@tomthelestaff-iamtimcorey7597 I prefer the simple mistakes most of the time though because they tend to have simple solutions haha
Golden words!
Thanks!
Waoh! Thanks ^1000000. Tim Corey Thank you God bless you.
You are very welcome.
Thanks for the video Tim, you’re awesome, I wanted to say “man” but I have to say “sir”.
You are welcome.
Damn, 6'6, you are really tall!!! Btw great video.
Thanks!
Great video!
Thanks!
I wanted to be a fighter pilot as a kid as well. After I saw Top Gun in 85.
That was quite the recruiting video.
Golden advise
Thanks!
I'm 5 feet tall exactly. I would never have become an NBA player but could I have become a fighter pilot?
I think that is a bit short. There is a very small range for fighter pilots when it comes to height. Then there are all of the other requirements. It is definitely an elite club.
He knows not everybody can code, but when your livelihood depends on teaching this / selling courses, then ofc EVERYBODY CAN!!!
Nothing against him, I think he is the best in this field, I am, just stating the obvious.
Can you become an NBA player, can you cramm yourself into a cockpit? Yes. Does it come with risks? Yes. Will you be a good fit? Most probably not.
If you CAN do something, it doesn't mean you SHOULD.
Can everybody code?
Short of a mental issue, yes, everybody can write a Hello World program.
Can ANYBODY be a developer?
I highly doubt, and its not based on IQ.
Well, I disagree. I know that I'm just some guy on the Internet, so trust is hard, so let me say something and then let me back it up. The statement: I don't say things to boost my course sales. The evidence: first, I avoid all sleezy sales tactics. I don't put teaser content here that forces you to buy the course to get the rest of the videos. I don't chase the latest clickbait headlines. I don't price my course at $2,000 but tell you that for a limited time, you can get it for $15. Second, I repeatedly say in my videos and in my comments here on TH-cam to try out a topic before you consider buying a course. I provide full training videos that will introduce a topic (for free, with no strings attached) to let you know if that topic is even for you. Only then do I even offer a paid course. For instance, the C# Projects site ( www.csharpprojects.com ) introduces you to each of the major C# project types and gives you a free intro video that shows you what the project type is, how to use it, and how to go deeper into it. Only then do I offer a course that will take you even deeper into the topic (or cover it as part of a larger whole). Third, I offer a 30-day money-back guarantee on all of my courses. That is plenty of time to try something out, find out you aren't cut out for it, and move on. Fourth, when people ask me about a course, I point them to a free TH-cam video first in most cases.
OK, so that's out of the way, let's discuss the "everyone can be a developer" statement. Since I've (hopefully) proven that this statement isn't financially motivated, why do I say it? I say it because I've seen it. But first, let's discuss the term "developer". Does that only mean people who are mid-level developers and higher who are getting paid by companies? Does it mean any developer who makes money working as a developer? Does it include people who build software to sell but who aren't employed by a company? Does it include people who build application to make their lives easier, but who don't sell those applications? When you start looking at all the ways you can be a developer, it starts to get hard to define who is a "real" developer. If you say you have to make money with your work, that means that there are a lot of successful open-source developers who aren't "real" developers.
My definition of developer is "anyone who writes code and who wants to claim that title". Yep, that means the person who writes a "Hello World" application could/should consider themselves a "real" developer. At first, that seems ridiculous. Just writing one sample application seems too little to consider yourself a developer, but then when you look at the list of questions above, you start to have a hard time defining what the line should be. Where I define it is a clear line. It is also one that does not exclude people. If you draw the line down the road, you start excluding people that shouldn't be excluded.
So, by that definition, everyone can be a developer. But I think everyone can be more than that. I think every person could write code that had a meaningful impact on others. That might be a simple text-based game or it might be a NuGet package to make someone else's life easier. Not everyone is cut out to be a day-to-day developer, but everyone can be a developer that has an impact on the world, however small the impact might be. With that being said, not everyone WANTS to be a developer. That is perfectly ok. In fact, I encourage people to do what fits their personality and set of abilities best. But, just because not everyone wants to be a developer and not everyone is cut out to be a developer full-time doesn't mean they cannot be a developer. I taught C# in a college classroom for years. During that time, I encountered multiple students who had been told they could never be developers. They were told they weren't smart enough, they weren't cut out for it, or they didn't have the right skills to cut it. They all passed my class with flying colors. The ones who didn't pass in my class were the ones who didn't put in the effort. I had a student who was "learning-challenged" take my class and get a B. They put in the extra effort and worked to get it. I had another student who took my class after failing the same class twice before with other professors. They not only got an A in my class, they went on to become a successful, paid developer for a local company. The harm of excluding people who aren't "good enough" is real, and it causes people who have potential to turn aside. I would rather encourage a person and tell them they can do it if they want, especially since I fully believe it to be true.
you are great and these things you advice people with are really great but i really have a difficult problem and i wish if you could help with ...my focus is to be C# developer and i am practicing on it but my college makes me learning other things like C++ and Java and now i have to join a team who will build a web application with Laravel and JavaScript can you please just help me about how can i focus on C# well and how can i not be confused
My nephew is in the same position. My advice is focus on JAVA. You will get all the fundamentals to migrate to C# later and will perform well in the school with no stress.
You (or someone) is paying for you to attend the college. Spend the time now learning all you can, focus on C# later.
not exactly agree on second point. imo its about a more general problem about getting sw developer, namely the question: where to start and whats important?
and in that regard you can see 2 types of "shinies". "shinies" which will give you some more general understanding and solutions to some sets of problems, and "shinies" which are trying to sell you just an alternative to something you already have, in a different way. most alternative "shinies" are just time traps, which just promise you, that with them everything will be 1000 times better. but in reality its mostly not the case, or not in a scale that it would be worth the time.
to see the difference you just need to use one of the most important sw dev skills: generalization. learn to see things by what they realy are, not by how they are called.
come up with own names for this things and classes of this things in a specific context.
for example the whole sw dev stuff can be seen like developing process description for programmable electronics namely for the cpu and additional utility mcs.
that is the level of assembler. then you have C language as kind of macro assembler to do this stuff more comfortable by adding some abstractions.
then you have everything on top of that like java, javascript, python, c++ as *_frameworks_* for C. so this are additional rules and abstractions to make the work more efficient. in that case it doesnt make much of a difference if you learn python, c++, java, javascript, lisp, c# or something else in some sense, because they are basicaly alternatives for the same level. but it would help to get more general understanding if you can java and learn c. if you get some additional information about how the OS and BIOS works, which are used by C to get things done, you will learn more about how and what happens inside jre and about java. if you learn a bit deeper, how the cpu and the utility mcus do work and how they are used by BIOS and OS, you will learn even more about java and about computer, OS and sw in general. same works for other "high lvl languages".
They would only be considered frameworks for C if you could drop down into C as well. You can't do that, though. These other languages are just that - languages. They have a higher level of abstraction, but that's a good thing. We don't all need to sit around inventing wheels when what we really need are vehicles. The wheel has been invented. Use it. That's what these higher-level languages provide us - wheels. Learning C can be interesting, but at the end of the day, unless you are going to be diving incredibly deep in an area, it just isn't necessary. That can be just as much of a shiny object (learning C) as anything else. Sure, you know some underpinnings, but that doesn't really affect the fact that you need to build a UI for a simple CRUD operation. It just distracts you from your objective.
@@IAmTimCorey
sorry if I hit a nerve or someting.
I hoped it is clear, that I talked not about learning C, but about getting deeper understanding about how BIOS and OS do work. and even better, to learn how a computer works.
high level languages do hide this stuff a bit, but not always can they give a hint, which one of all possible abstract implementations is best for a specific case and what one should take into account to not produce bad product. and in that situations the only thing that can help, is to understanding of how everything works inside, or to ask someone who has this knowledge.
in some countries every ingeneer, regardless what he will do later, *must* first work with his hands and simplest tools, to just know the realty, so that he has some basic deep understanding about stuff he will decide later.
you will not get the permission for exams before you did this practical work and wrote corrensponding protocols.
even if later he only works with some abstract tools, which do almost everything automated, and he just describes the requirements and signs the results.
and, imo, thats the best way to do it. it rises the possible level of responsibility of this professional.
and btw, even if it is offtopic, you always can fall back to C and with some things even back to asm and use the runtime of any langauge just as kind structure description and loader of implementation units.
Thanks!
You are welcome.
About learning. “Start from c# or cli”. Actually I disagree because if person do not know low-level primitives - he do not go further with c# or cli. I preferred next approach: start from high-level programming to avoid loose motivation and dig into low-level from the top. It much simpler for people with high-level mindset.
Ah, key point, "...simpler for people with high-level mindset". Folks need to explore what works best for them based on their personalities and skills.
@@tomthelestaff-iamtimcorey7597 Absolutely agree. Also I think that your point about - "start from basics" is absolutely correct for people who already jumped into programming. But a bit different for newbies who just came (just IMHO). About the rest points - it's really useful, thanks!
Sir where we get exercise on every topic specially oops?
I am not sure what you are asking for.
@@IAmTimCorey Sir, every math lesson in my childhood was in Exercise. To practice. Where in Exercise for a good developer in every topic specially oops?
Free time, free time, free time. That’s what you need
Almost everyone has more free time than they think. Look at how much time you spend online, on your phone, and watching TV. Actually add it up over the course of a week. It will be more than you think.
@@IAmTimCorey you are absolutely right. I'll practise it right now. Thank u a lot.
This gives hope
Something we all need after the last year.
Patience, lots and lots of patience because by god it's gonna be tested.
lol true
thx bro i keep going
You are welcome.
Thank you Tim for sharing your experiences and enlightening the path for junior developers just like me.
My pleasure!
Tim is if Kevin James never pursued Comedy
Thanks, I think.
You are like a father to me. I love you Tim. One day i will meet you and we will drink a Pepsi with lots of laughs.
Pepsi party at your place!! I'll bring Doritos and dip.
Tim ...... don't you DARE QUIT on US !
Amen. I can tell you that he has not plans to any time soon.
I can’t say I agree with your principle that anyone can be a software developer. In my 24 years of experience I’ve run across many in the range of 50% of people claiming that they’re software developers yet they don’t have the skills, experience, attitude or knowledge. I’ve seen people who were truck drivers, carpenters, paramedics etc. try to transition to being a software developer but failed not because they weren’t determined but because they weren’t qualified and after 5 years still couldn’t understand complex patterns, wanted to hack code in rather that have clean code. SCRUM is popular today and many people who aren’t developers are pushing that hard skills aren’t required and that anyone can be trained but behavior can’t be changed so skills aren’t important but behavior is. The bar is just lowered with this mentality. The inclusivity of being a software developer should depend on your skills, experience, attitude and knowledge for the level of software development your applying for. There truly are a lot of charlatans out here. There is an entire philosophy (Epistemology) which tries to determine how knowledge is best formed and everyone does not form the correct knowledge or quantity of knowledge. It depends on many factors not just dedication.
My advice is to base your theory on facts that would actually make someone successful and actual criteria that could be measured, the same as you would for your software applications.
I do base my theories on facts. I think I just have seen a different set of possibilities than you. I taught in the classroom for five years at one college. In that time, I had a girl come to my class who had been told by well-meaning people that she was not cut out for programming. She had failed the class twice before coming to my version of the class. She was painfully introverted because she was afraid to fail once more, but thought that was all she could achieve (this is something she told me later). She passed my class with an A. She actually learned C# and she saw that she didn't have to be a failure. She went on to get her degree, then went back for another degree in mobile development. She is now employed full-time as a software developer and confident. She is extroverted and open. I almost didn't recognize her because she was so different. I was fortunate enough to be there to help stop that cycle of people telling her she wasn't cut out to be a developer.
I had another student come to my class who was mentally challenged. No one expected him to accomplish anything. He struggled with the most basic of concepts at first. He was someone people thought was surely not cut out to be a developer. It took staying after class and additional work, but he graduated my class with a B+ and the ability to develop real applications that actually worked.
There are enough people in this world telling potential developers that they aren't good enough, that they will never make it, that they just weren't cut out for this career. I won't be one of them. If you can build an application, even a little one, even a console app that says "Hello World", you are a developer. You might not be the next rockstar developer, but you can still be an effective developer. And I am going to be the one fighting to make sure every one of my students knows that.
why do you think that a 2 mt tall guy like you did not have the genetics to play NBA ( or high level basket anyhow ) but everybody can code? Could not it be that just like you said for coding you did not have the burning desire and determination to be a top level player?
Becoming a great athlete is sure due to talent in part but there is a WHOLE LOT of determination and sacrifice and training as well...
I don t think that softare dev is so muh differente than a sport. The are some "deal breaking" limitations, in basketball it is height, in software dev is a particular kind of mental attitude and way of seeing things.. there really are people who really "do not get code"....
The only difference is that while you cannot train your way out of physical limitations like height we are stil very ignorant of what can be modified in our mind....
The difference is that being a software developer is not like being in the NBA. It isn’t an elite field where only 0.1% have a chance. You can be a hobby developer and be successful. You can be a low-skill developer and still get paid. You can even get paid by building something on your own. You don’t have to be a rockstar developer before you are a “real” developer. That’s the difference.
@@IAmTimCorey in fact I added "or play basketball at a high level". You can make a living with basket without being NBA just like you make a living with tennis without being an ATP player. And a 6,6+ height automatically puts anybody in you a very , very small percentage of "reasonable candidates". My point is that with athletics there are some kind of "hard limits" who cannot be pushed, but I do not think that in programming or other mental activities limits do no exist. You are just trying to bring back the "you can do anything if you really want" comforting lie for mental activities. The truth is though that to be a programmer you need the "material and potential" do be one. The only good news is that we still do not understand how much of that potential is pure genetics and how much is the result of your experiences and education, while phsycal trait like height are 99% genetics.
No, I'm not bringing back a comforting lie. I think you are just narrowing in too much on your definition of a programmer. This isn't about that level of skill or ability. This is about the ability to write code that accomplishes something. That's something that practically anyone who wants to do that will be able to do. I say practically because there are obviously some extreme outliers, but basically, if you want to do it you can. This isn't like playing basketball, it is like learning to read. It is a lot more inclusive.
@@IAmTimCorey , trust me, I teach programming for a living.. and there are way more "outliers" than you think.
First there are quite a few who really do not ""get" coding, it s hard to explain but it is like their brain is not wired for that kind of thinking... so they hardly understand anything and what they understand they forget almost immediately. Then there are way more who "want to be a programmer because it is cool, or because it s easy to find a job" but having no real natural interest in it would lead a miserable life coding most of their time..
Well, some of this may come down to how you teach too. Trust me - I’ve taught in the classroom for years. For five years, I taught the “rejects”. People would go to my class after failing once (or more) from the “regular” course. Mostly, they would earn an A in my class. I had mentally-challenged students, students who were told they were stupid, students who thought they couldn’t do it and more succeed. The only people who weren’t able to make it were those who weren’t motivated to succeed. A lot of them took one on one help or extra practice but they got there. So when I say they can do it and to not write them off, I know what I am talking about. I hate to hear people writing others off, especially when I’ve seen that it usually isn’t true. More often it is a failure to teach well for the audience (which I know is tough, because not everyone learns the same, but that’s what you need to do).
Sorry but there definitely is a genetic component to coding. The good thing is that unless you're very low IQ you can still code it'll just take a lot more effort than someone who has a naturally very logical and problem solving mind.
Hate to argue, but I have met some really low IQ developers. I did QA work for a lot of years so I can prove it - LoL
First comment 😍💪