I love this language

agolangf · · 504 次点击    
这是一个分享于 的资源,其中的信息可能已经有所发展或是发生改变。
<p>I just want to say, I&#39;ve been following the go language for a while now and I love it. I&#39;m a systems engineer who fell into software development and love doing it. I came from a matlab and python background so I&#39;m not the typical software developer, but I&#39;ve learned a lot. I&#39;ve heard the old guards&#39; (c++, c, java) gripes about the language and i sort of get some part of their side of the story. But the more i understand this simple language the more i think it&#39;s strengths more than make up for it&#39;s weaknesses. The interfaces, the inheritance by composition, the concurrency model baked in, the channels, even the way go handles reading and writing, which at first was insanely difficult to understand why, but now makes so much sense in the context of the language. I especially love the speed i can get with garbage collection, the tooling built in, and the ease of compilation. But i just wanted to voice my support that, for a rapid development, high performance, networked software system, i don&#39;t think go can be beat. And i can&#39;t wait to see the ecosystem that develops around it.</p> <hr/>**评论:**<br/><br/>maus80: <pre><p>I am also a system (and network) engineer and I completely agree. Go is the best candidate to follow up C. It is fast, safe and simple. It really is a dream come true for DevOps/NoOps type of engineers.</p></pre>orbat: <pre><p>Rust is probably the next C. I mean I like Go well enough, and it&#39;s absolutely great for e.g. network-facing projects or anything where a GC and a simpler type system won&#39;t be in the way.</p> <p>Having a runtime and/or a GC just doesn&#39;t work in certain scenarios (e.g. device drivers or operating systems in general). Rust has no runtime and no GC, but it also has no manual memory management as such, it encourages functional patterns (and makes most of them very cheap), it has an interesting and powerful type system, <em>and</em> it makes it easy to interface with C.</p></pre>jerf: <pre><p>Rust is significantly and irreducibly more complicated than C. There are good reasons for that, and it gets things for that complexity that are impossible to get without it, but it&#39;s hard to see it completely replacing C&#39;s niche because of that. Not everyone is a professional programmer, and I&#39;ve seen professional programmers balk at Rust&#39;s complexity too. (We can criticize them for that, but that doesn&#39;t change much.)</p> <p>Go, it is true, also does not completely replace C. But Go is mostly much <em>simpler</em> than C (at least to program in), and does the vast bulk of what people use C for, with a 21st century solution.</p> <p>Neither one is, strictly speaking, a &#34;replacement&#34;, but between the two of them, the vast majority of what you might want to do in C is covered by the two of them.</p> <p>After all, languages are complicated things. If you get particular enough about your specification for your C replacement, you just end up specifying C again. You do have to grant your replacement at least a little wiggle room if you want to avoid that outcome. </p></pre>jeremiahs_bullfrog: <pre><p>If you&#39;re not a professional programmer, then you probably shouldn&#39;t be writing in C. If you&#39;re not a professional programmer and C is your only option, them Go likely doesn&#39;t work on the platform you&#39;re targeting since it&#39;s GC&#39;d (hard to have a GC on a microcontroller).</p> <p>I don&#39;t think Go&#39;s niche is to replace C, but to be a faster alternative to Python, Node.js, Ruby, etc for threaded applications. That&#39;s essentially what we&#39;ve used it for, and we really appreciate the low learning curve as we tend to train a lot of our programmers.</p></pre>jerf: <pre><p>I agree that almost nobody should be writing in C, and that even if you are in a situation where it is forced on you, all that means is that you&#39;re being forced to take a bad choice, not that it&#39;s a good choice.</p> <p>But that still seems to be a minority view right now. We&#39;re slowly getting change on that, but there&#39;s still a lot of professional programmers who see no problem writing in C, even after all the plainly-visible issues it is responsible for.</p></pre>jeremiahs_bullfrog: <pre><blockquote> <p>almost nobody should be writing in C</p> </blockquote> <p>I didn&#39;t say that and I think C is a fine language, it just doesn&#39;t scale well (the larger it gets, the more likely bugs are). For microcontrollers and projects with only a few hundred lines of code, I think it&#39;s a perfectly reasonable choice.</p> <p>I think we need something safer as a replacement for C, and I think that language is Rust, but like any new technology, it needs to prove itself so it can replace C.</p></pre>orbat: <pre><p>Oh yeah, I absolutely agree with you; probably should have worded myself better.</p> <p>It&#39;s not a question of any language absolutely replacing or superseding another, but more that they fill a certain niche. Go and C are ultimately in different niches. C and Rust share one niche, but Rust also shares one niche with languages like Scala. C will be around long after we&#39;re gone, but some of its niche may now be filled by Rust</p></pre>SSoreil: <pre><p>I don&#39;t see Rust replacing C. The features it offers over C come at a cost to the programmer I don&#39;t think is low enough to justify moving away from C for many. Maybe in a few years with a few iterations of Rust.</p></pre>comradeswitch: <pre><p>Yeah. C has an odd sort of simplicity, somewhat like Python in my experience- it&#39;s easy to pick up and write a basic application in, but it takes a lot of work to master the languages.</p> <p>Rust definitely takes a lot of work to master- but that work has to be done up front in many cases. A concurrent application you could whip together the first day or two with Go could require dozens of hours of time with Rust before you get something you can run.</p> <p>I don&#39;t think that&#39;s inherently a bad thing, especially considering the safety benefits you get in exchange, but it&#39;s certainly going to hurt adoption.</p> <p>The fact that there are 20 different solutions in crates for any conceivable problem with no reasonable way to determine the quality or stability of each makes it an unappealing choice for business applications, too.</p> <p>I want to see Rust, or something like it, succeed. But I don&#39;t think &#34;success&#34; for Rust is going to look like it being a C killer. Not yet, at least. Too high of a barrier to entry, the main ecosystem of packages being unstable by definition just to get important compiler features...idk. I don&#39;t know the answers but I don&#39;t think C is in any danger of being replaced soon to any significant degree.</p></pre>mundanevoice: <pre><p>Rust has probably much worse syntax. It looks so complicated. </p></pre>ar1819: <pre><p>Sorry, but no. Rust is next something, but definitely not C. And type system, while being interesting, is definitely a problem, because of the complexity. And while some projects may benefit from it, I say safely say right now that systems programming and language complexity do not mix together. </p> <p>More importantly, most of the C developers this days are actually very good at managing memory and handling threading. The tooling also progressed. You may point me at examples like OpenSSL but those software was written long before Rust, Go, Nim or D. It also made to support tons of hardware configurations which LLVM didn&#39;t even heard of. The C is also relatively simple to implement for the target hardware. </p> <p>Short story - I believe that Rust will find it target audience when it stops comparing itself with C and C++. </p></pre>jeremiahs_bullfrog: <pre><blockquote> <p>systems programming and language complexity do not mix together</p> </blockquote> <p>C++ would like to have a word with you.</p> <p>Yes, Rust has a fairly complicated type system, but you don&#39;t need to use all of it, much like in C++. If you stick with loops, structs and implementing existing traits, you essentially have C or Go without channels/goroutines, just now strict.</p> <blockquote> <p>More importantly, most of the C developers this days are actually very good at managing memory and handling threading</p> </blockquote> <p>Yet they either still make mistakes or use excessive locks, which hits performance. Rust essentially double checks your code for you, so the term &#34;fearless concurrency&#34; is apt. If you&#39;re convinced you&#39;re right, you can always disable the checker with <code>unsafe</code>. I&#39;ve run into tons of concurrency related errors in Go (mostly due to invalid assumptions) that would have been caught with Rust.</p> <p>I think Rust will do quite well routing itself as a replacement for C/C++ because that&#39;s essentially what it was designed for, as it fixes many of the most common problems in C/C++.</p> <p>I don&#39;t think C will ever entirely go away, but I can see a lot of non trivial code moving from C to Rust. I&#39;ll still want C for my microcontroller projects, but I&#39;ll use Rust for everything where Go isn&#39;t a good fit.</p></pre>ar1819: <pre><blockquote> <p>C++ would like to have a word with you.</p> </blockquote> <p>Oh - it constantly does. Because I work with C++ too =). It&#39;s good for creating all kinds stuff (we have goroutines and channels too - in boost) but it&#39;s incredibly complex (boost). You need at least 1-2 years to get productive in it and 5+ to get proficient. Drivers are still C only in 99% of the cases (runtime). And don&#39;t get me started on Altera or such and their C++ implementation. And their optimizer. Grrrr....</p> <blockquote> <p>Yes, Rust has a fairly complicated type system, but you don&#39;t need to use all of it, much like in C++.</p> </blockquote> <p>I must be able to read it and &#34;parse&#34; in my head on the fly. Security flaws are not bound to index out of bounds (pun intended) and data races. Those do happen, but overrated (IMHO) because they are simpler to talk about.</p> <blockquote> <p>Yet they either still make mistakes or use excessive locks, which hits performance.</p> </blockquote> <p>Rust doesn&#39;t protect you from logical mistakes (<code>&lt;</code> instead of <code>&gt;</code> lol). Valgrind can catch most of the memory bound errors. Good static analysis can catch even more. As for performance - it depends. Benchmarks show that Rust is good at handling one sort of situations while failing at others.</p> <blockquote> <p>Rust essentially double checks your code for you, so the term &#34;fearless concurrency&#34; is apt.</p> </blockquote> <p>Rust forces me to strict owning mechanic. Which is not bad by itself, but on complex scenarios, it starts to slow down (RC is not free) or\and get incredibly hard to write.</p> <blockquote> <p>If you&#39;re convinced you&#39;re right, you can always disable the checker with unsafe</p> </blockquote> <p>I don&#39;t like to disable language features in critical parts of code. This essentially nullifies any statement about code being correct (unless unsafe part is proven, but that&#39;s entirely different subject).</p> <blockquote> <p>I&#39;ve run into tons of concurrency related errors in Go (mostly due to invalid assumptions) that would have been caught with Rust.</p> </blockquote> <p>Rust doesn&#39;t protect you from thread starvation. That&#39;s why I like Go channels - they ensure that each goroutine would eventually access the shared data. </p> <blockquote> <p>I think Rust will do quite well routing itself as a replacement for C/C++ because that&#39;s essentially what it was designed for, as it fixes many of the most common problems in C/C++.</p> </blockquote> <p>First versions of Rust were entirely different language - with functional patterns, green IO. Then it was redesigned to be used as a new language for the next Mozilla browser. Then they decided to use &#34;just in web rendering engine&#34; (Spidermonkey is not going anywhere.). So the language was designed to solve Mozilla problems. Just like Go was designed to solve Google problems.</p> <p>And here lies my problem - I have no trouble with borrow checker. Trait system and implicit conversions, on the other hand, which allow you to write incredibly complex code is bad for security. Because security is about readability when project reaches 100k+ lines of code.</p> <blockquote> <p>I don&#39;t think C will ever entirely go away, but I can see a lot of non trivial code moving from C to Rust. I&#39;ll still want C for my microcontroller projects, but I&#39;ll use Rust for everything where Go isn&#39;t a good fit.</p> </blockquote> <p>You can use any kind language you want, as long as it fulfills your needs or the needs of your customers. In end, all we care about is the result. But I honestly tired of this &#34;Rust is our salvation&#34; spam. It&#39;s not - Pony is coming and their type system is even &#34;better&#34; (and formally proven btw). </p> <p>Don&#39;t get me wrong - my company (listed on the Rust site btw) is using it - good language for some sort of the situations, but the scope is limited. And instead of seeing things like &#34;This would be better if it was written in Rust&#34; I would like to see &#34;We saved N amount of money\resources\manpower by writing this piece of our infrastructure in Rust. And here what we learned&#34;.</p></pre>jeremiahs_bullfrog: <pre><blockquote> <p>I must be able to read it and &#34;parse&#34; in my head on the fly</p> </blockquote> <p>And Rust is very good at that, but it takes some time to get familiar with it enough to do so. The benefit of Rust, IMO, is that it takes away many of the commonly missed memory errors and frees you to focus on the logic errors.</p> <blockquote> <p>Rust doesn&#39;t protect you from logical mistakes</p> </blockquote> <p>True, which is why it&#39;s awesome that it eliminates entire classes of errors and lets you focus on the logic.</p> <blockquote> <p>As for performance - it depends</p> </blockquote> <p>Exactly. Go&#39;s GC was a huger problem at launch (almost prevented us from adopting it because it&#39;s imprecise nature cause issues on low memory systems), but it&#39;s gotten way better. I expect the same from Rust, that as it matures, so will performance. Just recently someone landed a patch for <code>sort</code> that dramatically improves performance (based on TimSort).</p> <blockquote> <p>Valgrind can catch most of the memory bound errors</p> </blockquote> <p>Only if you hit that code path in your testing, which you should, but you won&#39;t necessarily do. I&#39;m still finding problems with Go&#39;s race detector in code I haven&#39;t touched in over a year, because it&#39;s not as commonly hit.</p> <p>Rust prevents nearly <em>all</em> classes of memory issues so you don&#39;t need tools like Valgrind, which simplifies testing.</p> <blockquote> <p>unless unsafe part is proven, but that&#39;s entirely different subject</p> </blockquote> <p>I think that&#39;s exactly the subject. If you have <code>unsafe</code> code, that&#39;s a red flag for an audit/unit tests, and should be the most well tested part of your code. You still get checks there, so it&#39;s at least as good as other languages in <code>unsafe</code> blocks.</p> <blockquote> <p>Rust doesn&#39;t protect you from thread starvation</p> </blockquote> <p>True, but that&#39;s not a memory error, and you can always use a async library to solve the same problem (like <a href="https://github.com/carllerche/mio"><code>mio</code></a> for sockets or <a href="https://github.com/tokio-rs/tokio-proto"><code>tokio</code></a> for other I/O).</p> <p><a href="https://github.com/golang/go/issues/10958">In Go, tight loops can block the GC</a>, so it&#39;s also a problem in Go (but I think it will be fixed in 1.8 since a commit seems to have landed).</p> <p><a href="https://doc.rust-lang.org/std/sync/mpsc/index.html">Rust also has channels</a>, so you can get similar benefits. They&#39;re not as nice as Go&#39;s channels (can&#39;t use them in a <code>select</code>), but they&#39;re there.</p> <blockquote> <p>it starts to slow down (RC is not free)</p> </blockquote> <p>You don&#39;t have to use reference counting, it&#39;s opt-in with the <code>Rc</code> and <code>Arc</code> types. By default it essentially works like C++ using scope to determine when to destruct things. If you want smart pointers w/o reference counting, use <code>Box</code>, which essentially just allocates on the heap and deallocates when it goes out of scope.</p> <p>In this case, it&#39;s better than Go in many regards because:</p> <ul> <li>you can choose the costs you want to pay (copying, <code>Rc/Arc</code>, <code>Box</code>); I&#39;ve heard rumors that there are some WIP garbage collectors you can add if that&#39;s your cup of tea</li> <li>no built-in garbage collection means you never stop the world</li> </ul> <blockquote> <p>First version&#39;s of Rust were entirely different language</p> </blockquote> <p>True, but the core reasons for its existence never changed: memory safety without compromising performance. Go also had quite a few major design changes since it was introduced, and it spent far less time as a public beta than Rust did (Rust was essentially developed in the open, Go only became public within a year or so of hitting 1.0).</p> <p>I <em>do</em> miss green threads, but I also like the direction it&#39;s gone since those things can (and are) be developed as libraries efficiently.</p> <blockquote> <p>Trait system and implicit conversions</p> </blockquote> <p>Examples? Rust has a more strict definition for implicit conversions than most languages, so you won&#39;t get the same issues that you&#39;d have in C, C++ or Java for example. I can see this potentially being a problem in crypto, for example, but the memory guarantees really offset that minor issue. YMMV of course.</p> <blockquote> <p>But I honestly tired of this &#34;Rust is our salvation&#34; spam</p> </blockquote> <p>I&#39;m not saying that at all. I use Rust, Go, Python, C, JavaScript, etc all for different purposes. My argument is that Rust is a more likely shoe-in for the types of problems most people use C for, and Go fits more as a replacement for higher level languages (like Ruby, JavaScript, Python, etc) when performance is needed.</p> <blockquote> <p>&#34;This would be better it was written in Rust&#34; I would like to see &#34;We saved N amount of money\resources\manpower by writing this piece of our infrastructure in Rust. And here what we learned&#34;</p> </blockquote> <p>I&#39;m sure we&#39;ll get that in time, just like we got with Go. It took a year or two for larger companies to switch to Go and blog about it, and I&#39;m sure the same will happen with Rust. Mozilla switching Firefox to Rust will be a fantastic boon to these kind of anecdotes (and they&#39;ve already landed code in Firefox).</p> <p>So yeah, that&#39;ll come in time, and I&#39;m eager to read them. I love Go and I love Rust, and before I push for it in a larger project, I&#39;ll need more proof that it scales well. For now, I&#39;m enjoying using it in smaller projects that I hope to ship to actual users.</p></pre>ar1819: <pre><blockquote> <p>Rust is very good at that</p> </blockquote> <p>Depends on who you asking.</p> <blockquote> <p>True, which is why it&#39;s awesome that it eliminates entire classes of errors and lets you focus on the logic.</p> </blockquote> <p>I really don&#39;t remember the last time I&#39;ve encountered use-after-free or data race error in my cpp apps. YMMV.</p> <blockquote> <p>Exactly. Go&#39;s GC was a huger problem at launch </p> </blockquote> <p>GC was young back then and immature. More importantly - it&#39;s quite different from Java\C# one.</p> <blockquote> <p>I expect the same from Rust, that as it matures, so will performance.</p> </blockquote> <p>Rust uses JeMalloc which is neither young nor immature.</p> <blockquote> <p>Only if you hit that code path in your testing, which you should, but you won&#39;t necessarily do.</p> </blockquote> <p>In critical systems? You wold not only test it, but will prove it be correct.</p> <blockquote> <p>Rust prevents nearly all classes of memory issues so you don&#39;t need tools like Valgrind</p> </blockquote> <p>There was an article about use after free in Rust. Also Valgrind is used for other things.</p> <blockquote> <p>Rust also has channels , so you can get similar benefits.</p> </blockquote> <p>You are comparing SPSC queues with MPMC. That&#39;s not the same thing.</p> <blockquote> <p>If you want smart pointers w/o reference counting, use Box, which essentially just allocates on the heap and deallocates when it goes out of scope.</p> </blockquote> <p>You can&#39;t use object graph with Box.</p> <blockquote> <p>no built-in garbage collection means you never stop the world</p> </blockquote> <p>STW argument is only working when you don&#39;t allocate\deallocate memory at all. Box doesn&#39;t allow you(yet) to specify allocation strategy. And Jemalloc is not free. </p> <blockquote> <p>Examples? </p> </blockquote> <p><code>Into</code> and <code>&amp;str</code>. </p> <blockquote> <p>same issues that you&#39;d have in C, C++ or Java for example</p> </blockquote> <p>I&#39;m not talking about <code>int -&gt; float</code> implicit conversions. Those could be enabled as warnings (even blocking ones) in GCC, Clang and MSVC.</p> <blockquote> <p>My argument is that Rust is a more likely shoe-in for the types of problems most people use C </p> </blockquote> <p>I need specific examples. I use Go, but I also still use Python. Scientific computations are MUCH cheaper in NumPy (FORTRAN say hello btw).</p> <blockquote> <p>I&#39;m sure we&#39;ll get that in time, just like we got with Go.</p> </blockquote> <p>It has been almost two years since the release - at that time (2014) we had Iron.io, Dropbox, CloudFlare and others.</p> <p>I don&#39;t love languages - they are simply the tools for making things done. But I also don&#39;t like complexity, when it&#39;s not needed. I heard &#34;C needs to go&#34; mantra back in 2007 and even before that. Even better - we had better C dialects (I&#39;m not talking about C++) with safe memory model. Didn&#39;t get much traction.</p></pre>jeremiahs_bullfrog: <pre><blockquote> <p>I really don&#39;t remember the last time I&#39;ve encountered use-after-free or data race error in my cpp apps. YMMV</p> </blockquote> <p>But that&#39;s not the only thing it prevents, and misses arguably the most important one: data races.</p> <p>When I first started building a large project in Go (I was lead developer), I made some unfortunate assumptions in Go and I ended up having to throw mutexes in a lot of places for operations that I thought were atomic (map reads/writes). On Go 1.4 and before, Go only used a single execution thread, so we didn&#39;t have any bugs, but once Go 1.5 came out, all kinds of threading-relate bugs surfaced. I then realized my error and have been adding mutexes everywhere to make sure things are safe. In Rust, such code would fail to compile.</p> <blockquote> <p>Rust uses JeMalloc which is neither young nor immature</p> </blockquote> <ol> <li>the allocator isn&#39;t the only thing that can be optimized</li> <li>Rust <a href="https://github.com/rust-lang/rfcs/blob/master/text/1183-swap-out-jemalloc.md" rel="nofollow">has accepted allowing a custom allocator</a> and <a href="https://github.com/rust-lang/rust/issues/33082" rel="nofollow">it&#39;s being worked on</a></li> </ol> <blockquote> <p>In critical systems? You wold not only test it, but will prove it be correct.</p> </blockquote> <p>Not everyone works on critical systems, but if you do, it would be far nicer to catch those errors in development so the review goes faster.</p> <blockquote> <p>There was an article about use after free in Rust</p> </blockquote> <p>There&#39;s also an article from someone on the Go core team about <a href="https://research.swtch.com/gorace" rel="nofollow">Go not being memory safe</a> and <a href="http://blog.stalkr.net/2015/04/golang-data-races-to-break-memory-safety.html" rel="nofollow">relatively recently confirmed</a>, so it&#39;s likely not fixed (though the Go bug mentioned is hard to trigger).</p> <p>Both compilers have bugs, but I haven&#39;t been able to find the one you mentioned, though I&#39;m very interested in reading it (the things I&#39;ve found are from over a year old).</p> <blockquote> <p>You are comparing SPSC queues with MPMC. That&#39;s not the same thing.</p> </blockquote> <p>Sort of. Go&#39;s channels are MPMC, Rust&#39;s channels are MPSC, but <a href="https://github.com/BurntSushi/chan" rel="nofollow">there&#39;s a library for MPMC channels in Rust</a> from someone who is quite big in the Rust community (author of <a href="https://github.com/BurntSushi/ripgrep" rel="nofollow">ripgrep</a>), so I&#39;m fairly confident in its quality.</p> <p>So you&#39;re right, Go and Rust don&#39;t quite do the same thing, but with a library they effectively do.</p> <blockquote> <p>You can&#39;t use object graph with Box</p> </blockquote> <p>Yes, there are limitations. See <a href="http://featherweightmusings.blogspot.com/2015/04/graphs-in-rust.html" rel="nofollow">this blog post</a> if you haven&#39;t already that gives solutions here.</p> <p>There <em>has</em> been talk about having an external GC (used much like <code>Rc</code>) to make these types of things easier, but I haven&#39;t seen anything concrete yet. There is <a href="https://github.com/Manishearth/rust-gc" rel="nofollow">this project</a> and I&#39;m sure others to solve these types of problems.</p> <blockquote> <p>I need specific examples</p> </blockquote> <ul> <li>games</li> <li>kernels/drivers</li> <li>microprocessors (assuming you have compiler support)</li> </ul> <blockquote> <p>It has been almost two years since the release</p> </blockquote> <p>And <a href="https://www.rust-lang.org/en-US/friends.html" rel="nofollow">here&#39;s a list of organizations using Rust in production</a>, among them is Dropbox, so it looks like Rust&#39;s market isn&#39;t necessarily so different from Go&#39;s.</p> <blockquote> <p>we had better C dialects (I&#39;m not talking about C++) with safe memory model. Didn&#39;t get much traction</p> </blockquote> <p>The problem is that nobody wants to switch unless they&#39;re sure the thing they&#39;re switching to has long term support. Go took off in large part because it&#39;s backed by Google, and I expect Rust to take off because it&#39;s backed by Mozilla. D, Vala and many others are not backed by a large organization, so people are a bit more hesitant to switch.</p> <p>The good part about Rust is that it&#39;s easy to port part of your application to Rust (since you can use Rust as a C library), whereas for Go, that wasn&#39;t possible until 1.6 or something like that, and even today, working with C++ is very difficult in Go and hasn&#39;t been a huge focus from what I can tell.</p> <p>From <a href="https://github.com/rust-lang/rfcs/pull/1774" rel="nofollow">Rust&#39;s 2017 roadmap</a>, this will hopefully be a focus. Under <a href="https://github.com/rust-lang/rfcs/blob/master/text/1774-roadmap-2017.md#integration-with-other-languages" rel="nofollow">&#34;Areas of Exploration&#34;</a>:</p> <blockquote> <ul> <li>Continuing work on bindgen, with focus on seamless C and eventually C++ support. This may involve some FFI-related language extensions (like richer repr).</li> <li>Other routes for C/C++ integration.</li> </ul> </blockquote> <p>I really hope this gets attention this year as it&#39;s one of my biggest complaints about Go. I&#39;m not sure what I&#39;m expecting though.</p> <blockquote> <p>I don&#39;t love languages - they are simply the tools for making things done</p> </blockquote> <p>And I do, but I use the right tool for the job. I wanted to build a game and I really wanted to do so with Rust, but the tools just weren&#39;t there for the platforms I wanted to target, so I&#39;m building it in Java (this particular game isn&#39;t very CPU/graphics intensive) using a framework that works on all platforms I want to target. I really don&#39;t like Java as a language, but it works well as a tool.</p> <p>I opted for writing the server in Rust because I want to make sure I don&#39;t have any concurrency-related issues as it would really suck to have to take the game server down for maintenance because of a data race.</p> <p>For smaller web-based projects, I use Go because the library support just isn&#39;t there in Rust yet (well, it&#39;s there, but not 1.0, though that&#39;s a focus for 2017).</p> <p>I expect C/C++ programmers to flock to a variety of different languages, and if I had to give a prediction today, I&#39;d say the main contenders are Rust, Go and Swift.</p></pre>ar1819: <pre><blockquote> <p>But that&#39;s not the only thing it prevents, and misses arguably the most important one: data races.</p> </blockquote> <p>I&#39;ve mentioned them.</p> <blockquote> <p>When I first started building a large project in Go (I was lead developer), I made some unfortunate assumptions in Go and I ended up having to throw mutexes in a lot of places for operations that I thought were atomic (map reads/writes).</p> </blockquote> <p><a href="https://golang.org/doc/faq#atomic_maps" rel="nofollow">https://golang.org/doc/faq#atomic_maps</a></p> <blockquote> <p>Rust&#39;s channels are MPSC, but there&#39;s a library for MPMC channels in Rust from someone who is quite big in the Rust community (author of ripgrep ), so I&#39;m fairly confident in its quality.</p> </blockquote> <p>I&#39;m not - Andrew Gallant is a really good developer, and I&#39;m grateful for ripgrep, but he is not &#34;multi-core developer&#34;. And, he himself, even admits that:</p> <pre><code>Channels can be leaked! In particular, if all receivers have been dropped, then any future sends will block. Usually this is indicative of a bug in your program. // This implementation is extremely naive and probably very inefficient. // Notably, *every* channel send/recv calls `notify`, which needs to acquire // a lock and broadcast to every select&#39;s condition variable. </code></pre> <p>This queue IS extremely naive and has no guaranties about thread ordering. I&#39;m not talking about cache lines and sizing, because it&#39;s not a lock-free queue.</p> <blockquote> <p>So you&#39;re right, Go and Rust don&#39;t quite do the same thing, but with a library they effectively do.</p> </blockquote> <p>Please read Go channel implementation before making such claims. You will surprised =)</p> <blockquote> <p>Yes, there are limitations. See this blog post if you haven&#39;t already that gives solutions here.</p> </blockquote> <p>I know about UnsafeCell, but I don&#39;t like the fact that I must bypass the language features in order to make this simple thing. </p> <blockquote> <p>but I haven&#39;t been able to find the one you mentioned</p> </blockquote> <p><a href="https://insanitybit.github.io/2016/12/28/golang-and-rustlang-memory-safety" rel="nofollow">https://insanitybit.github.io/2016/12/28/golang-and-rustlang-memory-safety</a> - it&#39;s not a bug, it&#39;s a valid construct. </p> <blockquote> <p>games</p> </blockquote> <p>Unless you talking about indie games - it&#39;s not happening. Triple A developers especially care about how <strong>EXACTLY</strong> their code is matched to the CPU set. There is also support problems (Official DirectX API in Rust) and tooling. And - you&#39;d not be surprised - game developers are willing to trade correctness for speed.</p> <blockquote> <p>kernels/drivers</p> </blockquote> <p>Good luck convincing Linux core people about that =D</p> <blockquote> <p>microprocessors (assuming you have compiler support)</p> </blockquote> <p>Yeah, about that - have you looked at LLVM hardware support? Better yet - have you looked at first-class Rust support?</p> <blockquote> <p>Rust to take off because it&#39;s backed by Mozilla.</p> </blockquote> <p>I&#39;d be vary before making such statements - Firefox market share is still shrinking. They essentially lost mobile segment entirely. And most of the senior stuff I&#39;ve talked with are well aware of that.</p> <blockquote> <p>I wanted to build a game</p> </blockquote> <ol> <li><p>Unreal Engine</p></li> <li><p>Unity</p></li> </ol> <p>Pick one and don&#39;t bother yourself.</p> <blockquote> <p>I expect C/C++ programmers to flock to a variety of different languages</p> </blockquote> <p>Yeah - C++ expected C developers to make transition. It was 90s. Didn&#39;t happen.</p></pre>jeremiahs_bullfrog: <pre><blockquote> <p><a href="https://golang.org/doc/faq#atomic_maps" rel="nofollow">https://golang.org/doc/faq#atomic_maps</a></p> </blockquote> <p>Yup, I found that when I was wondering why everything was broken. It doesn&#39;t help that many of our developers used to write in Node.js, so data races weren&#39;t commonly dealt with (we migrated because Node.js wasn&#39;t fast enough and was hard to debug).</p> <blockquote> <p>This queue IS extremely naive and has no guaranties about thread ordering</p> </blockquote> <p>I actually didn&#39;t really look into it beyond checking if there was a reasonable MSMC library.</p> <blockquote> <p>Please read Go channel implementation before making such claims. You will surprised =)</p> </blockquote> <p>I hope so, but I <em>do</em> know that Go uses locks both on send and receive, though I also know that the Go developers are very technically aware, so they probably use a hybrid lock-free/mutex design of some sort. I&#39;ll have to give it a read though, thanks for the nudge.</p> <blockquote> <p>but I don&#39;t like the fact that I must bypass the language features in order to make this simple thing</p> </blockquote> <p>It&#39;s a &#34;simple thing&#34; that plagues naive garbage collectors and pretty much any other form of memory management besides manual memory management. I seem to remember needing to manually nullify my ring buffers and graphs in Java to make sure the GC detected it (though I think that&#39;s since been solved).</p> <blockquote> <p>There is also support problems (Official DirectX API in Rust) and tooling</p> </blockquote> <p>Well, not to nitpick, but I think (hope?) Vulkan will replace DirectX. That being said, as long as there&#39;s a C API, it&#39;ll be fairly easy to make an efficient Rust binding.</p> <blockquote> <p>game developers are willing to trade correctness for speed</p> </blockquote> <p>Game developers also care a <em>lot</em> about meeting deadlines, and if Rust can help prevent the types of bugs that delay releases, it will be a big sell.</p> <p>Also, Rust has the option of using inline assembler (in <code>unsafe</code> blocks of course), so you can still optimize the hot paths in the same way.</p> <p>The one major hurdle that I can see with games is that game developers really don&#39;t like allocating or deallocating memory (as that&#39;s expensive), so it&#39;ll be interesting if safe concurrency is a big enough sell.</p> <blockquote> <p>Good luck convincing Linux core people about that =D</p> </blockquote> <p>Yeah, but Linux also isn&#39;t the only kernel around.</p> <blockquote> <p>Yeah, about that - have you looked at LLVM hardware support?</p> </blockquote> <p>Yup, definitely a WIP. But I&#39;m looking at the 5-10 year horizon, so it&#39;s certainly possible.</p> <blockquote> <p>Firefox market share is still shrinking</p> </blockquote> <p>True, but millions still use Firefox. Opera and Safari are way below Firefox, yet they&#39;re still being commercially developed. It&#39;ll be hard to convert the Chrome crowd for sure, but if Servo is even half as good as they say it will, they&#39;ll have lots of benchmarks to back them up, which apparently is important to some people.</p> <p>Anecdotally, I use Firefox on both desktop and mobile.</p> <blockquote> <ol> <li>Unreal Engine</li> <li>Unity</li> </ol> <p>Pick one and don&#39;t bother yourself.</p> </blockquote> <p>I went with <a href="http://libgdx.badlogicgames.com/" rel="nofollow">libgdx</a>, mostly because I wanted a 2D game and it was easier to get up and running than Unreal Engine. When I build a 3D game, you bet I&#39;ll try Unreal Engine (Unity isn&#39;t really an option for me because it doesn&#39;t seem to work well on Linux, and that&#39;s my dev environment).</p></pre>lonahex: <pre><p>Rust is a better C++. Go is a better C.</p></pre>orbat: <pre><p>People here keep repeating that, but I don&#39;t think you fully understand that C and Go have, for the most part, very different use cases</p></pre>comrade-jim: <pre><p>According to almost all statistics, Go is already orders of magnitude more popular than Rust. </p> <p>If any language is more likely to replace C it&#39;s Go, simply because no one is using Rust. </p></pre>disintegore: <pre><p>To this day I still don&#39;t understand the &#34;rivarly&#34; between Go and Rust. As far as I&#39;m concerned, they are vastly different and can/should co-exist.</p></pre>goomba_gibbon: <pre><p>Hear hear. Why does everything have to be the next version of something else? They both solve different problems in different ways with differing opinions.</p></pre>elingeniero: <pre><p>Also the rust development team really care about their product and their community which certainly can&#39;t be said about Go. </p> <p>If Rust weren&#39;t so hard to learn I think that it would overtake Go in a couple of years, even for network programming.</p></pre>orbat: <pre><p>Don&#39;t you think that&#39;s unnecessarily harsh? Sure, I think there are several issues with both the language and governance in general, but I don&#39;t think it&#39;s really fair to say the Go team doesn&#39;t care about the product or the community just because the direction they&#39;ve taken Go is not to your liking.</p> <p>I do agree about Rust, though. I&#39;ve started learning it on my free time, and it&#39;s definitely on the challenging side of the spectrum. It&#39;s not quite Haskell, but Scala comes to mind pretty often.</p></pre>jeremiahs_bullfrog: <pre><p>What&#39;s wrong with the governance? I appreciate how open it is compared to Go. In Go, I proposed a change that was met with &#34;that&#39;s not the direction we want to go&#34;, whereas in Rust I think I would have had a more thorough discussion as to why my change wasn&#39;t acceptable. Rust is developed by a core team like Go, but they are run as a true community project where language features are often proposed by members of the community.</p> <p>I think Rust also does a great job at keeping the community friendly and constructive. Newcomers are welcomed and guided to answers, not tersely dismissed.</p> <p>I love Go and I love Rust, but that fill two different niches for me.</p></pre>orbat: <pre><p>I specifically meant Go&#39;s governance</p></pre>jeremiahs_bullfrog: <pre><p>Ah, I misread. I guess we&#39;re on the same page then.</p> <p>I do think the Go project is well run, but the are lots of things I&#39;d like to see that the Go team is unlikely to entertain, such as:</p> <ul> <li>Destructors</li> <li>Genetics</li> <li>Required field values in interfaces</li> <li>Adding methods to types that you don&#39;t control (you can do this with type aliases)</li> <li>Default implementations for functions in interfaces (like Rust has with Traits)</li> <li>Subset of Go without a GC (e.g. for embedded work)</li> </ul> <p>I have all of those things in Rust (well, they&#39;re still deciding on what to do about fields in Traits), and I feel like the core team is open to well reasoned arguments for inclusion, unlike the Go team, which seems really opinionated (which is good in its own way, but you need balance).</p></pre>elingeniero: <pre><p>Maybe it is overly harsh, but running a language for seven years without any effort towards a good, official dependency management solution because &#34;Google uses GOPATH and <code>go get</code> just fine so f*** you guys&#34; feels almost like disdain to me, I think its justification enough to suggest that the development team doesn&#39;t care that much about the community.</p> <p>I saw the recent blog post about it, its a bit late though, especially when you compare it with the Rust team&#39;s approach to it - cargo and crates.io is probably the best attempt at dependency management so far; it is officially supported and was introduced before 1.0.</p></pre>hugthemachines: <pre><p>I don&#39;t even program in Rust but judging from what reasonable people say on reddit and on the web in general it does seem like the difficulty level of Rust decrease the popularity alot. Perhaps it is hard to make the language easier and still have the important features still in the language.</p></pre>jeremiahs_bullfrog: <pre><p>They&#39;re actually working on that this year, as their focus is on user friendliness. This means they&#39;re working on:</p> <ul> <li>IDE tooling (<a href="http://www.jonathanturner.org/2017/01/rls-alpha-release.html" rel="nofollow">just released an alpha of the Rust Language Server</a>)</li> <li>Documentation (already far better than most languages, but still can be better)</li> <li>Faster edit-compile-reload process</li> <li>Making the compiler smarter so lifetimes aren&#39;t needed as often (since 1.0, this has gotten a lot better already and I rarely use them now)</li> </ul> <p>I really wish the Go team made a roadmap or similar.</p></pre>hugthemachines: <pre><p>It sounds great and I really hope it will be better and better. I was a little dissapointed when I tried to set up IDE using eclipse and Rust plugin and it did not work to add projects using it. But what I have heard about is trouble with the borrow stuff. Perhaps it could be changed a bit to make it easier for people to grasp it and use it. It is just my thought though, perhaps it is good, just as it is.</p></pre>jeremiahs_bullfrog: <pre><blockquote> <p>I was a little dissapointed when I tried to set up IDE using eclipse and Rust plugin and it did not work to add projects using it</p> </blockquote> <p>And that&#39;s precisely the problem the Rust team is working on this year. In fact, if you&#39;re adventurous, you could probably use it today, though I&#39;d wait for a little while to make sure the documentation is there for Eclipse.</p> <blockquote> <p>But what I have heard about is trouble with the borrow stuff</p> </blockquote> <p>Yeah, and this is a two way street. If you want safety, you have to pay the price.</p> <p>However, the focus recently has been in making the compiler smarter so it understands your code better so it can figure out borrow issues. When Rust first came out, I had to throw lifetime annotations nearly everywhere, but recently, adding in lifetimes tends to signify a flaw in my design and is often a reminder that a struct if doing too much.</p> <p>It&#39;s important to note that it&#39;s getting better, though you&#39;ll always have to learn about them since it&#39;s a concept so fundamental to Rust. And one huge benefit is that it&#39;s essentially a one time cost in learning the language and you get true memory safety (compete with data race checks) in return.</p> <p>I&#39;m grateful that it&#39;s there since I&#39;ve run into all sorts of problems in the past with lifetime errors, though not as much with Go, where my problems are mostly race condition type issues.</p></pre>kalekold: <pre><p>Go is the next C, Rust <del>is</del> may be the next C++</p></pre>jeremiahs_bullfrog: <pre><p>Show me a microcontroller or OS running Go. The GC alone disqualifies it in many cases, much less the threading. If you can&#39;t use goroutines or the GC, Go doesn&#39;t make sense.</p></pre>jeremiahs_bullfrog: <pre><blockquote> <p>safe</p> </blockquote> <p>For some definitions of safe, but it doesn&#39;t help prevent some of the more common (and more subtle) classes of bugs, like race conditions (though the race detector <em>is</em> helpful here) and nil pointer errors. Rust does, so I think it&#39;ll find its niche among the crowd for whom &#34;safe&#34; is more important than simple.</p> <p>That being said, I think you&#39;re completely right about DevOps. I needed to write a simple port forwarding program in Go and it took maybe 30 minutes to build, test and deploy. Making simple, concurrent and safe programs is very easy in Go.</p> <p>My issues stem from scaling where it&#39;s difficult to ensure correct data access across tens of thousands of lines of code. This is why I&#39;m considering Rust for my future projects that will be large and make heavy use of threading, like games.</p></pre>karma_vacuum123: <pre><p>can anything be the &#34;next C&#34;?</p> <p>its one thing to write the tools themselves....another to produce something from them like the Linux kernel, Postgres, etc etc</p> <p>i predict a hugely lucrative market in maintaining C code that the world simply cannot replace as all the kids move on to their Better Languages</p> <p>likewise for Java...thirty years from now it will still be providing Null Pointer Exception job insurance</p></pre>tmornini: <pre><blockquote> <p>the inheritance by composition</p> </blockquote> <p>Go has no inheritance.</p></pre>frogmouse: <pre><p>Yes that&#39;s true, i meant they tackle the same feature by using composition instead. A more accurate saying would be &#34;use of composition and interfaces instead of inheritance&#34;</p></pre>orbat: <pre><p>How about instead of downvoting <a href="/u/tmornini" rel="nofollow">/u/tmornini</a> you read <a href="https://golang.org/ref/spec" rel="nofollow">the spec</a> and show us where it talks about inheritance or object orientation or classes.</p> <p>We&#39;ll wait.</p> <p>And no, the sentence starting with &#34;The declared type does not inherit any methods bound to the existing type&#34; is not it. </p> <p>Go <em>does not have inheritance.</em> Everything is about <a href="https://golang.org/ref/spec#Method_sets" rel="nofollow">method sets</a>; with composition you don&#39;t have is-a relationships – more like &#34;does-this&#34; (<code>io.Writer</code>), if that makes any sense. Interfaces (i.e. method sets) declare what something can do, not what it is.</p></pre>onwuka: <pre><p>Taking &#34;punting the diamond inheritance problem&#34; to the next level!</p></pre>__crackers__: <pre><p>I think of interfaces as formalised duck typing.</p> <p>Go doesn&#39;t care <em>what</em> the struct is, only whether it has, say, a <code>Read()</code> method that returns a string.</p></pre>comradeswitch: <pre><p>Whether the language spec uses that language or not isn&#39;t really relevant. The language spec could call structs &#34;classes&#34; and go would still be struct-based. These descriptors are just a way to think about languages in terms of common concepts.</p> <p>You knew exactly what OP meant, and so did most likely everyone else here. Maybe it&#39;s not perfectly technically correct, but it conveys the idea just fine, and it&#39;s hardly going to cause any sort of practical problems. This is just pedantry.</p> <p>Handwaving is bad when you&#39;re trying to enumerate a proof. It&#39;s really not an issue when describing the gist of a proof so that someone follows the general argument. It&#39;s really not a big deal. Especially sinxe OP clearly knows what they&#39;re talking about. </p></pre>tmornini: <pre><p>:-)</p></pre>golanger1: <pre><p>Even C has no inheritance, so whats your point?</p></pre>tmornini: <pre><p>Not sure what C has to do with this conversation, but to answer your question, my point was that -- wait for it -- Go doesn&#39;t have inheritance and instead relies entirely upon composition, which I consider to be a very good thing.</p></pre>dankoradora: <pre><blockquote> <p>Go doesn&#39;t have inheritance and instead relies entirely upon composition</p> </blockquote> <p>This is the same meaning as the OP&#39;s the inheritance by composition means in his context.</p> <p>People didn&#39;t downvote you because you were wrong, they did because you&#39;re nitpicking.</p></pre>tmornini: <pre><p>I&#39;ll happily be downvoted to avoid a single person believing Go had inheritance.</p></pre>mbyio: <pre><p>It&#39;s not really nitpicking though, is it? Go doesn&#39;t have inheritance. Suggesting that it simulates inheritance somehow is just wrong.</p></pre>dankoradora: <pre><p>The inheritance by composition is very often used in this context as &#34;solving a problem, that you would usually rely on inheritance, by composition&#34;.</p> <p>But I agree &#34;the inheritance by composition&#34; is quite unclear statement and can by easily misunderstood.</p></pre>onwuka: <pre><p>I&#39;m no expert but even I&#39;ve heard of composition over inheritance. Inheritance by composition is just wrong. </p></pre>__crackers__: <pre><p>Technically incorrect, but perfectly legit rhetorically. Frankly, it&#39;s little different to Go&#39;s own &#34;share memory by communicating&#34; mantra.</p> <p>&#34;Inheritance&#34; and &#34;sharing memory&#34; aren&#39;t meant to be taken literally, but stand for the ends you normally achieve via those means.</p></pre>comradeswitch: <pre><p>I&#39;m a mathematician/QA specialist turned developer. I worked with MATLAB when studying applied math and used Python for several years doing machine learning research. You may not be typical but you&#39;re definitely not alone!</p> <p>I love go. There are some things it doesn&#39;t do well. There are some areas of the ecosystem that are not as developed as I&#39;d like and some areas where it just isn&#39;t suited.</p> <p>But almost every time I start thinking about a project that isn&#39;t heavy on math, I turn to go. Sometimes I end up rewriting a project in another language, but for most applications? Go is just fine. The simplicity is the biggest feature for me. I like the idea of, say, Rust. I&#39;ve done some big projects in C++. Hell, even Python is pretty complex once you get past the basics.</p> <p>I&#39;ve learned, however, that unless that complexity provides a significant benefit because of a particular constraint, I would much rather work with a language that has a low cognitive load. When I&#39;m writing Rust or C++ code, I&#39;m often thinking more about the language and its ins and outs than the application I&#39;m writing. That significantly slows down development and requires more effort. if I&#39;m going to deal with a language spec the size of War and Peace, I <em>better</em> be getting a big benefit to my application for that </p> <p>And most of the time, I&#39;m just not. I don&#39;t want to have to remember more about constraints imposed by the language than constraints imposed by my problem unless I have to, and I rarely have to. Certainly much less often than many go critics might lead you to believe.</p></pre>

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

504 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传