Fredrik talks to Dejan Milicic about software development - understanding, methods, and stories.
We start by talking about encapsulation of knowledge and the essential software in organizations. Almost every organization should - it can be argued - be developing software that solves their unique problems, and yet so many outsource so much of their knowledge encapsulation. Oh, and we can never completely encapsulate our knowledge in code either, so all the more reason to keep people who actually know what the code does and why around.
Dejan tells us about his way to Ravendb and a developer relations role - and how you can craft your own job, stepping suitably outside of your comfort zone along the way.
We also talk about shortening attention spans, daring to dig down a bit and find out about the context of things. Like the second sentence of some oft-repeated quote. Prohibit bad things, but help automate doing good things and avoid doing the bad things completely.
Dejan shares some database backstories - why would someone want to build one more database? Specifically, what lead to the creation of Ravendb? And the very strong opinions which have been built into it. Avoiding falling into marketing-driven development.
After that, we drift into talking about processes and how we work. Every organization is unique - which strongly speaks against adapting the “best practices” and methodologies of others. Or keeping things completely the same for too long. Innovation is also about doing what other people are not doing.
Why is concurrency still hard? The free lunch has been over for twenty years! Functional programming and immutability offer ways forward, why aren’t these concepts spreading even more and faster? We get right back to understanding more context when Dejan discusses how few of us seem to have understood, just for example, the L in SOLID. Dive deeper, read more, and you will find new things and come up with new ideas.
Finally, Dejan would like to see software development becoming just a little bit more mathematical. So that things can be established, verified and built on in a different way.
Thank you Cloudnet for sponsoring our VPS!
Comments, questions or tips? We a re @kodsnack, @tobiashieta, @oferlund and @bjoreman on Twitter, have a page on Facebook and can be emailed at [email protected] if you want to write longer. We read everything we receive.
If you enjoy Kodsnack we would love a review in iTunes! You can also support the podcast by buying us a coffee (or two!) through Ko-fi.
Links
DejanRavendbInformaticsDomain-driven designEvent sourcingData is worthless - said in episode 601Developer relationsNosql databasesJack of all tradesJimmy - who introduced Fredrik to Dejan at Øredev 2024HibernateRelational databasesOren Eini - creator of RavendbAntipatternsn+1CouchbaseScrumAgile software developmentThe Toyota approachThe Scrum guideUnison programming language - VC fundedDr. Dobb’s journalThe free lunch is overConcurrencySOLIDLiskov substitution principleRepositories on top Unitofwork are not a good idea - by Rob ConeryElmTitles
A mathematician turned software developerCoding, but without deadlineSaturated with software developmentEncapsulation of knowledgeA bit surrealAccept people as they areThere’s a second lineProfessional depressionPrevented, not diagnosedThe pipeline kind of thinkingFrustration-driven development(You shouldn’t be) Punished for being successfulThe largest company of his or her life so farOptimized for maintaining the status quoWash away all the contextManager of oneThe proverbial JiraSubstantial contentMethods of moving forward