Whenever we use const qualifier with variable name, it becomes a read-only variable and get stored in .rodata segment. Any attempt to modify this read-only variable will then result in a compilation error: “assignment of read-only variable”.
In the below program, a read-only variable declared using the const qualifier is tried to modify:
prog.c: In function 'main': prog.c:5:9: error: assignment of read-only variable 'var'
Changing Value of a const variable through pointer
The variables declared using const keyword, get stored in .rodata segment, but we can still access the variable through the pointer and change the value of that variable. By assigning the address of the variable to a non-constant pointer, We are casting a constant variable to a non-constant pointer. The compiler will give warning while typecasting and will discard the const qualifier. Compiler optimization is different for variables and pointers. That is why we are able to change the value of a constant variable through a non-constant pointer.
Below program illustrates this:
prog.c: In function 'main': prog.c:6:16: warning: initialization discards 'const' qualifier from pointer target type [-Wdiscarded-qualifiers] int *ptr = &var; var = 12
Note: If we try to change the value through constant pointer then we will get an error because we are trying to change the read-only segment.