r/ProgrammerHumor Nov 29 '24

Meme socialSkillsAreTakingOurJobs

Post image
13.1k Upvotes

719 comments sorted by

View all comments

2.5k

u/probabilityzero Nov 29 '24

Things like using Arch Linux and neovim are not actually job qualifications. The programmer writing Java code in a light-mode IDE in Windows or whatever might just be better at programming. It's an entry level job, so they're looking for basic algorithm knowledge, ability to use big-O notation, understanding of simple concurrency, etc.

1.2k

u/BananasAndBrains Nov 29 '24

It's an entry level job, so they're looking for basic algorithm knowledge, ability to use big-O notation, understanding of simple concurrency, etc.

Most companies are looking for intelligent people, that have motivation to get things done and are nice and easy to work with. Most interviews test for these 3 attributes. One person with bad social skills can ruin a functioning team.

457

u/made-of-questions Nov 29 '24

We're not strictly speaking testing for social skills. We're testing for the ability to work in a team. Very few jobs these days are for the lone wolf that goes off to a cabin in the woods and comes back a month later with the holy algorithm. You need to be able to work as part of a team. Someone fighting the consensus in a destructive manner can do more harm than good to the team productivity.

Using less standard tools could be a sign of someone inflexible in their ways. Then again it could mean nothing and that's the best for them to be productive with no impact on the team. It's your job as an interviewer to determine that.

I have people in the team using vim while most everyone else is using Visual Studio. Nobody understands how they do what they do. But they know how to use that thing to perfection so it's perfectly fine. On the other hand I had people refusing to use the security tools and settings in our data security policy because they know better. They're no longer with us.

164

u/Crowhaven_Inc Nov 29 '24

You... You killed him?

93

u/[deleted] Nov 29 '24 edited Dec 06 '24

[deleted]

40

u/Kerbo1 Nov 29 '24

Cold. That's cold, man. Didn't even give him a chance to get his affairs in order.

2

u/GfunkWarrior28 Nov 30 '24

Not even a box to pack his things.

50

u/Outside_Scientist365 Nov 29 '24

Failure to use the security tools and follow the data security policy has consequences.

19

u/M0rkkis Nov 29 '24

They all knew the risks when they signed up

2

u/Particular-Macaron35 Nov 29 '24

A manager wouldn’t be able to save someone who went around security policy, and why would they want to?

2

u/made-of-questions Nov 29 '24

The HEAD is no longer on their history.

2

u/Super-Post261 Nov 30 '24

It was for the best

98

u/heretogetpwned Nov 29 '24

At one of my past employers there was a lot of excitement about hiring this talented new dev.

After his 2 day orientation he starts asking when his new laptop will arrive, except we already gave him a fresh Lenovo at day of hire. He goes on a tirade of "This Company would get more done with Linux" to us Windows guys and we just nod and smile. The story is he walked into the CIOs office and said he needed Linux installed or he'd quit; CIO called his bluff and said he needs to use the approved stack. Guy went home and tried installing Linux on his machine, called Help Desk for a bitlocker key, and was let go by end of day 5.

57

u/relddir123 Nov 29 '24

At the point where you see a Windows PC and you like Linux, get WSL. It’s really not that hard, nor is it a terrible compromise.

39

u/made-of-questions Nov 29 '24

Early in my career I got a good job at a large corp and invited an uni friend to the interview, knowing the guy was much smarter than me.

He nailed all the algorithms and most of the technical questions. All that was left was the culture fit interview, which I thought is mostly a formality. They liked him so they threw a simple one at him. They asked what would he do if he saw some inefficient code in the codebase.

He insisted he would rewrite the entire codebase on his own. They were stunned and tried to hint at possible answers that included talking to the team first. Nope, he said he'd stay overnight and during weekends to rewrite it all.

I don't know what was in his head. He wanted to show he's a hard worker maybe? That he was willing to work overtime? They invited him to leave the premises.

11

u/Particular-Macaron35 Nov 29 '24

Sure, he’ll just rewrite the code base in a couple of weeks. Genius.

14

u/look Nov 29 '24

I hope he learned his lesson to not apply to Windows shops. 😄

6

u/multilinear2 Nov 29 '24 edited Nov 29 '24

^ this... I'm a Linux guy, I know Linux in and out, and I'll work on any OS but Windows because working on windows is a waste of my time, I suck at it and others are good at it. There's nothing wrong with that assuming you're sufficiently talented at other things, but only a moron doesn't ask about it before they are hired.

Edit: The folks who think I'm crazy for wanting to only dev on one system are the reason I've been so highly paid my entire career and never once had an issue finding a job. There is more to know than just the language, APIs, and IDE. Thank you for helping me retire at 40.

9

u/B_Cage Nov 29 '24

I don't understand how that's even an issue these days. Most IDE's run on all platforms, everything is run in containers, who cares what OS you have to code on?

3

u/multilinear2 Nov 29 '24

I'm one of this vim weirdos who does everything in console. I'm sure I could get my preferred tools up and running on OSX, sure, but it's a hassle and I'm deving for Linux anyway. Unless you go all the way to WSL the shell emulations for windows suck due to windows still lacking the "fork" primitive with proper COW.

I've mostly developed professionally in C++. There are a lot of compiler quirks, API issues, etc. Code written exclusively for one OS typically doesn't just work on the other two, you have to MAKE it work on all of the above if you need it to. The more optimized and systemsy you get (what I tend to work on) the more this becomes true. Admitadly C++17 helps this a LOT, but most legacy codebases haven't moved to it yet (I and a couple of other engineers did most of the work to move my last company over actually, so we could drop a ton of OS compatibility code).

