十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
The Java programming language always uses call by value. That means that the method gets a copy of all parameter values. In particular, the method cannot modify the contents of any parameter variables that are passed to it.
成都创新互联公司专业为企业提供开州网站建设、开州做网站、开州网站设计、开州网站制作等企业网站建设、网页设计与制作、开州企业网站模板建站服务,十多年开州做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。
[@more@]For example, consider the following call:
double percent = 10; harry.raiseSalary(percent);
No matter how the method is implemented, we know that after the method call, the value of percent is still 10.
Let us look a little more closely at this situation. Suppose a method tried to triple the value of a method parameter:
public static void tripleValue(double x) // doesn't work { x = 3 * x; }
Let's call this method:
double percent = 10; tripleValue(percent);
However, this does not work. After the method call, the value of percent is still 10. Here is what happens:
x is initialized with a copy of the value of percent (that is, 10).
x is tripled—it is now 30. But percent is still 10 (see Figure 4-6).
The method ends, and the parameter variable x is no longer in use.
There are, however, two kinds of method parameters:
Primitive types (numbers, Boolean values)
Object references
You have seen that it is impossible for a method to change a primitive type parameter. The situation is different for object parameters. You can easily implement a method that triples the salary of an employee:
public static void tripleSalary(Employee x) // works { x.raiseSalary(200); }
When you call
harry = new Employee(. . .); tripleSalary(harry);
then the following happens:
x is initialized with a copy of the value of harry, that is, an object reference.
The raiseSalary method is applied to that object reference. The Employee object to which both x and harry refer gets its salary raised by 200 percent.
The method ends, and the parameter variable x is no longer in use. Of course, the object variable harry continues to refer to the object whose salary was tripled (see Figure 4-7).
As you have seen, it is easily possible—and in fact very common—to implement methods that change the state of an object parameter. The reason is simple. The method gets a copy of the object reference, and both the original and the copy refer to the same object.
Many programming languages (in particular, C++ and Pascal) have two methods for parameter passing: call by value and call by reference. Some programmers (and unfortunately even some book authors) claim that the Java programming language uses call by reference for objects. However, that is false. Because this is such a common misunderstanding, it is worth examining a counterexample in detail.
Let's try to write a method that swaps two employee objects:
public static void swap(Employee x, Employee y) // doesn't work { Employee temp = x; x = y; y = temp; }
If the Java programming language used call by reference for objects, this method would work:
Employee a = new Employee("Alice", . . .); Employee b = new Employee("Bob", . . .); swap(a, b); // does a now refer to Bob, b to Alice?
However, the method does not actually change the object references that are stored in the variables a and b. The x and y parameters of the swap method are initialized with copies of these references. The method then proceeds to swap these copies.
// x refers to Alice, y to Bob Employee temp = x; x = y; y = temp; // now x refers to Bob, y to Alice
But ultimately, this is a wasted effort. When the method ends, the parameter variables x and y are abandoned. The original variables a and b still refer to the same objects as they did before the method call (see Figure 4-8).
This discussion demonstrates that the Java programming language does not use call by reference for objects. Instead, object references are passed by value.
Here is a summary of what you can and cannot do with method parameters in the Java programming language:
A method cannot modify a parameter of primitive type (that is, numbers or Boolean values).
A method can change the state of an object parameter.
A method cannot make an object parameter refer to a new object.