Spyke
m_f
midwest.social

The cool kids are forcing people to read this at gunpoint nowadays

116
TootSweetreply
lemmy.world

Right? It's in the kernel and everything now. Linus likes it. Linus hates everything. HOW MUCH ARE THEY PAYING HIM?

72

Did he actually say that he likes it? My impression was that it's not his comfort zone, but he recognizes that for the vast majority of young programmers, C is not their comfort zone. And so, if they don't hop on this Rust train, the Linux kernel is going to look like a COBOL project in a not too distant future. It does not happen very often that a programming language capable of implementing kernels gains wide-spread adoption.

25
Annareply

I'm pretty sure Linus dissed on RUST, but then again he disses on everything and everyone.

3
Lucy :3reply
feddit.org

I'll never touch Rust.

I hate the syntax and cargo too much for that. If that means that I'll never write mission critical, low level code, so be it.

9
m_freply
midwest.social

What don't you like about Cargo? Is there another package manager you like more?

9

Well - of course I prefer a centralized package manager like pacman, which I also use for python packages etc., but I mainly dislike the building process of rust, which is usually done with cargo. No libraries, not even a global cache for already compiled dependencies, no distcc. This makes it infinitely slower than most C/C++ projects. Compiling the kernel is literally faster than compiling a "simple" project like spotify_cli (500+ dependencies, depending on configuration).

So it's ass from a user perspective, waiting for stuff to compile (just for it to fail, and start from scratch, as some stuff needs a clean build/src dir), and imo very weird from a dev perspective.

6
m_freply
midwest.social

C is definitely still king, but I wonder if crABI will eventually be able to dethrone it:

https://github.com/rust-lang/rust/issues/111423

If they can define a useful ABI that manages to include lifetimes, that might just be enough of an improvement to get people to switch over from assuming the C ABI everywhere.

6

Still remains to be seen if a potential rust ABI can avoid becoming a chain to the wall the way the C++ ABI seems to have become. When a lot of C++ers apparently agree with "I'm tired of paying for an ABI stability I'm not using" it's not so clear it would really be a boon to Rust.

That said no_std appears to be what people go to for the lean Rust.

And a lot of us are happy not having to juggle shared dependencies, but instead having somewhat fat but self-contained binaries. It's part of the draw of Go too; fat binaries come up as a way to avoid managing e.g. Python dependencies across OS-es. With Rust and Go you can build just one binary per architecture/libc and be done with it.

3
lemmy.zip

The problem is that both Rust and Go are huge. The compiled binaries are bigger and the compilers themselves and slower and more resource intensive. The current benefit to C is that is lean and compiles quickly.

1

Rust is only huge because it doesn't have an ABI. If you had an ABI (and didn't have to compile every single dependency into the binary) the binary sizes would probably drop a lot to the point where they're only slightly bigger than a C counterpart

Edit: I don't know if Go has an ABI but they also include a runtime garbage collector in their binaries so that probably has something to do with it.

5
Epherareply
lemmy.ml

I know you're joking, but uh, both of those are (largely) implemented in Rust...

5
lemmy.world

Linux is C only, ever read the rant by Linus last century about C++ ? I was there, in usenet

70
kbin.melroy.org

Wat? Don't you dare talk that way about my favorite multiple personality disorder clusterfuck of a language.

38
brown567reply
sh.itjust.works

C is the only language, all the rest are mental disorders (/j 😉)

Edit: maybe rust, but it's on thin ice XD

24

For anything mathematical, the fact that Fortran has integrated support for doing math on arrays is absolutely fantastic

1

As someone that has programmed professionally a good chunk in C for embedded systems (basically it’s home turf), fuck C.

0
kekmacskareply
lemmy.zip

the author of C++ said that C gives you many opportunities to shoot yourself in the leg. You have a much less chance for this to happen with C++, but when it does, you will blow your whole lower body off

16
Valmondreply
lemmy.world

