Details
- 
						AboutI like Java and C#
- 
						SkillsNothing which would be mentionable here.
Joined devRant on 12/8/2017
			Join devRant
Do all the things like
				++ or -- rants, post your own rants, comment on others' rants and build your customized dev avatar
				Sign Up
			Pipeless API
 
				From the creators of devRant, Pipeless lets you power real-time personalized recommendations and activity feeds using a simple API
				Learn More
			
- 
				    
				    A cracker just fell under my desk.
 
 I cannot find it.
 
 It's not possible that the cracker traveled farther than everywhere I looked.
 
 But I still can't find it.19
- 
				    
				    "Failure is not an option. It comes bundled with your Microsoft Product."
 
 - Wise Old Man
 
 (Taken from ebtionko.wordpress.com)
- 
				    
				    As a developer, sometimes you hammer away on some useless solo side project for a few weeks. Maybe a small game, a web interface for your home-built storage server, or an app to turn your living room lights on an off.
 
 I often see these posts and graphs here about motivation, about a desire to conceive perfection. You want to create a self-hosted Spotify clone "but better", or you set out to make the best todo app for iOS ever written.
 
 These rants and memes often highlight how you start with this incredible drive, how your code is perfectly clean when you begin. Then it all oscillates between states of panic and surprise, sweat, tears and euphoria, an end in a disillusioned stare at the tangled mess you created, to gather dust forever in some private repository.
 
 Writing a physics engine from scratch was harder than you expected. You needed a lot of ugly code to get your admin panel working in Safari. Some other shiny idea came along, and you decided to bite, even though you feel a burning guilt about the ever growing pile of unfinished failures.
 
 All I want to say is:
 
 No time was lost.
 
 This is how senior developers are born. You strengthen your brain, the calluses on your mind provide you with perseverance to solve problems. Even if (no, *especially* if) you gave up on your project.
 
 Eventually, giving up is good, it's a sign of wisdom an flexibility to focus on the broader domain again.
 
 One of the things I love about failures is how varied they tend to be, how they force you to start seeing overarching patterns.
 
 You don't notice the things you take back from your failures, they slip back sticking to you, undetected.
 
 You get intuitions for strengths and weaknesses in patterns. Whenever you're matching two sparse ordered indexed lists, there's this corner of your brain lighting up on how to do it efficiently. You realize it's not the ORMs which suck, it's the fundamental object-relational impedance mismatch existing in all languages which causes problems, and you feel your fingers tingling whenever you encounter its effects in the future, ready to dive in ever so slightly deeper.
 
 You notice you can suddenly solve completely abstract data problems using the pathfinding logic from your failed game. You realize you can use vector calculations from your physics engine to compare similarities in psychological behavior. You never understood trigonometry in high school, but while building a a deficient robotic Arduino abomination it suddenly started making sense.
 
 You're building intuitions, continuously. These intuitions are grooves which become deeper each time you encounter fundamental patterns. The more variation in environments and topics you expose yourself to, the more permanent these associations become.
 
 Failure is inconsequential, failure even deserves respect, failure builds intuition about patterns. Every single epiphany about similarity in patterns is an incredible victory.
 
 Please, for the love of code...
 
 Start and fail as many projects as you can.30
- 
				    
				    *code doesn't work*
 
 -Run three times, just to be sure
 -Its NOT the code, must be the project. Full rebuild.
 -Run a few more times after rebuild didn't fix it.
 -Google the issue.
 -Stackoverflow must be wrong. The code is JUST like their solution.
 -Run a few more times, but with your lucky underpants
 -Reboot. Must be an operating system thing.
 -Tea break. Give the issue time and it will fix itself.
 -Run a few more times. Still unfixed
 -Contact customer support.
 -Walmart said they can't help.
 -Consider writing your own language without this OBVIOUS flaw
 -Kickstarter for c++++
 -Raise $50,000
 -Start a family
 -Contact customer support again
 -Run a few more times
 -Now banned from Walmart
 -Oh shit, missing a semicolon24
- 
				    
				    Actual conversation:
 - Vim has weird commands. For instance, you copy by typing "Y".
 - Why?
 - Correct.3
