pillaiindu

pillaiindu

Let's make the variable non-rebindable

I know that I’m a noob in front of the creator of Elixir, the core-team and many others in the forum, but whenever I’m explaining to my friends that Elixir’s data is immutable, they think if the variable is rebindable, may be the data isn’t immutable.
If the variable is non-rebindable, it will make it easier for the new-comers to consider the data immutable. Of course we can leave the variables rebindable inside the iex, but in the code it should be non-rebindable.

Just an idea!

Most Liked

gregvaughn

gregvaughn

It’s more than “just an idea”. It’s how Erlang works. And the Elixir core team is aware of that, but decided on a rebindable approach instead. Elixir is not going to change this feature. If it deeply matters to you, then I recommend you explore Erlang more deeply.

sasajuric

sasajuric

Author of Elixir In Action

Let’s try to unpick this argument.

First, let’s see a javascript example of mutability:

a = {}

// b holds a reference to the same data as a
b = a

// mutability: we're changing the data
a.x = 1

// data pointed to by b is implicitly changed
console.log(b) // {x: 1}

Now let’s see a javascript example of rebinding:

a = {}
b = a

// rebinding: a points to different data
a = {x: 1}

// rebinding a didn't change anything in b, hence it's not mutability
console.log(b) // {}

The former (mutability) is problematic because it’s much harder to reason about the code. For example if we invoke foo(a), we have no way of knowing if this will change something in a. We need to read the code of foo and all the code it invokes (recursively!) to reliably answer that. This is extremely tedious, prone to errors, and whatever assumptions we have about the code today can implicitly change tomorrow without us knowing it, for example if a team member changes some indirect dependency of foo.

The latter (variable rebinding) doesn’t suffer from such problems, because rebinding doesn’t change the data.

chrismcg

chrismcg

José wrote about rebinding in Elixir and Erlang in detail here:

ityonemo

ityonemo

Of course we can leave the variables rebindable inside the iex, but in the code it should be non-rebindable.

That’s exactly why it should stay the way it is. It’s really fantastic that what works in the repl works in code. If you really want this feature, you can turn it on in credo and activate it so you can’t pull request code that disobeys this rule (I do this). If you need an escape hatch, I’ve even committed an exception to credo where it disallows rebinding unless the variable ends in !

Where Next?

Popular in Discussions Top

jswny
I would like to better understand what the advantages/disadvantages of umbrella applications are compared to structuring your app as as s...
New
sashaafm
I’m trying to evaluate the best combo/stack for a BEAM Web app. Right now I’m exploring Yaws a bit, after having dealt with Phoenix for a...
New
jeramyRR
This is an interesting article to read. Elixir’s performance, like usual, is excellent. However, it seems like the high CPU usage is co...
New
laiboonh
Hi all, I am trying to convince my team to use liveview over the current react. What are some of the points where one should consider us...
New
axelson
Decided against including more info in the title, but the gist is that Plataformatec sponsored projects will continue with the assets bei...
New
arcanemachine
https://nitter.net/josevalim/status/1744395345872683471 https://twitter.com/josevalim/status/1744395345872683471
New
marciol
Please, let me know if this kind of discussion already took place in another topic . Hi all, how do you consider if is better to build ...
New
restack_oslo
Hello, Please pardon me for any faux paux. I am 46 and this is my first time on a forum of any kind. I wanted to to get answers from tho...
New
AstonJ
Can you believe the first professionally published Elixir book was published just 8 years ago? Since then I think we’ve seen more books f...
New
sergio
Kind of like when jquery came out, it was super necessary. Existing drag and drop libraries have a bunch of baggage to support old browse...
New

Other popular topics Top

siddhant3030
Hi, I have to write a raw query for one of my project. But till now I have used ecto queries and don’t have much experience writing raw ...
New
TunkShif
This post is an instruction guide to help you setup your Neovim for Elixir development from scratch. It includes general information on h...
274 41539 114
New
shahryarjb
Hello, I have map which I want to convert it to string like this: the map: %{last_name: "tavakkoli", name: "shahryar"} the string I ne...
New
stefanchrobot
What’s the safe way to decode a JSON string into a struct? I want to avoid calling String.to_atom. Jason.decode can give me a map with st...
New
jay1
Why is it that the mnesia database isn’t the most preferred database for use in Elixir/Phoenix?
New
stefanluptak
Hello everybody, usually, I use a 29" ultra-wide monitor for VSCode which can easily accomodate explorer (files panel) + file with code ...
New
Emily
I have VueJS GUIs with the project generated using Webpack. I have Elixir modules that will need to be used by the VueJS GUIs. I forese...
New
nsuchy
Hi. I’ve noticed that Windows Powershell has it’s own IEX command and you cannot access Elixir’s IEX due to the conflict. This isn’t a cr...
New
openscript
Hello! Sorry for this astonishing simple question, but I’m really stuck. I try to set up the intellij-elixir plugin, but I don’t know ho...
New
lanycrost
Hi everyone! I need implement if…else if…else condition from my elixir code, and anymore of this control flow structures not work proper...
New

We're in Beta

About us Mission Statement