Rust is a nightmare to learn coming from Java

Agree, take a quick look at C if you have the time to invest on low level matters like allocating, handling and freeing memory explicitly (malloc, free and pointer arithmetic).

Scala is an Object & Functional language (not my words, theirs) and Rust is none of that so I don't really understand how it could help. Rust is imperative with some FP pattern, like Java tends to be since Java 8 (less than Rust but in progress).

The Rust book (The Rust Programming Language - The Rust Programming Language) is kind of exhaustive, and if you can get the "Programming Rust" (O'reilly) book, even though a little old now, it offers great explanations on how Rust handles memory and concurrency (it miss the async part that came later but it's really not a problem).
This article is a "quick" remainder you can use: A half-hour to learn Rust. It's not a deep dive into Rust internals, but it enumerates a lot of standard features and concepts you'll have to deal with.

'hope you'll enjoy your investment in Rust :grin:

Yep, a lot of good advice here. :slight_smile:

What I always come down to when Rust gets difficult is that it is paying off for me big time with:

  • Catching all kinds of bugs at compile-time instead of making me run the program before running into them. This saves hours upon hours upon hours of debugging time.

  • Running blazing fast for my users and making my apps easy to install.

Yes, there are no doubt the epic struggles that will ensue between you and the compiler and your brain as you try to figure out why you had to &**my_var or whatever it is, but your application will serve your users with speed and efficiency in a way that you would not be able to provide without Rust.

Edit: Oh and I think the first rust Koan should be near mandatory reading for anybody who has ever run into a Rust compiler error ( which is everybody that writes Rust ). :slight_smile:

7 Likes

Not Scala, but I would say that someone who knows both C++ well-ish and Haskell well will have an easy time with Rust. If you've mastered Haskell then advanced trait usage is something you're familiar with, seeing as traits are basically type classes with some different syntactic conventions (+ some different orphan rules & and some complicated rules re. object safety). Typed FP languages typically also have strong pattern matching facilities. Moreover, Haskell prepares you for "symbolic / equational thinking", which is helpful for understanding lifetimes (although the subtyping is unfamiliar).

5 Likes

The benefits of learning Rust greatly outweigh the hurdles at the beginning, and in the end will make it all worth the effort.

6 Likes

I know the challenge, but from a different perspective. I come from a mixed programming background that is mainly rooted in COBOL.
I agree with a lot of the other commenters, though - it is worth the challenge! I especially enjoy getting back to the system-level thinking and relearning some of the fundamentals that I have not had to deal with in a long time.

1 Like

Glad to see i am not the only one :sweat_smile: . I didn't expect my topic to be so hot :yum:

6 Likes

I feel like I'm starting to sound like a broken record in plugging it again and again but, once you've got some practice with building applications using .clone() and other people's crates, Learn Rust With Entirely Too Many Linked Lists is great help in wrapping your mind around ownership to a level where you can start to write data structures without getting frustrated.

6 Likes

It's not my experience. It went quite smooth. Only the lifetime annotations can sometimes drive me mad. But I expected it to be much harder to learn then it was. Worked through the book at first.

2 Likes

Don't sell yourself short based on titles you may not have. Rust only seems complex because it's foreign to you. Things should click one by one, over time. Lifetimes are pretty complex if you've never had to think too much about memory before, but it takes learning and practice to master them, not titles or degrees.

22 Likes

I think this is very true. I remember learning Java and being completely confused by class, public, static, interface, extends, implements, etc. Any programming language is confusing if you aren't familiar with the concepts it uses. But you learned Java even though it was confusing in the beginning, so you can learn Rust.

6 Likes

"It's not painful to learn something if you learn it incrementally."

-- Yo-Yo Ma at his NPR tiny desk concert. :smile:

7 Likes

I think it has been said already, but I just want to emphasize it again: learning Rust coming from a language which did memory management for you will require some study and will cause some frustration. I think trying to get into C from Java will do the same, just less obvious, since broken code will compile, and you probably won't realize that that thing you're doing all the time causes serious trouble until you move away from toy examples to learn the language. So the feeling is that you "get the hang of it" quicker, but that's not true. Rust just forces you to learn those things up front and prevents you to take the "quick and easy" route, with the payoff that when you get your code to compile, it will probably work.

8 Likes