- 
				    
				    Let's install some Addons! Hmm where is that menu item... oh could it be called Extensions? No? Wait... maybe Plugins then?
 
 Maybe it's inside of a Settings window. Oh there's nothing called settings in this endless menu I think. Or is it called Preferences? Options? Properties? Configuration? Ugh and should I look in the File or Edit or Extra menu in this App, Application and/or Program?
 
 Maybe I can Search for it?
 
 OH YOU FUCKING NAMED THAT FIND INSTEAD OF SEARCH, YOU PRESUMPTUOUS PRICK, I CAN'T FUCKING FIND ANYTHING IN YOUR BLOATED GOO OF A GUI.
 
 *scrambles back into his bash-shell like a hermit crab, making soft defensive noises*8
- 
				    
				    HR Requirements:
 - Must have an active social life with hobbies and interests outside work.
 Dev Requirements
 - Must have an active GIT hub profile to the point that you couldn't possibly have a social life5
- 
				    
				    Enough of this!!! I need a break.
 *Gets up partially from chair*
 *Looks back at the code, gets an idea*
 *Sits down again for couple of hours*4
- 
				    
				    "Windows is better than Java".
 
 A classmate literally screamed that out in class.
 He'd heard me often bash Windows, I was just in the middle of a friendly debate about Java with the professor, so in a desperate attempt to get attention, his brain concocted this diarrhea of a sentence. And he doesn't even know how stupid what he said was.15
- 
				    
				    Yesterday: Senior dev messages out a screenshot of someone using an extension method I wrote (he didn’t know I wrote it)..
 
 SeniorDev: “OMG…that has to be the stupidest thing I ever saw.”
 Me: “Stupid? Why?”
 SeniorDev: “Why are they having to check the value from the database to see if it’s DBNull and if it is, return null. The database value is already null. So stupid.”
 Me: “DBNull is not null, it has a value. When you call the .ToString, it returns an empty string.”
 SeniorDev: ”No it doesn’t, it returns null.”
 <oh no he didn’t….the smack down begins>
 Me: “Really? Are you sure?”
 SeniorDev: “Yes! And if the developer bothered to write any unit tests, he would have known.”
 Me: “Unit tests? Why do you assume there aren’t any unit tests? Did you look?”
 <at this moment, couple other devs take off their head phones and turn around>
 SeniorDev:”Well…uh…I just assumed there aren’t because this is an obvious use case. If there was a test, it would have failed.”
 Me: “Well, let’s take a look..”
 <open up the test project…navigate to the specific use case>
 Me: “Yep, there it is. DBNull.Value.ToString does not return a Null value.”
 SeniorDev: “Huh? Must be a new feature of C#. Anyway, if the developers wrote their code correctly, they wouldn’t have to use those extension methods. It’s a mess.”
 <trying really hard not drop the F-Bomb or two>
 Me: “Couple of years ago the DBAs changed the data access standard so any nullable values would always default to null. So no empty strings, zeros, negative values to indicate a non-value. Downside was now the developers couldn’t assume the value returned the expected data type. What they ended up writing was a lot of code to check the value if it was DBNull. Lots of variations of ‘if …’ , ternary operators, some creative lamda expressions, which led to unexpected behavior in the user interface. Developers blamed the DBAs, DBAs blamed the developers. Remember, Tom and DBA-Sam almost got into a fist fight over it.”
 SeniorDev: “Oh…yea…but that’s a management problem, not a programming problem.”
 Me: “Probably, but since the developers starting using the extension methods, bug tickets related to mis-matched data has nearly disappeared. When was the last time you saw DBA-Sam complain about the developers?”
 SeniorDev: “I guess not for a while, but it’s still no excuse.”
 Me: “Excuse? Excuse for what?”
 <couple of awkward seconds of silence>
 SeniorDev: “Hey, did you guys see the video of the guy punching the kangaroo? It’s hilarious…here, check this out.. ”
 
 Pin shoulders the mat…1 2 3….I win.6
- 
				    
				    Everyone here ranting about a fucking missing semicolon. I can't remember the last time a missing semicolon was the issue...
 
 You wanna know what's REALLY BALL-BUSTING????
 
 WHEN THE FUCKING 10 y/o LEGACY CODEBASE, CODED BY FUCKING PHP WORDPRESS SCRIPTERS WHO THOUGHT THEY COULD BUILD AN ENTERPRISE SHIT CAUSE ZF2 "LOOKS EASY" AND THEN FILL IT UP WITH SPAGHETTI, IS SO BAD WRITTEN THAT IN ORDER FOR THE PAGE TO RENDER YOU ACTUALLY ****HAVE**** TO DISABLE ERROR REPORTING SO WHENEVER A FUCKING ERROR HAPPENS ON THE TEMPLATE RENDER COMPONENT OF ZEND FRAMESHIT 2, YOU'RE LEFT WITH A FUCKING BLANK PAGE AND NOTHING IS LOGGED TO THE LOG FILE, SO YOUR ONLY OPTION IS DIE() DEBUGGING LINE BY LINE ON THE 1300 LINES PHTML FUCKFEST OF A VIEW THEY HAVE.
 
 MISSING SEMICOLON? YES PLEASE, GIVE ME MORE OF THAT SHIT37
