I was looking at code.golf the other day and I wondered which languages were the least verbose, so I did a little data gathering.

I looked at 48 different languages that had completed 79 different code challenges on code.golf. I then gathered the results for each language and challenge. If a “golfer” had more than 1 submission to a challenge, I grabbed the most recent one. I then dropped the top 5% and bottom 5% to hopefully mitigate most outliers. Then came up with an average for each language, for each challenge. I then averaged the results across each language and that is what you see here.

For another perspective, I ranked each challenge then got the average ranking across all challenges. Below is the results of that.

Disclaimer: This is in no way scientific. It’s just for fun. If you know of a better way to sort these results please let me know.

55 points

Java placed way better than I expected

permalink
report
reply
32 points

You can write concise Java. Just like you can write readable Haskell. It’s just not idiomatic to do so.

permalink
report
parent
reply
22 points

System.out.print("I agree.");

permalink
report
parent
reply
5 points
*

Don’t you mean:

class AgreementManagerClass {
    public static void main(String[] args) {
        System.out.println("I agree."); 
    }
}
permalink
report
parent
reply
14 points

It is always dismissed as too verbose, while in go’s case it is never mentioned, when in fact the latter is way more verbose… People’s bias show.

permalink
report
parent
reply
10 points

Maybe also bias by the number / experience of people using it.

1st semester students getting shocked by public static void main(String args) and meming it on the internet.

Go on the other hand likely isn’t a common choice / option for a first language.

permalink
report
parent
reply
8 points

I will gladly complain any day about go being terribly verbose.

permalink
report
parent
reply
1 point

Go’s less verbose than Java in my experience. And I’ve written quite a lot of both. But YMMV.

permalink
report
parent
reply
4 points

My mileage has indeed varied.

permalink
report
parent
reply
13 points

Code Golf rules allow people to submit an anonymous function instead of a full program, which eliminates a lot of the boilerplate.

permalink
report
parent
reply
10 points

They weren’t writing enterprise Java or they’d need a dozen factories and a few factory factories and probably a factory factory factory just to be safe.

permalink
report
parent
reply
3 points

Ya but then you’ll need a factory for all of those factories

permalink
report
parent
reply
3 points

You’re confused, I get it. You only need one factory factory as long as you sprinkle Inversion of Craziness (IoC) all over everything. Also, for this to work you must spread your code into as many files/directories as possible and also make sure you use really, really strict and verbose XML that doesn’t just define how your code runs but instead generates code itself.

I highly suspect the reason why Java didn’t seem to have as much code is because the authors were using proper enterprise Java which is mostly XML that can only be understood if your IDE takes at least 5 minutes to open and another 5 to open your project.

permalink
report
parent
reply
9 points

I don’t know the specifics of the golf problems, but I’m mostly in c#, also notorious for “having too much boilerplate,” and it looks like it’s 3rd by char count.

My guess is that languages with comprehensive standard libraries can do more with less custom code. As you should expect.

permalink
report
parent
reply
2 points

And yet C with its not at all comprehensive standard library did well. I’m a bit puzzled about these results.

There’s no way that Go is more verbose than Java. I’ve written both in decent quantities and Java was always way more verbose than Go for me. I suspect it’s the nature of code.golf giving these results more than the languages themselves.

permalink
report
parent
reply
5 points

I wonder if it’s all those variables named with single letter and abbreviations, so annoying to code review

permalink
report
parent
reply
5 points

String IDontKnowWhatsWorseEspeciallyWhenTheTypeIsAlsoIncludedString = “I don’t know what’s worse, especially when the type is also included”;

permalink
report
parent
reply
5 points

Honestly, I prefer an overly long name over some cryptic naming scheme that looks like minified JS. At least you can be sure of the variable’s purpose and don’t have to guess, which is far better for readability.

permalink
report
parent
reply
3 points

Yes, but it looks like it is already I think more than twice as verbose as Python.

permalink
report
parent
reply
2 points

What’s interesting to me is how differently C# scored vs Java.

permalink
report
parent
reply
31 points

I’d love to see the same comparison with more real-world use-cases.

Code golf, is mostly pretty simple use-cases, which have been optimized many times over.

When, you build out an application with a user-interface, proper event handling, etc… c++ is MUCH more verbose then c# for example, and they are ranked pretty close together.

permalink
report
reply
5 points

I think code golf is a great dataset for this kind of analysis specifically because they are artificial and people are paying attention to the number of characters used. Leetcode solutions might be a better option though.

In real world projects there are too many confounding factors. People aren’t implementing servers in brainfuck or websites in C. Even rewrites of a project into another language have more/fewer features. So it’s an apples to oranges comparison.

permalink
report
parent
reply
3 points

But a big problem with this dataset is error handling - or really the complete lack thereof. Real code needs to deal with errors and they can add a lot depending on the language.

I was very surprised to see rust and go so close as I find go vastly more verbose due to error handling and need to reimplement things like searching a list. But code golf type problems ignore these types of things that you see in real code.

So there is not really and useful conclusion that can be made except if you spend all day writing code golf problems.

permalink
report
parent
reply
1 point

That’s true, and you can also combine multiple errors to have a single catch block or handle each error separately. The perfect dataset for this comparison will need to be written. Code golf data is good enough for a non-academic fun analysis like this one.

permalink
report
parent
reply
24 points

Not expected C# to be this high. Also did not expected F# be so far away from C#.

permalink
report
reply
5 points

Yeah that seems suspicious. F# is pretty succinct.

permalink
report
parent
reply
7 points

My guess is that this is really a measure of how much abuse the language will tolerate. C# probably lets you get away with a bunch of things (like checking for nulls) that F# requires.

permalink
report
parent
reply
5 points

In newer versions of C# you can use top level statements, which remove a lot of characters

permalink
report
parent
reply
22 points

On another look, though, we have to keep in mind, though that this is code-golf, so in no way representative for actual code-bases.

permalink
report
reply
18 points

Haskell being so high really doesn’t make any sense. Experience level maybe?

It’s one of the tersest languages out there.

permalink
report
reply
10 points

Bash being so high is what confuses me.

Damn near everything is an acronym

permalink
report
parent
reply
9 points

I guess it takes more calls to different programs to do a task

permalink
report
parent
reply
7 points

It’s hard make such comparisons on “real world” code, and challenges use to be more attractive to people trying to learn, so your hypothesis make sense.

permalink
report
parent
reply

Programming

!programming@programming.dev

Create post

Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!

Cross posting is strongly encouraged in the instance. If you feel your post or another person’s post makes sense in another community cross post into it.

Hope you enjoy the instance!

Rules

Rules

  • Follow the programming.dev instance rules
  • Keep content related to programming in some way
  • If you’re posting long videos try to add in some form of tldr for those who don’t want to watch videos

Wormhole

Follow the wormhole through a path of communities !webdev@programming.dev



Community stats

  • 3.2K

    Monthly active users

  • 1.8K

    Posts

  • 30K

    Comments