Note: The attached image is a screenshot of page 31 of Dr. Charles Severance’s book, Python for Everybody: Exploring Data Using Python 3 (2024-01-01 Revision).
I thought =
was a mathematical operator, not a logical operator; why does Python use
=
instead of ==
, or
<=
instead of <==
, or
!=
instead of !==
?
Thanks in advance for any clarification. I would have posted this in the help forums of FreeCodeCamp, but I wasn’t sure if this question was too…unspecified(?) for that domain.
Cheers!
Edit: I think I get it now! Thanks so much to everyone for helping, and @FizzyOrange@programming.dev and @itslilith@lemmy.blahaj.zone in particular! ^_^
Yeah it’s confusing because in maths they are the same and use the same symbol but they are 100% not the same in programming, yet they confusingly used the same symbol. In fact they even used the mathematical equality symbol (
=
) for the thing that is least like equality (i.e. assignment).To be fair not all languages made that mistake. There are a fair few where assignment is like
Or
which is probably the most logical option because it really conveys the “store 20 in x” meaning.
Anyway on to your actual question… They definitely aren’t the same in programming. Probably the simplest way to think of it is that assignment is a command: make these things equal! and equality is a question: are these things equal?
So for example equality will never mutate it’s arguments.
x == y
will never changex
ory
because you’re just asking “are they equal?”. The value of that equality expression is a bool (true or false) so you can do something like:x == y
asks if they are equal and becomes a bool with the answer, and then the = stores that answer insidea
.In contrast
=
always mutates something. You can do this:And it will print 4. If you do this:
It will (if the language doesn’t complain at you for this mistake) print 3 because the == doesn’t actually change
a
.Ohhhhh! I think I get it now!
So
==
means “equals” and is a declaration of the state of things, while=
means "assigned the value of` and is a command toward a certain state of things. A description vs an action. An observation of a thing as opposed to effecting that thing.Is that about right?
Well == is a question or a query rather than a declaration of the state of things because it isn’t necessarily true.
You can write
which is perfectly valid code; it will just set
a
to befalse
, because the answer to the question “does 3 equal 4?” is no.I think you’ve got it anyway.
That’s exactly it. Some languages (e.g. Rust) make it even more clear¹, by following math notation for assignment even closer:
let x = 5;
¹ simplified Rust a little bit, there’s a bit more nuance
Thanks so much to you and @FizzyOrange@programming.dev for helping! This has been driving me crazy for like 3-4 weeks now! >_<