- 
				    
				    Dear people who complain about spending a whole night to find a tiny syntax error; Every time I read one of your rants, I feel like a part of me dies.
 
 As a developer, your job is to create elegant optimized rivers of data, to puzzle with interesting algorithmic problems, to craft beautiful mappings from user input to computer storage and back.
 
 You should strive to write code like a Michelangelo, not like a house painter.
 
 You're arguing about indentation or getting annoyed by a project with braces on the same line as the method name. You're struggling with semicolons, misplaced braces or wrongly spelled keywords.
 
 You're bitching about the medium of your paint, about the hardness of the marble -- when you should be lamenting the absence of your muse or the struggle to capture the essence of elegance in your work.
 
 In other words:
 
 Fix your fucking mindset, and fix your fucking tools. Don't fucking rant about your tabs and spaces. Stop fucking screaming how your bloated swiss-army-knife text editor is soooo much better than a purpose-built IDE, if it fails to draw something red and obnoxious around your fuck ups.
 
 Thanks.62
- 
				    
				    An entirely typical exchange at work:
 
 PM: How long would it take to build an application that collates Gubblefluffs and exports them as a PDF?
 
 ME: Hard to say. What’s a Gubblefluff?
 
 PM: Nothing complex. Its basically an object with some stuff in.
 
 ME: Erm, okay. So I’ll define a Gubblefluff object plus methods to add edit and delete, then for each Gubblefluff have it write a line to a PDF.
 
 PM: It will need to email that PDF to somebody.
 
 ME: Okay, cool. “Gubblefluffs-by-email” should take about a day.
 
 6 hours later…
 
 ME: I’ve done Gubblefluffs-to-pdf, I’m not clear on what’s in a Gubblefluff but I’ve made it flexible so it can take almost anything.
 
 PM: No, a Gubblefluff can ONLY be one of 4 Snigglefingers plus a timestamp and some JSON.
 
 ME: What? Right. Okay. What’s a Snigglefinger?
 
 PM: (sighs) A Snigglefinger is the collection of relevant Babelsets.
 
 ME: Babelsets?
 
 PM: Yeah, a user can have any number of Babelsets but they must correspond to one of the four types of Snigglefingers.
 
 ME: There are users!?
 
 PM: Of course!
 
 ME: But I’ve not coded anything for users.
 
 PM: Shit. I’ve told the client they can have it today. How long to add in users?
 
 ME: And Babelsets, and Snigglefingers and the new Gubblefluff rules?
 
 PM: Yeah.
 
 6 days later…
 
 ME: This is done now. It’s a beast but it works. Who should it email the PDFs to?
 
 PM: Client X, plus cc to Y and bcc to Z.
 
 ME: What? It doesn't support CC and BCC!
 
 1 hour later…
 
 ME: This is done. I’ve tested it and sent you a copy of the PDF it generates.
 
 PM: Okay thanks. Is the cron running daily?
 
 ME: What cron?
 
 …
 
 ME: Okay, so the cron’s running once a day at 8pm.
 
 PM: Oh, it’ll need to be at 3:15pm. That’s when we’ve told the client they’ll get it.
 
 ME: Right. I’ll change it...
 
 PM: Also, the PDF you sent me looks nothing like the visual.
 
 ME: What visual?
 ...53
- 
				    
				    I went to Paris for my first interview (that was 1989) for a job of Unix kernel developer. All dressed up. I step out of the elevator and see a young punk with scruffy hair and different colour shoes. I reckon he must be the pizza delivery guy. I ask him "dude, can you please point me to the CEO's office for interview". He said "sure, follow me man, I'll show you". We arrive at a desk, he sat down in the big chair and looks at me with a big smile and says "Ok dude, here we are. I am the CEO. Now let's see how good you are!"
 I got the job. And 26 years latet, last week, amazing coincidence: I met him again at a trade show in Paris ... with the same coloured shoes. How cool is that!!! 29 29