Yeah C++ is a bazooka, C is like the death of 1000 paper cuts.

The paper cuts are all poisonous and kills you anyway.

4
kekmacskareply
lemmy.zip

I haven't used either, but compiled a lot of C source code and they compiled or could be adjusted easier even for someone who barely knows what printf, fopen, or #include are

3

The thing with C is that you probaby won't know you messed it up. It happens silently as memory gets corrupted.

Modern compilers are much more advanced but you still can overwrite stuff in memory with other stuff

4
infosec.pub

Put the gun away and throw that cpp book in the bin, fool. I brought The Linux Kernel Programming Guide, which is in C, and my own socks, which are wool. Now let's gets crackin.

51
Pickle_Jrreply
lemmy.dbzer0.com

I already use linux. My feet have been getting cold lately. it never occurred to me to get wool socks. Is this how it starts? Are skirts next?

8
lemmy.world

Unless you use goat wool socks. Then you can go for a old school hippie build. Sandals, long hair, tie dye shirt and go from there.

8

Socks were invented to be used in sandals, it's the one true way!

(Typed wearing big woolen socks in birkenstocks)

3
infosec.pub

Never touched rust, so I don't understand the hype. I'm not arguing against it, mind you, but I'm gathering, more and more, that it's worth a look. Maybe I'll look into it after work.

1
snekmuffinreply
lemmy.dbzer0.com

even all of that hype about memory safety and borrow checker you keep hearing aside, the actual coolest thing about Rust is how it does Traits instead of classes and that you can bind arbitrary data to enums

2
infosec.pub

Really? That's really cool. So, what's all the hate? Is there any actual merit to it, or is it just an "I'm better than you because I just am" mindset?

1
esareply
discuss.tchncs.de

The serious answer here likely has several components:

  1. Some people and businesses have invested a lot in languages that governments are now trying to deprecate. When someone is told that their assets may be stranding, and please move on to $NEWTHING, they're likely to get … grumpy. Both they and the government may be correct here, even if they're at odds—they have different scopes and concerns.
  2. Differing values. See e.g. Cantrill's "Platform as a reflection of values".
  • Rust highly values correctness, which will feel like a straitjacket to a lot of people.
  • It also moves as much error detection as it can to the compilation stage, which won't sit well with people who want to get something out the door ASAP and then find the bugs as they happen.
  • So it also encourages tackling complexity early rather than kicking the can down the road, which again isn't to everyone's preference.
5

This is a very detailed answer, and I greatly appreciate it. So, the subpoints on point 2 are benefits in my eyes. Just another reason to delve deeper into this language. Thanks!

2
Croquettereply
sh.itjust.works

More than half the points are just good engineering practice directly embedded in the language.

It tells a lot about the state of programming in general with the pushback we see with memory safe languages.

I'm down with Rust and I can't wait for official support for embedded Rust in chip manufacturers, because until then, very few clients will be okay with using unofficial Rust cargos for their products.

1