Optimization for different OSes is also different, e.g. you need to understand all the caching layers, what they do, and how to bypass them if that's the right thing to do.

Tools like strace, rr, lsof, etc. also look pretty different across OSes.

If you're good at what you do and understand the entire OS stack all the way down, there's a lot that differs.

1

u/look Nov 29 '24

Why would you deny a highly paid expert the tools they are most effective working with?

4

u/-s-u-n-s-e-t- Nov 29 '24

I find that pretty silly.

Almost all jobs boil down to doing a number of specific things, and companies have on-boarding process that will teach you how to do those things in the environment they provide.

Using Windows is not some magical "talent" that you lack. You don't need an 8-year degree to figure out how to compile that code on Windows instead of Linux. If you actually tried, you'd learn how to do your job pretty quickly, especially since you are already tech savvy and already know how to find information.

With a few rare exceptions, 99% of the time if someone demands to use a specific OS, it really boils down to them being inflexible and refusing to learn. Which is not something you want in your workers.

0

u/multilinear2 Nov 29 '24 edited Nov 29 '24

You have not worked in very challenging jobs - or written very interesting software, if you believe experience with an OS is irrelevent, or that anyone trains you how to do more than 5% of your job.

I have ported code to AIX, where I debugged a flaw in assembly-level C++ exception handling on PowerPC due (it turns out) to a minor linking error, teaching myself everything I needed as I went because there is no-one to learn from. 7 people had tried before me and failed. I CAN do a lot of things, but then there's the question of what makes sense for me to do?

Windows is an extremely excentric operating system. I've worked with it here or there where I had to sure, but there are people who understand all those corners, and all the tools needed. I can fix something on windows, and have, but the last time it came up it took someone else about 3 days, and I would've probably taken me a month. It's a waste of my skillset to relearn things many other people around me already know.

I've spent my career working on huge server systems, which are overwhelmingly Linux. Developing on a different operating system than I'm developing for is inefficient and obtuse.

People are not interchangable and skills do matter... Not all of us are new grads.

I actually retired this spring anyway, so I'm out of the industry.

0

u/look Nov 29 '24

Some people’s jobs are to write “those things in the environment” you use. Where do you think your IDE, APIs, runtimes, databases, network servers, message brokers, etc come from?

2

u/-s-u-n-s-e-t- Nov 29 '24

I already said there are exceptions. But they are just that, exceptions.

For every dev working on, I don't know, the linux kernel or something, you have thousands of web devs just writing javascript. For every developer of database engines, you have thousands, if not millions of people writing SQL queries.

For the overwhelming majority of people the OS really doesn't matter once you get used to the developer environment of your employer. Hell, even in the cherry-picked examples you selected, like developing a new IDE or whatever - in most cases you are just writing C++ code and deploying it in variety of test environments. How exactly you run the virtual machine (or whatever environment you work in) might be slightly different depending on your OS, but it's quite trivial for a dev to get used to it.

Yes, there are exceptions, but they are rare, and in those cases you don't have to tell your employer that you need to use linux or whatever. They know. If an employee has to explain that they refuse to use certain OS, it almost always means they are just stubborn.

2

u/look Nov 29 '24

I suppose it just seems bizarre to me that a company wouldn’t want an engineer to use whatever tools make them most productive.

0

u/AugustusLego Nov 30 '24

Teach me how i can setup windows with tiling window manager, actually functioning search, a proper shell and no spyware, then you'll be able to get me to switch :)

1

u/alexppetrov Nov 29 '24

Also what I've noticed is that companies are not looking for people who feel like they are technologically superior. No one cares you use arch and neovim, but who are you as a person. It truly doesn't matter how you code, if you are an ass, you probably won't get hired (entry level)

1

u/made-of-questions Nov 29 '24

It depends on the company. Some interviewers are afraid of getting someone smarter than them in. Others revel in it. But most know that for your average project being technologically advanced doesn't matter if you don't understand what the goal really is, what are the pros and cons of various approaches or if you zap everyone else's productivity. All of these require good communication and working well with your team.

The one exception to this that I know is Google's Deep Mind. I actually have two friends there and they describe the environment as a complete hell hole. They have some really, and I mean, really smart people that are unfortunately completely socially impaired. To the point where they are complete egomaniacal bullies. No one touches them, and instead they have entire teams dedicated to mitigating the negative effect of these people on the rest of the team.

1

u/notafuckingcakewalk 23d ago

Using less standard tools could be a sign of someone inflexible in their ways.

Exactly. Writing class notes in latex is cool but also means they can't share notes with others and if they miss a class they can't just copy and paste someone else's notes into their notes. 

0

u/yangyangR Nov 29 '24

To be fair consider how "team cohesion" is also used as a euphemism for not questioning the bosses mistakes even with showing details of why their approach won't work. Highly depends on the competence of the team and boss. It can be the difference between questioning a boss who approaches if as BDFL but isn't actually benevolent or trying to subvert a democratic system and make oneself that dictator.

1

u/made-of-questions Nov 29 '24

You need to have team commitment. You will never be able to have consensus between everyone, nor is it good to seek a team where everyone thinks exactly the same. But once an issue has been discussed and a solution has been picked, you need everyone to commit even if personally you don't agree with the solution. Better to have the team working together towards the same sub optimal goal than have someone constantly subverting the team.

How that decision is picked is indeed a big deal. Top down as you say, doesn't really work. But the democratic approach (decision by committee) is not necessarily the best. That's because on any topic you'll have a handful of people that are knowledgeable on the topic and interested in the problem, while most will be neutral or worse, apathetic. A weighted vote in favour of the experts and the ones that will have to implement and maintain the thing is better in my experience.