Looks like you have a pretty good list already, depending on how much they
love Scala, they may/may not invalidate some of your points but you know
them better.

On Sun, Feb 19, 2017 at 2:37 AM, Will Faught <will.fau...@gmail.com> wrote:

> Thanks to the two replies so far! Very helpful.
>
> Here are the reasons I'd thought of before sending the question. I don't
> know Scala, so maybe some of these aren't advantages relative to Scala in
> particular; if so, please let me know. Ideas and feedback are much
> appreciated!
>
> # Concurrency and parallelism
>
> - Simple, well-defined concurrency memory model
>     - Happens-before guarantees for channel sending and receiving
>     - Lock and atomic primitives
>     - Built-in build/test data race detector
>     - Goroutines (lightweight/green threads)
>     - Part of the language
>     - Small and fast (4 KB in memory, no context switching)
>     - Multiplexed onto all processor cores for automatic parallelism
> - Channels
>     - Part of the language
>     - Simple send/receive/close semantics
>     - Concurrent sends and receives are safe
>     - Buffered and unbuffered
>     - Send any type, even other channels
>     - Enable concurrent composition of components (think pipelines, fan
> out/in)
> - Orchestration
>     - Built-in support for orchestrating concurrent work
>     - Work deadlines, timeouts, and cancellations that can span APIs and
> processes
>     - Concurrent code looks synchronous
>     - No callbacks, promises, or futures
> - Performance
>     - Fast, native, statically-linked builds
>     - Small disk and memory footprints (basic server: 11 MB on disk and
> 2.3 MB in memory)
>     - GC pauses are usually under 100 microseconds and often as low as 10
> microseconds
>     - GC tuning unnecessary and GC performance scales with memory size
> automatically
>     - Hundreds of thousands of goroutines per process is practical
>     - All tests can run in parallel
>     - Regexps are guaranteed to run in time linear to the size of the input
>
> # Tooling
>
> - Easy development: quick and simple to clone repos and then build, test,
> and run code
> - Single command-line tool that does everything
> - Built-in testing, benchmarking, profiling, package managing,
> documentation, coverage
> - Code buildable from source alone; no third-party build tool (make, ant)
> needed
> - Fast builds (object files are cached; only changed code is rebuilt)
> - Cross compilation for various operating system and architectures
> - Deploying an executable is just copying a single file
> - Thorough, official language spec and standard library documentation
> - Modern standard library with built-in transport clients/servers and
> encoders/decoders
> - Simple build tag logic with file name suffixes and file comments
> - Built-in dependency vendoring
> - Built-in code formatter and linter
> - Built-in code generation
> - Clean builds (no warnings or logs; successful builds print nothing; no
> build artifacts)
>
> # Design
>
> - Uses interface composition, not class inheritance; avoids complex type
> hierarchies
> - Built-in equality/comparisons and hashing
> - Simple package model for encapsulation and distribution/use
> - Unit tests for service interfaces can double as integration tests
>
> On Friday, February 17, 2017 at 10:55:37 PM UTC-8, Will Faught wrote:
>>
>> I want to make the case to a software architect where I work that we
>> should write some fast, high-load servers we need in Go rather than Scala.
>> What pragmatic arguments should I use?
>>
>> Note that the architect isn't against ever using Go; the question is
>> whether to use Go now, for these servers in particular. Not much detail has
>> been hashed out yet about them, aside from general speed and load
>> requirements.
>>
>> As a general example of a pragmatic reason one might choose Go over
>> Scala, the architect said Scala would be bad for making a standalone
>> program that checks gRPC health endpoints because the binary would be large
>> and the start-up time would be long.
>>
> --
> You received this message because you are subscribed to a topic in the
> Google Groups "golang-nuts" group.
> To unsubscribe from this topic, visit https://groups.google.com/d/to
> pic/golang-nuts/Fg1I34HrtqU/unsubscribe.
> To unsubscribe from this group and all its topics, send an email to
> golang-nuts+unsubscr...@googlegroups.com.
>
> For more options, visit https://groups.google.com/d/optout.
>



-- 
Diego Medina
Lift/Scala Consultant
di...@fmpwizard.com
https://blog.fmpwizard.com/

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to