this post was submitted on 21 Jul 2023
1241 points (99.8% liked)

Programmer Humor

32464 readers
442 users here now

Post funny things about programming here! (Or just rant about your favourite programming language.)

Rules:

founded 5 years ago
MODERATORS
 
top 41 comments
sorted by: hot top controversial new old
[–] TheSaneWriter@lemmy.thesanewriter.com 72 points 1 year ago (2 children)

This is a really good way of explaining the difference.

[–] 0ops@lemm.ee 93 points 1 year ago* (last edited 1 year ago) (1 children)

Nah, tcp still yeats the baby, it just verifies that it was caught unbruised, or at all. If it wasn't that's ok. Try again. Yeet the baby's little sister

[–] InverseParallax@lemmy.world 10 points 1 year ago

You got that baby? Great, I'll send the next 500 much faster, tell me when you drop one and I'll slow down again.

[–] becool@kbin.social 14 points 1 year ago (7 children)

So, UDP just sends it out there and anyone can intercept it?

[–] r00ty@kbin.life 43 points 1 year ago (1 children)

No. Both UDP and TCP can be intercepted the same. The difference is that UDP sends a packet to an address. But doesn't have any in built system to check that it arrived, that it arrived intact or to resend if it didn't. There's also no built in way to protect against spoofing or out of order packet delivery. But generally implementations will handle the ones that are important of those themselves.

TCP establishes a circuit, packets are sent, verified and resent if required until the original data, in the correct order is delivered to the application. Also there is some protection against spoofing with sequence numbering. The downside is that time sensitive data might be delayed because of the retransmission and re-assembling. Which is why time sensitive streams like VoIP are usually sent over UDP.

[–] Celivalg@iusearchlinux.fyi 13 points 1 year ago (1 children)

Btw, on my device you sent the message -110min ago, not 110, -110

Welcome, traveler from the future

[–] r00ty@kbin.life 20 points 1 year ago

Yeah, this is a known interoperability thing between kbin and lemmy. So, I'm afraid I can't give you this week's lottery numbers ahead of time.

[–] Clent@lemmy.world 28 points 1 year ago (4 children)

No. UDP is at the packet level. Interception is a different layer.

To use to today's language, UDP yeets the packets at you as fast as it can generate them.

It doesn't care if you catch any of them.

Don't yeet the baby.

[–] b3nsn0w@pricefield.org 40 points 1 year ago (1 children)

actually, do yeet the baby if you have an application with different needs. for example, if you want to play a game, you're better off yeeting 60 babies a second and just hope that whoever is on the side catches enough of them to get a smooth stream of babies, than making sure every baby is handed gently to the next person and get the whole line clogged up the moment anything disrupts it. if you just use the yeetomatic 3000 you're always getting fresh babies on the other end, a few might just be dropped in the process

[–] Marxine@lemmy.ml 18 points 1 year ago* (last edited 1 year ago)

Getting a smooth stream of babies is a sentence that has no right in being this funny. I wheezed hard

[–] MxM111@kbin.social 7 points 1 year ago (1 children)

Don’t yeet the baby.

or at least care if you catch any of them.

[–] andrew@lemmy.stuart.fun 5 points 1 year ago (3 children)

I mean generally, I don't think we yeet babies. We yeet lots of things, but usually not babies.

[–] over_clox@lemmy.world 5 points 1 year ago
[–] over_clox@lemmy.world 4 points 1 year ago
[–] over_clox@lemmy.world 4 points 1 year ago
[–] Parallax@kbin.social 3 points 1 year ago* (last edited 1 year ago) (1 children)

What do you mean interception is at a different layer? You can capture at any layer as long as the payload isn't encrypted, and if it is, you still get layers 1 through 4 (Physical, Link, Network, and Transport).

[–] andrew@lemmy.stuart.fun 7 points 1 year ago

UDP is a transport protocol. OSI layer 4. It sits atop the packet (network/L3) layer which is where IP dictates where a packet is going. A broadcast or multicast IP address would mean it can be observed by many machines, but unicast is still the most common, and is routed to just one machine.

[–] UltraMagnus0001@lemmy.world 1 points 1 year ago

Is it like multicast or are they the same?

[–] thisbenzingring@lemmy.sdf.org 7 points 1 year ago

It's not so much that anyone can intercept it, it's more that the sender just blasts it and no acknowledgement so there's lots of potential for loss

[–] TheSaneWriter@lemmy.thesanewriter.com 5 points 1 year ago* (last edited 1 year ago) (2 children)

From what I can tell yes. There's no established connection, the data is sort of just broadcasted.

Edit: I was operating under a misunderstanding, please refer to andrew's response.

[–] andrew@lemmy.stuart.fun 8 points 1 year ago