- 
				    
				    Interviewer: Welcome, Mr X. Thanks for dropping by. We like to keep our interviews informal. And even though I have all the power here, and you are nothing but a cretin, let’s pretend we are going to have fun here.
 
 Mr X: Sure, man, whatever.
 
 I: Let’s start with the technical stuff, shall we? Do you know what a linked list is?
 
 X: (Tells what it is).
 
 I: Great. Can you tell me where linked lists are used?
 
 X:: Sure. In interview questions.
 
 I: What?
 
 X: The only time linked lists come up is in interview questions.
 
 I:: That’s not true. They have lots of real world applications. Like, like…. (fumbles)
 
 X:: Like to implement memory allocation in operating systems. But you don’t sell operating systems, do you?
 
 I:: Well… moving on. Do you know what the Big O notation is?
 
 X: Sure. It’s another thing used only in interviews.
 
 I: What?! Not true at all. What if you want to sort a billion records a minute, like Google has to?
 
 X: But you are not Google, are you? You are hiring me to work with 5 year old PHP code, and most of the tasks will be hacking HTML/CSS. Why don’t you ask me something I will actually be doing?
 I: (Getting a bit frustrated) Fine. How would you do FooBar in version X of PHP?
 
 X: I would, er, Google that.
 
 I: And how do you call library ABC in PHP?
 
 X: Google?
 
 I: (shocked) OMG. You mean you don’t remember all the 97 million PHP functions, and have to actually Google stuff? What if the Internet goes down?
 
 X: Does it? We’re in the 1st world, aren’t we?
 
 I: Tut, tut. Kids these days. Anyway,looking at your resume, we need at least 7 years of ReactJS. You don’t have that.
 
 X: That’s great, because React came out last year.
 
 I: Excuses, excuses. Let’s ask some lateral thinking questions. How would you go about finding how many piano tuners there are in San Francisco?
 
 X: 37.
 
 I: What?!
 
 X: 37. I googled before coming here. Also Googled other puzzle questions. You can fit 7,895,345 balls in a Boeing 747. Manholes covers are round because that is the shape that won’t fall in. You ask the guard what the other guard would say. You then take the fox across the bridge first, and eat the chicken. As for how to move Mount Fuji, you tell it a sad story.
 
 I: Ooooooooookkkkkaaaayyyyyyy. Right, tell me a bit about yourself.
 
 X: Everything is there in the resume.
 
 I: I mean other than that. What sort of a person are you? What are your hobbies?
 
 X: Japanese culture.
 
 I: Interesting. What specifically?
 
 X: Hentai.
 
 I: What’s hentai?
 
 X: It’s an televised art form.
 
 I: Ok. Now, can you give me an example of a time when you were really challenged?
 
 X: Well, just the other day, a few pennies from my pocket fell behind the sofa. Took me an hour to take them out. Boy was it challenging.
 
 I: I meant technical challenge.
 
 X: I once spent 10 hours installing Windows 10 on a Mac.
 
 I: Why did you do that?
 
 X: I had nothing better to do.
 
 I: Why did you decide to apply to us?
 
 X: The voices in my head told me.
 
 I: What?
 
 X: You advertised a job, so I applied.
 I: And why do you want to change your job?
 
 X: Money, baby!
 
 I: (shocked)
 
 X: I mean, I am looking for more lateral changes in a fast moving cloud connected social media agile web 2.0 company.
 
 I: Great. That’s the answer we were looking for. What do you feel about constant overtime?
 
 X: I don’t know. What do you feel about overtime pay?
 
 I: What is your biggest weakness?
 
 X: Kryptonite. Also, ice cream.
 
 I: What are your salary expectations?
 
 X: A million dollars a year, three months paid vacation on the beach, stock options, the lot. Failing that, whatever you have.
 
 I: Great. Any questions for me?
 
 X: No.
 
 I: No? You are supposed to ask me a question, to impress me with your knowledge. I’ll ask you one. Where do you see yourself in 5 years?
 
 X: Doing your job, minus the stupid questions.
 
 I: Get out. Don’t call us, we’ll call you.
 
 All Credit to:
 http://pythonforengineers.com/the-p...89
