DEV Community

Cover image for The Rise of Microsoft Visual Studio Code
Lyn Levenick for Triplebyte

Posted on with ammonb • Originally published at triplebyte.com

The Rise of Microsoft Visual Studio Code

tl;dr Visual Studio Code usage is rising rapidly! VS Code is now the editor chosen by the majority of engineers during programming interviews, and it appears to be rapidly taking market share from other top editors.

Triplebyte interviews hundreds of engineers every week. For each interview, we record the editor, language and operating system used. We don't use this information to decide who passes our interview (I don't think that would be fair). However, it is fascinating data! It gives us insight into which tools different cohorts of engineers prefer, and how these preferences change over time. It also allows us to identify correlations between the tools engineers choose and their performance during programming interviews.

My co-worker Mike wrote a post about this data a year ago. But Triplebyte has grown a LOT since then, and we now have enough data to dive much deeper. That's my goal for this blog post.

Editor Usage Rates

To get started, I pulled data on the editors used during all interviews conducted over the last year:

editor-popularity-margin.png

The first thing that jumps out from this graph is the prominence of Visual Studio Code. With 17% of the pie, VS Code was the editor used by the plurality of Triplebyte candidates last year. This was a surprise to me for two reasons. First, VS Code is a relatively new product from Microsoft, and, second, last year it didn't even appear on our charts—its share was small enough to fall into the “other” bucket.

To get a better view of this, I graphed the same data over time:

editor-popularity-over-time-margin.png

Yikes! VS Code is eating everyone else's lunch! The story here is pretty clear. Over the past year, VS Code usage has gone from 5% to 22%. Over the same time, Sublime Text usage has fallen from 17% to 11%, and Atom usage has fallen from 11% to 6%. Even Eclipse is falling. And VS Code is accelerating every month. Google Trends shows the same thing:

editor-popularity-google-trends-margin.png

VS Code is on the rise and is poised to become the most dominant editor we've ever seen. Maybe I should give it a try!

Interview Pass Rates

Editor usage is only one part of the story, however. Not all usage is equal. I wanted to see which editors are used by the best programmers. To look at that, I pulled data on how Triplebyte candidates performed during our interview, grouped by the editor they used:

editor-performance-margin.png This chart shows the rates at which each editor's users pass our interview compared to the mean pass rate for all candidates. First, notice the preeminence of Emacs and Vim! Engineers who use these editors pass our interview at significantly higher rates than other engineers. And the effect size is not small. Emacs users pass our interview at a rate 50% higher than other engineers. What could explain this phenomenon? One possible explanation is that Vim and Emacs are old school. You might expect their users to have more experience and, thus, to do better. However, notice that VS Code is the third best editor—and it is brand new. This undercuts that narrative a bit (and makes VS Code look even more dominant).

Do Emacs and Vim users have some other characteristic that makes them more likely to succeed during interviews? Perhaps they tend to be more willing to invest time and effort customizing a complex editor in the short-term in order to get returns from a more powerful tool in the long-term?

On the negative end, engineers who use Eclipse, intelliJ and Visual Studio pass our interview at lower rates. What do Eclipse, IntelliJ and Visual Studio have in common? Well, they are all IDEs. However, PyCharm is also a full-featured IDE, and it shows a high pass rate. What else could be going on? Another distinguishing feature of Eclipes, IntelliJ, and Visual Studio is their strong association with Java and C#, so might we merely be seeing the result of a correlation between specific editors and specific languages?

To investigate this, I looked at interview pass rates by language as well:

language-performance-margin.png Java and C# do have relatively low pass rates, although notice that Eclipse has a lower pass rate than Java (-21.4% vs. -16.7), so we cannot fully explain its poor performance as Java dragging it down.

Also, what's going on with Go? Go programmers are great! To dig deeper into these questions, I looked at editor usage by language:

