this post was submitted on 12 Jun 2023
482 points (100.0% liked)

Technology

1928 readers
7 users here now

Rumors, happenings, and innovations in the technology sphere. If it's technological news, it probably belongs here.

Subcommunities on Beehaw:


This community's icon was made by Aaron Schneider, under the CC-BY-NC-SA 4.0 license.

founded 2 years ago
MODERATORS
 

I run a few groups, like @[email protected], mostly on Friendica. It's okay, but Friendica resembles Facebook Groups more than Reddit. I also like the moderation options that Lemmy has.

Currently, I'm testing jerboa, which is an Android client for Lemmy. It's in alpha, has a few hiccups, but it's coming along nicely.

Personally, I hope the #RedditMigration spurs adoption of more Fediverse server software. And I hope Mastodon users continue to interact with Lemmy and Kbin.

All that said, as a mod of a Reddit community (r/Sizz) I somewhat regret giving Reddit all that content. They have nerve charging so much for API access!

Hopefully, we can build a better version of social media that focuses on protocols, not platforms.

you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 62 points 1 year ago (3 children)

It's looking great! I joined just 2 days ago and the communities I subscribed to are already looking much more lively today. Thanks, Reddit blackout!

Also written in Rust, btw :)

[–] [email protected] 60 points 1 year ago (2 children)

How do you know something is developed with Rust?

Don't worry, the devs will tell you.

[–] [email protected] 3 points 1 year ago

Check the GitHub! It’s linked at the bottom of the web page (“Code”)

[–] [email protected] 3 points 1 year ago

I've also found this to be true with Julia devs

Source: am Julia dev

[–] [email protected] 10 points 1 year ago (2 children)

Weirdly enough the fact that it’s written in rust is why I am using it instead of kbin (PHP)

[–] [email protected] 14 points 1 year ago (1 children)

PHP!? They're writing the shiny new thing in the joke language from r/ProgrammerHumor?

[–] [email protected] 3 points 1 year ago (1 children)

Exactly right?

To the average Redditor I guess its fine, but to me its unacceptable haha.

Repo link: https://github.com/ernestwisniewski/kbin

[–] [email protected] 1 points 1 year ago (1 children)

Welp, I guess I chose right after all.

[–] [email protected] 2 points 1 year ago

There is:

  • The right choice
  • The other choice (PHP)
  • The wrong choice (PHP)
[–] [email protected] 6 points 1 year ago (3 children)
[–] J_C___ 21 points 1 year ago (1 children)
[–] [email protected] 7 points 1 year ago (1 children)

God damn! Okay now I'm fully behind it

[–] [email protected] 9 points 1 year ago* (last edited 1 year ago) (1 children)

Fast because it's pointer-based like C/C++, but better because it's memory safe, which means it won't crash, leak or mysteriously overwrite it's own data constantly.

[–] [email protected] 3 points 1 year ago (1 children)

I'd say that it's fast because it's compiled to machine code and doesn't use garbage collection. But I see what you mean with "pointer-based".

[–] [email protected] 0 points 1 year ago (1 children)

Is there anything with no garbage collection that doesn't work with pointers? If the compiler is handling all the memory allocation for you it might as well just collect garbage, so I figured they were kind of synonymous.

Since we're now going into details, Rust is neat because they figured out a way to keep track of the memory safety of pointers at compile time. That's hard to do, which is why it's a new language and not the old standard.

[–] [email protected] 1 points 1 year ago (1 children)

I would argue that on the one hand you could say that the references to objects in garbage collected languages are also pointers.

On the other hand, you could argue that such references are not pointers, but then you might as well argue that references in rust are not pointers.

I just feel like "a language with pointers" is a weird way to describe a language and it isn't really something that causes the language to become fast. Pointers are low level constructs that are used all the time, and whether or not they are abstracted away in the high level language doesn't automatically make it slow or fast.

[–] [email protected] 1 points 1 year ago (1 children)

Hmm. Alright, what word would you use to differentiate C or Rust from, say, Python? I haven't actually made anything with Rust, but it sounds like you can store a reference in another structure like you can in C, but you can't AFAIK in Python.

[–] [email protected] 2 points 1 year ago (2 children)

You can store references in another structure, but you probably don't want to do this most of the time, since it's a major headache to get ownership and lifetimes right. You shouldn't think of references as pointers, but you should think of them as "borrows": you are temporarily borrowing something from the owner, but you can only do so if the owner exists. So you need to statically guarantee that for as long as you borrow it, the owner must be alive, which gets tricky when you store that borrow somewhere in some data structure. In practice, references or borrows will be short-lived, and most operations on data will be done by the owner of that data.

