Skip to main content

Are parameters passed by reference or passed by value in method invocation in Java?

In programming, there are two ways to pass arguments to a method, pass-by-value and pass-by-reference:
  • When you have a pass-by-value parameter, a copy of the argument is stored into the memory location allocated for the formal parameter. In this case, any changes made to the formal parameter inside the method will not affect the value of the argument back in the calling method.
  • When a parameter is pass-by-reference, the memory address of the argument is passed to the method, making the formal parameter an alias for the argument. This means that changes made to the formal parameter inside the method will be reflected in the value of the argument when control is returned to the calling function.
Technically, all parameters in Java are pass-by-value.
All primitives are pass-by-value, period. When a primitive value is passed into a method, a copy of the primitive is made. The copy is what is actually manipulated in the method. So, the value of the copy can be changed within the method, but the original value remains unchanged.
For example:
public class TestPassPrimitive {
  static void doSomething(int m) {
    m = m + 2;
    System.out.println("The new value is " + m + ".");
  } 
  public static void main(String[] args) {
    int m = 5;
    System.out.println("Before doSomething, m is " + m + ".");
    doSomething(m);
    System.out.println("After doSomething, m is " + m + ".");
  }
}
The output result is
Before doSomething, m is 5.
The new value is 7.
After doSomething, m is 5.
Objects, however, work a bit differently. When you pass a Java object or array as a parameter, an object reference or array reference is passed into a method. The method can manipulate the attributes of the object that is referenced by the reference (formal parameter).
This reference is passed-by-value. What does this mean exactly?
  • Any direct changes made to the reference (formal parameter) inside the method will be reflected in the value of the object back in the calling method;
  • If you were to reassigns a new instantiation of an object or array to the reference (formal parameter) within the method, the reassignment only affects the copy reference (formal parameter), not the original reference passed by the caller. After that, any direct changes made to the reference (formal parameter) inside the method will be reflected the new reassigned object or array.
The subtleties of passing parameters will become clearer as you write more and more methods. Experimentation is the best form of learning. For example:
class TestReferenceParameter{
  public static void main (String args[]) {
    String s1 = "one";
    String s2 = doSomething(s1);
    System.out.println(s1 + " " + s2);
  }


  static String doSomething(String s1) {
    s1 = s1 + " two";
    System.out.println(s1 + " ");
    return "three";
  }
}
The output result is
one two 
one three
 

Comments

  1. passing primitive variables is by value while objects is by reference

    http://www.thejavacode.com

    ReplyDelete

Post a Comment

Popular posts from this blog

Asynchronous Vs. Synchronous Communications

Synchronous (One thread):   1 thread -> |<---A---->||<----B---------->||<------C----->| Synchronous (multi-threaded):   thread A -> |<---A---->| \ thread B ------------> ->|<----B---------->| \ thread C ----------------------------------> ->|<------C----->|

WebSphere MQ Interview Questions

What is MQ and what does it do? Ans. MQ stands for MESSAGE QUEUEING. WebSphere MQ allows application programs to use message queuing to participate in message-driven processing. Application programs can communicate across different platforms by using the appropriate message queuing software products. What is Message driven process? Ans . When messages arrive on a queue, they can automatically start an application using triggering. If necessary, the applications can be stopped when the message (or messages) have been processed. What are advantages of the MQ? Ans. 1. Integration. 2. Asynchrony 3. Assured Delivery 4. Scalability. How does it support the Integration? Ans. Because the MQ is independent of the Operating System you use i.e. it may be Windows, Solaris,AIX.It is independent of the protocol (i.e. TCP/IP, LU6.2, SNA, NetBIOS, UDP).It is not required that both the sender and receiver should be running on the same platform What is Asynchrony? Ans. With messag...

Advantages & Disadvantages of Synchronous / Asynchronous Communications?

  Asynchronous Communication Advantages: Requests need not be targeted to specific server. Service need not be available when request is made. No blocking, so resources could be freed.  Could use connectionless protocol Disadvantages: Response times are unpredictable. Error handling usually more complex.  Usually requires connection-oriented protocol.  Harder to design apps Synchronous Communication Advantages: Easy to program Outcome is known immediately  Error recovery easier (usually)  Better real-time response (usually) Disadvantages: Service must be up and ready. Requestor blocks, held resources are “tied up”.  Usually requires connection-oriented protocol