What It Takes To Be A Software Engineer

  Рет қаралды 31,022

Continuous Delivery

Continuous Delivery

Күн бұрын

Пікірлер: 70
@XShollaj
@XShollaj 3 жыл бұрын
Best channel on youtube.
@queenstownswords
@queenstownswords 3 жыл бұрын
I agree with this video. I would add that a lot of the projects software engineers are tasked with is breaking up monolithic solutions into smaller pieces. So not only do you have to be 'good' at building things up in small iterations, you have to get 'good' at breaking things up into small pieces - while keeping the solution running.
@jamesgg9950
@jamesgg9950 3 жыл бұрын
Keeping it running is more like being a software EMT than being a software engineer. From an engineering standpoint, the system might need an outright transplant, but the need to keep it running means management will only approve a quadruple bypass.
@MrBadPriest
@MrBadPriest 3 жыл бұрын
I've always felt that a good coding session often reminded me of the scientific method. Glad to see I'm not alone in this.
@retrocu
@retrocu 3 жыл бұрын
pen and paper helped me a lot. it still does. i just write and draw about the problem or design when i stuck. it really helps.
@jolynnathan8475
@jolynnathan8475 3 жыл бұрын
I am deeply impressed that you can talk for so long in front of the camera without jump cuts and almost completely without hiccups!
@ross4814
@ross4814 3 жыл бұрын
You're videos have helped me in ways I didn't think possible. I've worked in web design (bit of development) for a long time and the concepts I've learned improved the work that I do. The simple step of breaking tasks into small individual chunks (small business) empowers not only my work, but also the communicating with the stakeholders. They also feel empowered and in control of a project that don't really understand.
@TheMrFlipp
@TheMrFlipp 3 жыл бұрын
On the one side, it’s really refreshing to listen to a real leading engineer like you. On the other side, it feels so sad to work with so many people in the industry, that have shiny roles like “Head of this and that” that don’t get even the basics of professional engineering and system design.
@haseebs.7286
@haseebs.7286 3 жыл бұрын
15:00 A good analogy for this concept is a library and a landfill. For a book to be read, it has to be easily discoverable. For the book’s content to be internalized, it has to be easy to read. The Dewey Decimal System makes the book easily discoverable. When the book includes a table of contents, familiar language, good grammar, coherent thoughts and a clear objective, it is easier to read. Books that wind up in the landfill probably weren’t worth the read and aren’t worth discovering. They could be full of great information but are difficult to comprehend and practically useless. Software Projects are the same idea as iterating on and publishing books. It is easy to edit a book that is well written, comprehensible, and has a defined objective; hard to iterate on a book that is written in gibberish that nobody understands and has no purpose.
@lepidoptera9337
@lepidoptera9337 3 жыл бұрын
A book non quantum field theory is neither easily discoverable for the average reader (it won't be in the local library), nor will it be even borderline readable. According to you it should end up on the landfill. Maybe you want to refine your quality criteria a little bit.
@haseebs.7286
@haseebs.7286 3 жыл бұрын
@@lepidoptera9337 In this analogy “landfill” is meant to be a metaphor for forgotten or lost knowledge/work. In a software project, you can’t reuse a library or method if you can’t find it or understand it. You bring up a good point though that for many things, specialized knowledge is required to even begin to ingest the material. Even then, it has to be well written for the sub-population that has a chance at understanding it.
@lepidoptera9337
@lepidoptera9337 3 жыл бұрын
@@haseebs.7286 Point is that most information is useless to most people and extremely valuable to those who know how to use it. I am sure we have a wonderful collection of Persian poetry... but since I don't speak the language I will never be able to experience it. You are correct, that same phenomenon also hits software reuse hard. Most libraries are not nearly as reusable as their authors were most likely hoping for. Often it is little things like language bindings... and even externalities like the license terms. A great example of reuse are the Python libraries. The "batteries included" concept works. The lower the threshold for the user, the more likely that the code will be reused.
@kayakMike1000
@kayakMike1000 3 жыл бұрын
Totally buying your book. It's currently #4 on Amazon in the software category, right behind some O'Reilly titles. Maybe someday you could sign it for me.
@ducodarling
@ducodarling 3 жыл бұрын
Your videos are a great way to start a day of coding. Gets my head in the right place.
@ContinuousDelivery
@ContinuousDelivery 3 жыл бұрын
That's great to hear! Thanks!
@LegendOfMurray
@LegendOfMurray 3 жыл бұрын
I gave myself early Christmas gifts from Amazon: Continuous Delivery, Modern Software Development and Continuous Delivery Pipelines. Thank you for your work! Stay safe.
@ContinuousDelivery
@ContinuousDelivery 3 жыл бұрын
Thank you for your support!
@Chemaclass
@Chemaclass 2 жыл бұрын
Great summary of your Modern Software Development book. Great work 👏
@ContinuousDelivery
@ContinuousDelivery 2 жыл бұрын
Glad you liked it!
@christophdahne2306
@christophdahne2306 2 жыл бұрын
Another great video, thanks. The book is now top-most on my reading list.
@gerelltroche
@gerelltroche 3 жыл бұрын
Where do you get your shirts?! I need all of them
@deank179
@deank179 3 жыл бұрын
You always have the best t-shirts!
@4F2E4A2E
@4F2E4A2E 3 жыл бұрын
You sir, honors our profession, thank you! Totally buying your book.
@philipoakley5498
@philipoakley5498 3 жыл бұрын
Always interesting hearing about how software is re-learning how engineering works, and where the dead bodies lie in one's particular discipline (the things that make designs 'fragile' in that discipline/area..)
@Pedro5antos_
@Pedro5antos_ 3 жыл бұрын
Awesome content! Really insightful
@cryvage1354
@cryvage1354 3 жыл бұрын
"I'm sure if you have been working in software development for any time you've seen those systems too" What's worse, I've made them.
@ContinuousDelivery
@ContinuousDelivery 3 жыл бұрын
😂
@CosasCotidianas
@CosasCotidianas 3 жыл бұрын
Excellent video
@ericbluealfa
@ericbluealfa 3 жыл бұрын
Great video! But I've been wondering how do you tie software engineering with your SDLC (say Scrum, Kanban or even Waterfall)? How do you relate them. I always seen discussions on either software engineering practices or a SDLC concepts, but never seen anything were someone tries to tie them together. Probably a 50 thousand foot level thing. Would it even been helpful to do that? I'm not sure.
@ContinuousDelivery
@ContinuousDelivery 3 жыл бұрын
Well, it rules out some bad ones. Waterfall is not iterative or incremental, for example.
@rebelsdeveloper367
@rebelsdeveloper367 3 жыл бұрын
haha it mean nothing to me. The problem is people these day word "agile" . But forgeting to build the structure base . If you don't have at , you just keep hiring more staff doing the same thing again2 .
@Zuzezno
@Zuzezno 2 жыл бұрын
You almost made me cry when talking about the messy code in minute 16. I fight against that coding "style" every day.
@emonymph6911
@emonymph6911 3 жыл бұрын
@Dave Farley do you discuss these architectural software design choices in your new book? I bought it and can't wait to read it. I want to learn more about good framework methodologies in software, so if your book doesn't cover this can you recommend another one? Thank you.
@lcirocco
@lcirocco 3 жыл бұрын
Ok, I'm into chapter 2 of your latest book and I love it. Do you have a `Knuthesque` compensation scheme for errata identification, I've found one worth a cent in my ebook version: at the end of **Engineering != Code** section in the sidebar the middle of Fred Brooks quote `...he ` should be `... the` FWIW I always liken the scientific (and engineering) process to that of long division: You could do a precursory step of rounding off the two numbers in question first (just to make sure that you final answers are in the ballpark) then use the following algorithm: take a guess at how many times the denominator can divide the numerator by check how close you are stop when you have a good enough answer (in engineering) or a better answer than everybody else (in science)
@ContinuousDelivery
@ContinuousDelivery 3 жыл бұрын
I like the idea of the errata compensation, I think I will allocate the funds for each find to a charity. I have added £1 (given inflation) to the fund for your find, thank you. I really like your division example and may steal that, thanks again.
@badradish2116
@badradish2116 3 жыл бұрын
whats the difference between modularity and separation of concerns? reuse? and for that matter, isnt separation of concerns and loosely coupled the same thing??
@ContinuousDelivery
@ContinuousDelivery 3 жыл бұрын
They are closely related, but not the same. My new book describes what I mean and why I think the division matters. I can have a module that does three things, that is not a separation of concerns. I can have code where the concerns of storage are separated from the biz logic, but are tightly-coupled. So no, they aren't the same.
@lepidoptera9337
@lepidoptera9337 3 жыл бұрын
How many versions of the same product are you going to release? 18? In that case you need reuse. If you don't, then reuse is of absolutely no concern. It will weigh you down and you will never ship a product. Separation of concerns has to do with the structure of your problem (data entry, data storage, filters, search, output generation). Can it be factored into the completely independent solution of partial problem? Modularity is an implementation strategy. Even if your problem factors, the single solution may still require too much code to be implemented monolithically and you have to break it up into loosely coupled modules.
@user-nr3wm6jg1f
@user-nr3wm6jg1f 3 жыл бұрын
We're building an engineering shop from scratch. Continuous Delivery will be a fundamental part of its DNA.
@IceQub3
@IceQub3 3 жыл бұрын
Hi dave, your channels is one of the best in KZbin, thank you for doing free videos. I want to buy a physical copy of your new book as soon as its available again. Nice shirt btw
@ContinuousDelivery
@ContinuousDelivery 3 жыл бұрын
Thanks, I think that paper copies are out next week 🤞😁😎
@jenamazin2194
@jenamazin2194 3 жыл бұрын
His book will be software engineering 101 one day...
@ContinuousDelivery
@ContinuousDelivery 3 жыл бұрын
Thanks 😊
@henkvanboeijen7643
@henkvanboeijen7643 3 жыл бұрын
This channel is about bringing the same story in as many variations as possible. Continuous Delivery on repeat.
@ContinuousDelivery
@ContinuousDelivery 3 жыл бұрын
Ah, you noticed my secret plan 🤣🤣 There is a good reason for that, it works better than anything else! 😁😎
@natedekeba608
@natedekeba608 3 жыл бұрын
I’m 21 and I have finally decided the path of software developer. I’m currently working to change my major and dive into IT. And I’m planning on going to a boot camp in the future. Any advise is appreciated. Thanks in advance.
@ContinuousDelivery
@ContinuousDelivery 3 жыл бұрын
I have a few videos with advice that is meant to help people starting out, so you could take a look there: On Interviews - kzbin.info/www/bejne/paTRgIxrr8yXg6s Getting started with TDD: kzbin.info/www/bejne/r5ezkKlspqiXmdU 101 Tips for New Developers: kzbin.info/www/bejne/npusnYeXdrKmmKs There's a lot more that you may find interesting on the channel, but I hope these are helpful.
@lepidoptera9337
@lepidoptera9337 3 жыл бұрын
Unless you are a nerd with very low EQ that prevents you from interacting favorably with people, I would suggest that you go into a different profession. Take it from a nerd with very low EQ. You have been warned.
@Vennotius
@Vennotius 3 жыл бұрын
That T-shirt... :-)
@Meleeman011
@Meleeman011 3 жыл бұрын
I feel more like a composer than an engineer, although rust is getting me into high perf computing
@ssssssstssssssss
@ssssssstssssssss 3 жыл бұрын
The biggest sin should be calling software engineers "coders". Software engineering, heck even programming, entails much more than coding. Thinking of oneself as a coder puts a person in the wrong mindset and they'll think their job is just to write code.
@ssssssstssssssss
@ssssssstssssssss 3 жыл бұрын
@jeff pentagon I know you are joking. Though it's a bit harsh, if you are just coding, you are not a software engineer and don't understand what engineering is.
@rebelsdeveloper367
@rebelsdeveloper367 3 жыл бұрын
a bit diff . Coder /code monkey deal with tech so on. Which end user doesn't understand a thing. Actually most of them is under appreciated . But these day with lack of budget , a coder can be a designer / system analyst. / senior engineer . A big job responsibility but never ever people appreciated it. Usually coder don't like to meet people , while some does like me doing all sort of cum before.
@msc8382
@msc8382 2 жыл бұрын
Headsup: sts, I'm not criticizing you, my message is sort of trying to compliment yours. Anyone who CANNOT proof my product or principle that their software works, they may not be calling themselves engineers. To be an engineer means you HAVE to apply the principles of engineering. Otherwise you're an engineer in name only. Now that we have this base condition classified; how can you have the wrong mindset if the actual evidence of success or failure is directly explainable? It is if you understand the engineering principles for software. There is NO exception to this rule; if it is expressible you can analyze it with engineering principles. Someone whos mindset is that they're not engineer is probably correct; Then they should just be writing code. You may argue that someone with a lot of experience and trial and error experience can be applying engineering through experience but the problem is that you cannot dissect deviations because you're missing effective methods to process deviating results (deviating compared to your experiences). Engineers using principles do not have this problem. Someone who gains experience by exception only cannot be an engineer. To be an engineer means to apply logical principles which always proof themselves. If you're in constant doubt of what your code does, you're not applying logic needed to be an engineer. You may call yourself a developer though. PS: One fundamental detail: At least in my country its illegal to call yourself an engineer without a degree that proofs you can apply the logic of engineering. So there's also a strict line that coders may not call themselves software engineers. To call software engineers coders, would be the same in terms of level as saying that physics school teachers are the same as theoretical physicists. The area where the two work is just dramatically different and require different set of skills.
@manuelmeyer1026
@manuelmeyer1026 3 жыл бұрын
Engineering for me is getting most out of the constraints physics is imposing on reality. In software creation we are so detached from real world physics, that Software Engineering needs to set proper constraints first. Though this might be a rather modern need as in the past the hardware itself served as constraining factor.
@philipoakley5498
@philipoakley5498 3 жыл бұрын
Most software is applied logic (maths) and the misunderstanding of how humans (the real world constraint) work (or don't)!
@lepidoptera9337
@lepidoptera9337 3 жыл бұрын
You are detached from the physical world? So the 24h day and the speed with which your fingers can type don't count? Lucky for you, that is exactly how your boss thinks about his underlings. :-)
@philipoakley5498
@philipoakley5498 3 жыл бұрын
@@lepidoptera9337 What's the implemented loc/coder/day rate in your organisation ;-) There a confusion between innovation/design, and it's implementation in most discussions.
@lepidoptera9337
@lepidoptera9337 3 жыл бұрын
@@philipoakley5498 Thankfully my organization is a one man shop, so all I have to care about is that I finish my own projects. While I used to work with project managers on science projects, we had rules of twos and threes, though. It always takes twice as long and costs three times as much as the naive first estimate suggests. :-)
@philipoakley5498
@philipoakley5498 3 жыл бұрын
@@lepidoptera9337 "rules of twos and threes" !!! yay, so true. The naive estimates are just the direct parts, the rest is the indirect (un-estimated) aspects.
@tomrkba4685
@tomrkba4685 3 жыл бұрын
Twist my arm into buying your book! (but I wimped out and bought the electronic version)
@OggerFN
@OggerFN 3 жыл бұрын
Buying the electronic version is even better. It can't either away and will always be instantly accessible. All you need now is the dedication to read it :)
@admiralthrawn7089
@admiralthrawn7089 2 жыл бұрын
Is it realistic to become a Software Engineer if you're age 40? (I'm seriously considering it, now learning Python)
@ContinuousDelivery
@ContinuousDelivery 2 жыл бұрын
I don't think that there are any reasons why not in terms of skills and learning. It is possible that you may face some difficulties getting your first job because of your age. In my experience the tech industry is not very used to older, but less experienced people, so you will probably be an outlier, but these days there are also lots of ways of finding work online, where that wouldn't be a problem. Good luck.
@markd5622
@markd5622 3 жыл бұрын
Come to google books please!
@istovall2624
@istovall2624 3 жыл бұрын
I liked before I watched.... dont let me down.
@OggerFN
@OggerFN 3 жыл бұрын
lmao
@Anastasiaknt
@Anastasiaknt 3 жыл бұрын
I take a lot of ideas out of this video. And (correct me if I'm wrong) I do feel that there is something critical and difficult to measure about the ability to "train" a critical thinking that doesn't interfere with the ability to see and comprehend the global image
@Palundrium
@Palundrium 3 жыл бұрын
Great video but I must say that while I appreciate the style, I disagree with the substance with your t-shirt. It's ambiguous whether life, the universe, and everything is referring to a union or an intersection. 😁
@ContinuousDelivery
@ContinuousDelivery 3 жыл бұрын
You may be reading too much into the shirt 🤣🤣
Why Pull Requests Are A BAD IDEA
19:13
Continuous Delivery
Рет қаралды 232 М.
Is This Why You’re Bad At Programming?
20:09
Continuous Delivery
Рет қаралды 85 М.
How Strong Is Tape?
00:24
Stokes Twins
Рет қаралды 96 МЛН
UFC 310 : Рахмонов VS Мачадо Гэрри
05:00
Setanta Sports UFC
Рет қаралды 1,2 МЛН
Software Crimes That Send Developers To JAIL
17:43
Continuous Delivery
Рет қаралды 21 М.
Software Engineering Basics
32:38
0612 TV w/ NERDfirst
Рет қаралды 353 М.
Yes... Microservices REALLY ARE Technical Debt
14:50
Continuous Delivery
Рет қаралды 67 М.
Go Iterators Are Bad
36:12
ThePrimeTime
Рет қаралды 109 М.
How To Estimate Software Development Time
16:47
Continuous Delivery
Рет қаралды 173 М.
When Test Driven Development Goes Wrong
21:11
Continuous Delivery
Рет қаралды 73 М.
The Problem With Microservices
17:47
Continuous Delivery
Рет қаралды 439 М.
Test Driven Development vs Behavior Driven Development
18:42
Continuous Delivery
Рет қаралды 155 М.
Is This Why You’re Bad At Programming? • Dave Farley • GOTO 2023
20:23
How Strong Is Tape?
00:24
Stokes Twins
Рет қаралды 96 МЛН