C and C++ support pointers, which is different from most other programming languages such as Java, Python, Ruby, Perl and PHP as they only support references. But interestingly, C++, along with pointers, also supports references.
On the surface, both references and pointers are very similar as both are used to have one variable provide access to another. With both providing lots of the same capabilities, it’s often unclear what is different between these mechanisms. In this article, I will try to illustrate the differences between pointers and references.
Pointers : A pointer is a variable that holds the memory address of another variable. A pointer needs to be dereferenced with the * operator to access the memory location it points to.
References : A reference variable is an alias, that is, another name for an already existing variable. A reference, like a pointer, is also implemented by storing the address of an object.
A reference can be thought of as a constant pointer (not to be confused with a pointer to a constant value!) with automatic indirection, i.e., the compiler will apply the * operator for you.
Differences :
1. Initialization: A pointer can be initialized in this way:
int a = 10;We can declare and initialize pointer at same step or in multiple line.
2. While in references,
int a = 10;NOTE: This difference may vary from compiler to compiler. The above difference is with respect to Turbo IDE.
3. Reassignment: A pointer can be re-assigned. This property is useful for the implementation of data structures like a linked list, a tree, etc. See the following example:
int a = 5;4. On the other hand, a reference cannot be re-assigned, and must be assigned at initialization.
int a = 5;5. Memory Address: A pointer has its own memory address and size on the stack, whereas a reference shares the same memory address with the original variable and takes up no space on the stack.
int &p = a;6. NULL value: A pointer can be assigned NULL directly, whereas a reference cannot be. The constraints associated with references (no NULL, no reassignment) ensure that the underlying operations do not run into an exception situation.
7. Indirection: You can have a pointer to pointer (known as a double pointer) offering extra levels of indirection, whereas references only offer one level of indirection. For example,
In Pointers,8. Arithmetic operations: Various arithmetic operations can be performed on pointers, whereas there is no such thing called Reference Arithmetic (however, you can perform pointer arithmetic on the address of an object pointed to by a reference, as in &obj + 5).
References | Pointers | |
---|---|---|
Reassignment | The variable cannot be reassigned in Reference. | The variable can be reassigned in Pointers. |
Memory Address | It shares the same address as the original variable. | Pointers have their own memory address. |
Work | It is referring to another variable. | It is storing the address of the variable. |
Null Value | It does not have null value. | It can have value assigned as null. |
Arguments | This variable is referenced by the method pass by value. | The pointer does it work by the method known as pass by reference. |
When to use What
The performances are exactly the same as references are implemented internally as pointers. But still, you can keep some points in your mind to decide when to use what:
Quoted in C++ FAQ Lite : Use references when you can, and pointers when you have to. References are usually preferred over pointers whenever you don’t need “reseating”. This usually means that references are most useful in a class’s public interface. References typically appear on the skin of an object, and pointers on the inside.
The exception to the above is where a function’s parameter or return value needs a “sentinel” reference — a reference that does not refer to an object. This is usually best done by returning/taking a pointer, and giving the “nullptr” value this special significance (references must always alias objects, not a dereferenced null pointer).