Underneath, references are represented by pointers, but you shouldn't think of them as pointers, but rather as something you have borrowed, so in that sense it's different from C.

Also, Python does use references everywhere, it's just implicit, and depends on the type. Try storing a list in a class: you've just stored a reference to another structure. Most things (e.g. lists, objects) are passed and stored by reference, some types like integers are copied. In Rust, you can choose whether you want to pass by reference, copy or move ownership. At this point we're still at a high level of abstraction, we don't think so much about whether this will be pointers at the low level.

But my main point is that whether you use pointers, references, or whether it's implicit or explicit doesn't make a language slow or fast, it just defines how programs are written. Rust is very fast because it's compiled to machine code and doesn't do garbage collection or have any other overhead from a "runtime". Python is relatively slow because it's interpreted. You could argue that more manual control over references/pointers can make a language faster, but it's not the main contributing factor.

[–] [email protected] 1 points 1 year ago* (last edited 1 year ago)

I guess I could just say "Rust isn't garbage collected" but I feel like that would be meaningless to someone who doesn't think about compilation. I gravitated to manual pointer/reference control because that's the part you can actually see in the code, and it's pretty closely connected to the lack of garbage collection.

[–] [email protected] 1 points 1 year ago* (last edited 1 year ago) (1 children)

While I have your ear, "who" exactly are the owners in Rust? So far I've come to understand it from the aliasing XOR mutability perspective, so I don't really understand the more common terminology.

[–] [email protected] 0 points 1 year ago (1 children)

When you create an instance of a struct and assign it to a variable or field of another struct, that variable becomes the owner of that value. When you assign it to some other variable or pass it to a function that takes ownership, ownership will move. Otherwise, you will borrow. But there will always only be one owner for each value. That way you know exactly when to free up memory: whenever the owner is dropped.

[–] [email protected] 0 points 1 year ago* (last edited 1 year ago) (1 children)

So then when you say "most operations on data will be done by the owner of that data", do you mean ownership-taking functions? In my head a variable is like a bin, so it's odd to think of it doing any "operations" other than holding.

[–] [email protected] 1 points 1 year ago (1 children)

No, I phrased that poorly. What I meant is that if you have a struct that has some field (it owns that data), your operations on that data will be methods of that struct, and not some other struct that happens to have a reference to that struct. The latter is something people tend to do in OO languages like Java. In Rust, if a function accesses data, you usually "freshly" borrow from the owner of that data and pass it as argument to that function instead of relying on some "hidden" references somewhere in hidden in an object. Borrows will almost always be short-lived.

I don't know if any of this makes sense, I'm sorry for the bad explanation. It might make more sense if you play with Rust yourself.

[–] [email protected] 1 points 1 year ago

Alright, thanks! I have every intention of playing around a bit.

[–] [email protected] 6 points 1 year ago (2 children)

Rust is a very good language but is relatively new on the scene so it has to compete against other languages that fit the same niche(primarily C++) that have been around a lot longer.

Rust has been very popular for hobby projects for a while but it's still pretty rare to see it for larger projects, and you still almost never see it for enterprise projects. So it's cool seeing an app that uses it blow up.

[–] [email protected] 2 points 1 year ago

There's a bit of a groundswell, where I've seen young devs try to push an organisation that they're working in towards Rust. This is usually a terrible mistake because it means you'll be forcing all the other devs to maintain your Rust code.

[–] [email protected] 1 points 1 year ago

It should be noted that while Rust is rarely used, some very big players are pushing it. E.g. last year Microsoft Azure's CEO tweeted that "it's time to halt starting any new projects in C/C++ and use Rust for those scenarios where a non-GC language is required", Windows contains some Rust code now and the Linux kernel also supports Rust in addition to C since December.

[–] [email protected] 4 points 1 year ago (1 children)

While I lean more towards Go, I have found that any Rust project that actually reaches maturity tends to be amazingly well built.

It might be a side-effect of Rustaceans on average being good programmers, or maybe the language itself just lends itself to robust, high performance software. Who knows.

[–] Bread 1 points 1 year ago

It is mostly the second part. To code in rust, you must rethink how you code. If it isn't made properly, it just doesn't work whatsoever. So if it works, it really works. It really isn't an option to write error prone code.

People that learn rust can often apply those principles it forces you to learn to other languages too.

[–] [email protected] 2 points 1 year ago

I haven't been here much longer. It's been really cool seeing all of the communities pop up as users flood in.