- 
				    
				    !rant
 
 After over 20 years as a Software Engineer, Architect, and Manager, I want to pass along some unsolicited advice to junior developers either because I grew through it, or I've had to deal with developers who behaved poorly:
 
 1) Your ego will hurt you FAR more than your junior coding skills. Nobody expects you to be the best early in your career, so don't act like you are.
 
 2) Working independently is a must. It's okay to ask questions, but ask sparingly. Remember, mid and senior level guys need to focus just as much as you do, so before interrupting them, exhaust your resources (Google, Stack Overflow, books, etc..)
 
 3) Working code != good code. You are an author. Write your code so that it can be read. Accept criticism that may seem trivial such as renaming a variable or method. If someone is suggesting it, it's because they didn't know what it did without further investigation.
 
 4) Ask for peer reviews and LISTEN to the critique. Even after 20+ years, I send my code to more junior developers and often get good corrections sent back. (remember the ego thing from tip #1?) Even if they have no critiques for me, sometimes they will see a technique I used and learn from that. Peer reviews are win-win-win.
 
 5) When in doubt, do NOT BS your way out. Refer to someone who knows, or offer to get back to them. Often times, persons other than engineers will take what you said as gospel. If that later turns out to be wrong, a bunch of people will have to get involved to clean up the expectations.
 
 6) Slow down in order to speed up. Always start a task by thinking about the very high level use cases, then slowly work through your logic to achieve that. Rushing to complete, even for senior engineers, usually means less-than-ideal code that somebody will have to maintain.
 
 7) Write documentation, always! Even if your company doesn't take documentation seriously, other engineers will remember how well documented your code is, and they will appreciate you for it/think of you next time that sweet job opens up.
 
 8) Good code is important, but good impressions are better. I have code that is the most embarrassing crap ever still in production to this day. People don't think of me as "that shitty developer who wrote that ugly ass code that one time a decade ago," They think of me as "that developer who was fun to work with and busted his ass." Because of that, I've never been unemployed for more than a day. It's critical to have a good network and good references.
 
 9) Don't shy away from the unknown. It's easy to hope somebody else picks up that task that you don't understand, but you wont learn it if they do. The daunting, unknown tasks are the most rewarding to complete (and trust me, other devs will notice.)
 
 10) Learning is up to you. I can't tell you the number of engineers I passed on hiring because their answer to what they know about PHP7 was: "Nothing. I haven't learned it yet because my current company is still using PHP5." This is YOUR craft. It's not up to your employer to keep you relevant in the job market, it's up to YOU. You don't always need to be a pro at the latest and greatest, but at least read the changelog. Stay abreast of current technology, security threats, etc...
 
 These are just a few quick tips from my experience. Others may chime in with theirs, and some may dispute mine. I wish you all fruitful careers!226
- 
				    
				    A young guy I work with burst into tears today, I had no idea what happened so I tried to comfort him and ask what was up.
 
 It appears his main client had gone nuts with him because they wanted him to make an internet toolbar (think Ask.com) and he politely informed them toolbars doesn't really exist anymore and it wouldn't work on things like modern browsers or mobile devices.
 
 Being given a polite but honest opinion was obviously something the client wasn't used to and knowing the guy was a young and fairly inexperienced, they started throwing very personal insults and asking him exactly what he knows about things (a lot more than them).
 
 So being the big, bold, handsome senior developer I am, I immediately phoned the client back and told them to either come speak to me face-to-face and apologise to him in person or we'd terminate there contract with immediate effect. They're coming down tomorrow...
 
 So part my rant, part a rant on behalf of a young developer who did nothing wrong and was treated like shit, I think we've all been there.
 
 We'll see how this goes! Who the hell wants a toolbar anyway?!414
- 
				    
				    "Coding is solving puzzles".
 
 I think everyone has heard that platitude. But it's not exactly right.
 
 So I grew up in a very poor environment, a moldy building full of jobless addicts.
 
 And in my town there was this shop where super poor parents could take their kids to borrow free toys and stuff.
 
 So as a kid I remember being frustrated by these second hand jigsaw puzzles, because there were always a few pieces which had been teared up or chewed on, or were even completely missing.
 
 That is what development is.
 
 You pull in this seemingly awesome composer package, and that one super useful method is declared private, so you need to fork the whole thing.
 
 Your coworker has built this great microservice in python, but instead of returning 404 not found, it returns 200 with json key/value saying "error": "not found".
 
 There's a shitload of nicely designed templates for the company website, but half of them have container divs inside the components, the other half expect to be wrapped in container divs when included.
 
 You're solving puzzles, but your peers are all brainless jigsaw-piece-chewers. They tried to mend a problem, but half way through got distracted, hungry and angry, started drooling over the task and used a hammer to fit in the remaining stuff.11
- 
				    
				    I'd never imagine that my interests would shift from webapps and servers to embedded devices and measuring 500volts with an arduino....1
- 
				    
				    When you remember code from last night in the middle of your day and you know exactly where you fucked up.3

 
		
		
	