I had this exact experience in college. I took a summer course after my first year where we used C. I didn't learn about memory management. So when I implemented merge sort and started making variable sized arrays, I had no idea why I was getting a whole lot of garbage. I eventually learned about malloc after hours of banging my head against a wall. It worked! Jump forward 7 years. I started learning Rust from the rust book and I realized that I never called free on that memory.

6 Likes

These are both excellent beginner tips. I see way too many people get stuck in lifetime soup by just adding more and more all over, when really they just wanted to store a String. One can always use more references -- especially in things like function arguments -- as one gets more comfortable.

11 Likes

No problem you will get it only try make projects with rust. I'm javascript developer and now I can start making some projects with this amazing language.

On top of all the great advice above (avoid storing borrows, liberal use of clone at first, etc.), I will give a seemingly small suggestion: use nightly (but not features) and update often. There are many stumbling blocks that have been ironed out in the compiler that will make your learning experience much better. We have diagnostics improvements landing every other day, sometimes quite significant ones at that! It would be a shame if you got stuck on things that won't be as big of a problem 12 weeks down the line when they hit stable.

Finally, be aware that some concepts just need some time to "bake" in your head. The first time I tried to learn rust I had to put it down for 6 months before I could actually do something useful with it. But I feel it is worth it.

14 Likes

It is very unexpecting to me..- to advise for a novice nightly build usage... - have you any real reason for?

-<| Quoting yjoking via The Rust Programming Language Forum rust_lang+70f17081b18868c077b66dbbbc6ceeeb@discoursemail.com, on Thursday, 2020-01-30 06:58:19 PM |>-

& * 'a &'a Box || macro! mod crate extern crate #[...] String vs &str &self unwrap expect ? Rc Arc

I know it’s no much of a consolation but used to be way worse
back in the days when Rust still had sigils:

I was so happy and excited with my first println!("hello") program but more and more things get complex till a point i turn crazy

Guys, how are you able to understand such a complex programming lang ? You are all engineers ??

As the resident Rust advocate at work I find that people do well
when they start with one of the books (Blandy/Orendorff, or
Nichols/Klabnik). Much better than randomly googling every aspect
you don’t understand about a non-working program.

2 Likes

As a beginner to Rust a few months ago it was only a matter days before I found I needed to use nightly.

There were a number of reasons for that most of which I don't recall now but one of the main ones was so that I could use the Rocket web framework.

I don't recall using nightly causing me any problems so I could reverse the question and ask: Have you any real reason not to advise a novice to use nightly?

& * 'a &'a Box || macro! mod crate extern crate #[...] String vs &str &self unwrap expect ? Rc Arc

I'm from C++ world where things like

template<
    template<class> A,
    template = std::enable_if_v</* 10 more lines of nested expressions */>
> ...

isn't that uncommon.

OTOH I had to write Java some time ago. Just a few things I hit in process:

  1. Syntax-wise, it's much more noisy to me and harder to read in some aspects - because most things are just words. And main idea is often buried in those words. Punctuation characters give an eye something to latch onto.
  2. Java world likes XML configs too much. I'd prefer to have simple code-based initialization
  3. Too much reflection-based stuff is happening, often based on those XML configs. Very, very hard to debug if something goes wrong.
  4. Ecosystem is too centered on bloated enterprise'ish solutions. Making simple REST service requires picking JAX-RS implementation, writing web.xml comfig, setting up application server...
  5. Type system is very weak and limited.
  6. Error handling is a mess when you come to generics since most JRE exceptions are checked but you cannot generalize on type of exception being thrown! And in some cases your best bet is to wrap checked exception into RuntimeError. Goodbye static checking.
  7. Standard library doesn't follow some common idea. Iterable vs Iterator vs Stream as an example.

I was so happy and excited with my first println!("hello") program but more and more things get complex till a point i turn crazy

Rust is a different world. No GC, but RAII and borrow checker. No reflection but much better type system and generics. No synchronized but Send/Sync plus more stuff for safe concurrency. No callbacks but proper async.

Guys, how are you able to understand such a complex programming lang ? You are all engineers ??

Well... yes, we're software engineers, just like fellow Java programmers. Who else?

To conclude, everything is relative. When you come to ecosystem/community with a different paradigm, you often hit such roadblocks. And you need to overcome those roadblocks by accepting there are other ways to solve problems that the ones you know.

EDIT: Too many "well"s. Removed some.

7 Likes