Yeah, that's the correctness focus. Some people dislike it as a straitjacket, some even take it as a personal insult because they see it as a skill issue. They, the good devs, shouldn't be held back like that (spoiler: they aren't as good as they think they are).

Personally I like that aspect of Rust, but I also write Python with a typechecker and a loong list of enabled lints in ruff. I can get the happy path done without it, but having just the happy path often isn't good enough.

Enforced correctness helps a lot with confidence for those of us who know we sometimes make bad assumptions or forget some nuance or detail. But it will be absolutely infuriating for people who can't stand being told they made an error, even one of omission.

2
lemmy.ml

Girl, I will wear whatever socks you want, but... pulls out my own gun. We're reading this damn book instead.

37

Honestly, I prefer King's book to any other for intro to C programming. K&R is a classic, and is really quite good for diving into some cool tricks (i.e. postfix operation wizardry).

But as a beginner, I can just say that King's book is much more digestible. The author holds your hand a lot more and assumes you only have a basic knowledge of programming and the UNIX command line.

That said, the exercises and simple projects do push you to demonstrate what you learned in each chapter as well as enforcing other Computer Science fundamentals like basic data structures (stacks, queues, linked lists) through demonstrations in the C language.

My plan is to revisit K&R after a few other books in C like Advanced Programming In The Unix Environment, Unix Network Programming, and The Linux Programming Interface. All while referencing Beej's Resources.

I feel like by then I'll hopefully have a more solid grasp on C and can then more aptly appreciate The K&R Book.

6
lemmy.world

I appreciate the usage of the pi 1 and not one of the newer versions.

15

Pi 1 was an amazing idea, I ordered one as a sonon as they were available and then never used it for anything. I've bought way to many pis since then.

4

Here's what we're gonna do. We're going to do the equivalent of x11 application network transparency but with wayland.

Kind of like streaming a desktop with sunshine, but on an app by app basis.

Also we're gonna make a client that work for it on android, windows and in a browser.

Then I'm going to fuck you in the ass

11

please don’t make me read another bjarne book. the last time i read one it made me want to stop programming

3
lemmy.zip

for command line apps bash, python, perl, ruby and similiar high level languages are more than enough. You can write some Kali Lincox the louder you are the less you hear network probe stuff with any of these, or even a storage optimizer (BleachBit is almost entirely written in Python, which is a very highly abstracted language implemented from C) Rust and C are only needed for performance-crtitical stuff (like rythm games) or/and directly interacting with hardware (drivers, firmware, system functions)

2
sepireply
piefed.social

Don't listen to the newbie above. You can use whatever language you are comfy with that works for your situation.

4
kekmacskareply
lemmy.zip

i never said you can't. But high level languages were made for high level programming, and low level for low level programming. If you only know C, sure, you can write a desktop music player, but it will be much harder than just using Java, or even Python, since both of these languages are known about their extensive prewritten libraries. And you have to write much less, which means less room for error. Using a high level language will also benefit you if you decide to port your app to a drasticly different operating system. You can use the same codebase for Python, and for Java too to seamlessly run the program on any other os supported by these languages. In C, you need to adjust a lot of things, i know from experience that Linux C source can compile and run on windows, but it is extremely rare and can introduce bugs. However, you are right that C is highly multifunctional. If you know it, you can write any low level software or desktop app. And it also runs mich faster than any high level intrepeted language. And even if i could be considered a beginner, i actually study software development and testing, so i have an idea what i'm talking about

3

"However you are right that..." I did not make the claim you are telling me I am right for making. I think a bot wrote this.

0

I would not throw Rust and C together in this.
Rust is low-level in terms of being usable for kernel and embedded development (due to not needing a runtime), but it's rather high-level in terms of the syntax offering lots of abstraction from the weirdness of the hardware.

Some of that not-needing-a-runtime does bleed into the syntax, but in my opinion, it's still higher level from a syntax perspective than Bash et al, because it brings in many functional aspects.

I guess, I'm also just bothered by you saying, you don't 'need' Rust for writing CLIs, when it's my favorite language for this.
To some degree, I do just find it ridiculous to launch a whole runtime when the user just wants the --help, but the argument parsing in Rust is also just really nice: https://rust-cli.github.io/book/tutorial/cli-args.html#parsing-cli-arguments-with-clap

2

Am I going too hard by making shortcuts to start and stop SSH on my steamdeck desktop for easier file transfer? Feels like a basic security step when connecting to other networks, while not wanting to remember the commands to enable, also wanting to avoid keeping the perms permanently open for the sake of unknown backdoors. Even added windows stating if it was started or stopped in the case of extra sauce or herb.

Ayy girl, we're going over and beyond with your network security, because we all do a fucky wucky from time to time.

2

Stroustroup textbooks aren't for Visual Studio? At least Programming: theory and practice?

1