editor-by-language-margin.png The percentages on this graph are per editor. So we can see, for example, that 97% of engineers using PyCharm program in Python (which makes sense — it's in the name). Eclipse is dominated by Java (94%) and Visual Studio is mostly C# and C++ (88%). I can't really say which way the causality goes, but it seems that both the languages (Java, C#) and the IDEs (Eclipse, Visual Studio) are associated with lower pass rates in interviews. This data comes from our internal interviews, but the same result holds for interviews conducted by the outside companies who use our platform.

Triplebyte does not take language or editor selection into account when making interview decisions. And there are tons of great C# and Java programmers out there (and we've helped many of them get jobs with companies on our platform). However, it seems that the average C# or Java engineer who goes through our process does less well than the average Ruby or Go engineer. I have no idea why.

Another finding from this chart is the difference between VS Code and Sublime. VS Code is primarily used for JavaScript development (61%) but less frequently for Python development (22%). With Sublime, the numbers are basically reversed (51% Python and 30% JavaScript). It's interesting that VS Code users pass interviews at a higher rate than Sublime engineers, even though they predominately use a language with a lower success rate (JavaSript).

Experience / Location

To wrap things up, I sliced the data by experience level and location. Here you can see language usage by experience level:

language-by-experience-margin.png Again, rows sum to 100%, so the chart shows what percentage of people with a given level of experience use each language. Most notable here is how popular Python and Java are among candidates with only internships or part time experience. Are we seeing folks who recently graduated from college using the languages in which they were taught?

Then there's editor usage by experience level:

editor-by-experience-margin.png First off, you can see VS Code usage dropping off as experience level increases. It's definitely more popular among junior engineers. You can also see that Vim and Emacs are more popular among more experienced engineers. It seems plausible that this is indeed the main reason why Vim and Emacs users have such a high pass rate in our interviews.

Finally, we looked at the relationship between location and language used:

language-by-location.png I like this chart for what it says about Bay Area geography. On the peninsula, where larger companies tend to be located, you see a lot of Java developers. In San Francisco, where startups dominate, you see more JavaScript.

Conclusions

Here's a summary of the trends in tool usage we saw over the past year along with some intriguing relationships between the tools engineers choose and their programming ability:

Visual Studio Code is on the rise. Over the past year, it has become the most popular editor across the board, and it's gaining ground every month. I wonder if the editor landscape is experiencing a tectonic shift, from a relatively fractured market to a world in which a single editor has over 50% of the market?

Engineers who use old school editors like Vim or Emacs tend to be strong programmers. That said, this finding may be best explained by the fact that these editors are especially popular among more experienced engineers.

Engineers who use Go are also especially strong. If you know why, please let me know.

Engineers who use Eclipse or Visual Studio do less well (on average) in our interviews. This correlation still stands for interviews with external companies who use our platform.

Take all of this with a grain of salt. I want to end by saying that we don't think any of this is causative. That is, I don't recommend that you start using Emacs and Go (or stop using Eclipse and Java) on the basis of this data. There are strong programmers who use every set of tools. The most important thing in any interview is using the tool that you are most comfortable with.

I would really appreciate your feedback. I have a lot of questions about this data, and I would love to know what other programmers think about what we've seen over the past year. Email Ammon at ammon@triplebyte.com or Lyn at lyn@triplebyte.com!

No matter which editor you choose, if you're an engineer interested in being matched with top tech companies in San Francisco, New York, Los Angeles, and/or Seattle, check out our process.

If you're a company interested in hiring great engineers, explore our platform!

Latest comments (65)

Collapse
 
mithereal profile image
Jason Clark • Edited

back in 2016 i was a phpstorm lover, but then a very very bad bug appeared, if the ide crashed it would index your entire home directory, including the phpstorm cache, this caused an infinite loop and nothing was usable, this issue still exists and theres over 1000 comments on the bug report for that specific issue, they arent even interested in fixing. so i said to myself im not paying for indexing when it goes on for 4 hrs at a time, causing me to fix the config file or just reinstall, it was just too much technical debit, and caused me serious issues with my employer.
so now i use vscode 100'%, its less buggy, kinda frustrating (nothing compared to phpstorm)
and i am no longer a php dev, just lotsa legacy php projects im converting to erlang.
thank gid im no longer a php dev, the amout of batshit crazy stuff ive seen in 20 years of php is mind boggeling.!!

Collapse
 
adam_cyclones profile image
Adam Crockett 🌀

Since Jetbrains products are amazing but highly specialised tools and not all purpose in quite the same way, like vscode, but perhaps the language behind the tool has a huge part in the market share, specialised tools I would expect to not be as popular unless the language is widespread.

Collapse
 
sollyucko profile image
Solomon Ucko

What about correlation with OS? Also, it might be interesting to see the raw, anonymized data so we can perform our own analyses.

 
jcabraham profile image
Jim Abraham

Yeah, I wrote that stuff too. 15 years before Linux. And -- editors are tools. You should use the right one for the job. If you're unfamiliar with a power tool, you might not appreciate it. I could go into detail, but I don't think I can do a better job than this famous post: gist.github.com/nifl/1178878

Thread Thread
 
jcabraham profile image
Jim Abraham

Oh, and Dennis Ritchie was talking about Unix, not Linux, which is of course just a flavor of Unix. Which is so ancient a tool that it powers just about everything. So, yeah, "modernity" is not a useful metric for anything.

Collapse
 
jcabraham profile image
Jim Abraham

If you're coding stuff in PHP, your editor is only your second problem....

Collapse
 
jcabraham profile image
Jim Abraham

I will say to you what Dennis Ritchie said about Unix, in the days when Apple and Windows were yet to be consumer products: those who do not understand Unix are doomed to reinvent it -- badly.

Emacs and Vim are so incredibly powerful that they do things most people, including programmers, did not realize were possible in an editor. You probably work incredibly inefficiently, but you don't even realize what you could not be doing.

Collapse
 
jcabraham profile image
Jim Abraham

I have many (many) years of experience with Perl and Java, with about five years experience in Python/Ruby/Scala. I started my career using Emacs (and vi), and Emacs is still my editor for almost everything. Many years ago a programmer wrote an article for Slate explaining how, in her experience, the Emacs and Vim people in the shop could always fix stuff the IDE people couldn't understand, because you can't have the IDE doing heavy lifting for you.

Nevertheless, when I started writing Java all day I ended up using an IDE -- not because Java itself requires it, but because one usually ends up so deep in the Java class libraries or third-party libraries that you need code inspection. And also because in the early days the IDEs would embed a servlet container and handle rebuilds and redeploys automatically. .NET (which is what people use Visual Studio for) is effectively the same.

For most Java programmers, that means that after several years they can't remember the syntax for anything. Since coding interviews inevitably (and foolishly) require actual working code, the Java people have a harder time of it.

Emacs does have pretty good code and even build integration, depending on the language, but for REPL languages (Perl, Ruby, Python, R, Go, Scala) it's usually sufficient to have the code in one buffer (an Emacs window) and the REPL in a shell buffer.

I suspect that Emacs and Vim people are better debuggers, especially, but that seems like the last thing most Google-wannabe companies care about in candidates.

Collapse
 
andev profile image
andev

Willing to give VS Code a try!

I used Vim when I first started coding, but quite honestly I'm not working as a programmer right now, so I haven't used it for quite a while; efficiency is not my highest priority right now, so I've been trying out multiple other solutions to see what works best for me.

I'm working very small code bases atm, mostly for automation purposes. I'm a jeweller and metalsmith these days, so most of my programming ends up producing ways to track processes (Nomie2 extensions), website guff, accounting automation, and 3D modelling automation. (And the very occasional ESO Addon).

I've been using Notepad++ forever for Python, and have been tempted by Visual Studio, which my partner works in these days (when he's not using Vim, that is). Np++ has been just sufficient for my needs for ages, but because of my change in career, I haven't bothered to find something better.


Using a tool because it is the latest thing out, or the oldest, or the trendiest, or whatever, doesn't make sense to me. Testing a tool to see if it works better for the individual or an integrated group makes way more sense. Traditions should be interrogated, but not thrown away just because they are old. Some traditions are still good! Some should be changed. Test, evaluate, make decisions :)

Also? Rubbishing other people's choices does not make you a comic genius. If you are ever lucky enough to work in the field of accessibility (one day, hopefully, this will include everyone), you'll find that no one person's brain works the same as any other, and that differing tools support different people.

Collapse
 
neochar profile image
neochar • Edited

People who say that IDE guys without their IDEs are nobody. Are you serious?
Why do you ever need to work without IDE? To work through ssh? There are tools created to get rid of working on server with ssh.

I prefer using Intellij IDEA with IdeaVim installed. Yes, I love Vim and I use it everyday in my console because I'm too lazy to setup deployment and earn some money to update my laptop to use IDEA 100%.

I use advantages of both sides: speed of moving through the code with Vim and code refactoring tools + context-based code completion from JetBrains. I really tried to setup comfortable Vim-based IDE but when it comes to everyday coding - there is nothing better than IDE which works on you.

While I'm writing a code with IDEA, in Vim/Neovim I have to deal with ctags problems, which is too stupid to send me to parent class method because there is a method with the same name in a file which has nothing to do with my current class. I need to setup my environment more and more in Vim/Neovim just to get what I already have in IDE out-of-box? Just to play Lego? No, thanks.

PS: sorry for my lack of English knowledge.

PPS: once again, I love Vim when I need to edit some small files / write little script / work through ssh / as IdeaVim plugin.

Collapse
 
pzelnip profile image
Adam Parkin

Really interesting read, though the headline is a bit click-baity. Really the interesting part of this article is more the analysis of the different correlations between editor usage & job applicants you saw, less that VS Code is on the rise (though as a VS Code user myself I'm happy to see that too). :)

Good stuff!

Collapse
 
awwsmm profile image
Andrew (he/him)

Really interesting! Thanks for posting!

Collapse
 
margobra8 profile image
Marcos G.

One of the reasons I think VS Code is popular is the fact that it’s fast compared to other fully-fledged IDEs. So if people are just starting to learn a new language or prototyping/experimenting, they just want it to be fast and efficient and avoid waiting for an IDE to load, so they use VS Code.

Collapse
 
mikeschinkel profile image
Mike Schinkel

JetBrain's IDEs are at 22.3% compared to 16.8% for VSCode.

IntelliJ + PyCharm + Android Studio are all different flavors of JetBrain IDEs, analogous to VSCode with different add-ons.

But grouping them together like this would not support the narrative you chose in the headline, so it seems obvious why you did not.

<sigh>

Collapse
 
neochar profile image
neochar

Moreover, PHPStorm is not pointed here.
When it comes to write PHP code - PHPStorm is #1 IDE and it is also JetBrain's product.

Collapse
 
mikeschinkel profile image
Mike Schinkel

lol, I should have mentioned PhpStorm too! Been using since before 1.0. :-)

Collapse
 
mikeschinkel profile image
Mike Schinkel

LOL, absolutely! :-D

Collapse
 
dazlari profile image
Darron Smith

It would be interesting to separate out those who pay for their editor or opt for the freebie.

There's a good reason VSCode is free - MS is gunning for the mind-share of the new developers which is way more valuable to them than just being notable for having the best editor.

They have successfully turned the ship on this one with VSCode. Look out for a paid for VSCodePro when they clear 50%. Developers, developers, developers...

Collapse
 
pzelnip profile image
Adam Parkin

Possibly, though given MS's focus on Azure & the cloud, I think they're less focussed on milking devs for software licenses & more on betting on cloud revenue. VSCode is very much in line with that vision as there's many tools for Azure & such that are either built in or easily installable by extension, so getting as many devs to use VS Code as possible supports the whole Azure play they're riding right now.

Collapse
 
johnkazer profile image
John Kazer

Azure has an in-browser simple version of VSC which is gradually gaining features. I reckon it will eventually be one and the same...