Broadcast would mean it's sent to anyone. UDP packets still usually have a unicast address and thus are routed by routers and switches to specific machines, but as a connectionless protocol, UDP never validates which, if any, packets are received by the recipient like TCP does. If any verification is needed that needs to be handled higher in the OSI stack. E.g. by the application layer.

[–] exscape@kbin.social 5 points 1 year ago

No no, it's not "broadcasted". It still has a fixed sender and receiver IP address, but UDP doesn't verify whether the receiver got the data or not. You can implement that over UDP, but you have to do it yourself.

With TCP, the packet will retransmitted automatically if the receiver didn't tell the sender "yep, I got it".

[–] Lith@lemmy.sdf.org 4 points 1 year ago

The benefit is that you don't need to wait for verification from the user that they got the packet before you can send the next group of packets. If you're, say, watching a stream, it's not important that you received the packets because that's just a few skipped frames or a second of lag, whereas the tradeoff on overhead is pretty big.

TCP is more important with like file downloads where it's okay if it takes a couple hours to get a really big file as long as that file isn't corrupted or missing any data.

[–] Parallax@kbin.social 3 points 1 year ago

You'd have to be somewhere in the route from A to B to intercept it. But TCP is no different in that regard.

TCP is connection based so both sides need to agree to connect before data is exchanged. UDP is connectionless, so it will send data from A to B (and vice versa) regardless of if the other side is available.

[–] UnverifiedAPK@lemmy.ml 2 points 1 year ago

No, instead of using TLS for encryption (like most TCP traffic) UDP will use things like DTLS and SIP

Or if you're asking about the actual transport it's more like TCP is going to your friend's house and calling your mom to let her know you're there vs UDP is going to their house and not calling.

[–] Parallax@kbin.social 41 points 1 year ago (1 children)

Wanna hear a UDP joke?

Nevermind, you wouldn't get it.

[–] netburnr@lemmy.world 21 points 1 year ago (1 children)
[–] Colombo@kbin.social 5 points 1 year ago

"not get You" Don't forget the packet loss and non-ordered packets.

[–] superminerJG@lemmy.world 29 points 1 year ago

Alice and Bob are friends at ${university_name}. At ${date_time} they cross paths.

Alice: Hi, I want to tell you a TCP joke.

Bob: Sure, I'm ready to hear the TCP joke.

Alice: Alright,I am going to tell you the TCP joke.

Alice: Here's the actual joke. It's hilarious.

Bob: laughs hysterically

Alice: I'm glad you liked my joke.

Alice: Alright, that was the TCP joke.

Bob: Thanks for telling me about it.

Bob: So, that's it I guess?

Alice: Yeah, that's about all I wanted to tell you.

Alice and Bob part ways and run off to their next classes.

[–] kira_ananta@lemmy.blahaj.zone 28 points 1 year ago (3 children)

Yeahhhh I get the joke but I wish the meme didn't do it in a racist way. Why is the TCP baby white and the UDP baby not?

[–] bloodfart@lemmy.ml 20 points 1 year ago

Because udp packets are targeted for harassment by border devices like firewalls more often.

[–] Psionicsickness@reddthat.com 18 points 1 year ago (1 children)

Please stop. It's not intentional. Stop basing your judgment on people and actions with an acute view of their skin color. Just see two sets of people. Thanks.

[–] igorkraw@lemmy.ml 8 points 1 year ago (2 children)

Please stop.

In a world where there is racism, acting like racist themes don't exist only helps prolong it.

One set of of people here was drawn white (and responsible with a child), the other was drawn black (and irresponsible). That's worth critiquing, intentional or not.

Acting racist doesn't mean you are literally Satan, it means you are acting racist. Not stopping after people point it out and acting defensive and in denial is worse than thoughtlessly doing something racist, being told off and then correcting

[–] Llewellyn@lemmy.ml 13 points 1 year ago

You're the part of the problem.

[–] AnarchoYeasty@beehaw.org 1 points 1 year ago (1 children)

Would you feel better about this if it was a stock photo of a white woman yeeting their baby rather than using a comic? A comic that the meme maker didn't create? Should the meme maker recolor the baby and woman white to make things better for you? This isn't racist because one of the meme images happens to be of black people.

[–] igorkraw@lemmy.ml 2 points 1 year ago
  1. Yes
  2. I don't care about who created it, the composition was done by the creator
  3. What is the line of "racist" for you? Before we argue this further, let's establish what is racist and what isn't
[–] vanZuider@feddit.de 22 points 1 year ago

Old but gold.

[–] Amilo159@lemmy.world 18 points 1 year ago

Hey, that's racist!

[–] Dominic8999@lemm.ee 4 points 1 year ago

Made me kinda chuckle ngl

[–] epenance@lemmy.dosh.dk 3 points 1 year ago

Haha giggled not gonna lie

load more comments
view more: next ›