Home >Backend Development >PHP Tutorial >Detailed explanation of PHP references_PHP tutorial

Detailed explanation of PHP references_PHP tutorial

WBOY
WBOYOriginal
2016-07-13 10:03:56799browse

Detailed explanation of PHP citations

This article shows you a comprehensive introduction to PHP citations. It is very detailed and comes with examples. It is a very good article and is recommended to everyone in need. Friends, please refer to it.

What is a quote

Quoting in PHP means accessing the same variable content with different names. This is not like a C pointer; instead, the reference is a symbol table alias. Note that in PHP, variable names and variable contents are different, so the same content can have different names. The closest analogy is Unix's filenames and the files themselves - the variable names are the directory entries, and the variable contents are the files themselves. References can be thought of as hardlinks in Unix file systems.

What does a quote do

PHP’s references allow two variables to point to the same content. Meaning, when doing this:

The code is as follows:


$a =& $b;
?>

This means $a and $b point to the same variable.

Note:

$a and $b are exactly the same here. It’s not that $a points to $b or vice versa, but that $a and $b point to the same place.

Note:

If an array with a reference is copied, its value will not be dereferenced. The same is true for passing array values ​​to functions.

Note:

If an undefined variable is assigned by reference, passed by reference, or returned by reference, the variable will be automatically created.

Example #1 Using references to undefined variables

The code is as follows:


function foo(&$var) { }
foo($a); // $a is "created" and assigned to null
$b = array();
foo($b['b']);
var_dump(array_key_exists('b', $b)); // bool(true)
$c = new StdClass;
foo($c->d);
var_dump(property_exists($c, 'd')); // bool(true)
?>

The same syntax can be used in functions, which return references, and in the new operator (PHP 4.0.4 and later):

The code is as follows:


$bar =& new fooclass();
$foo =& find_var($bar);
?>

As of PHP 5, new automatically returns a reference, so using =& here is obsolete and produces an E_STRICT level message.

Note:

Not using the & operator causes a copy of the object to be generated. If you use $this in a class, it will apply to the current instance of that class. Assignment without & will copy the instance (e.g. object) and $this will be applied to the copy, which is not always the desired result. Due to performance and memory consumption issues, you usually only want to work on one instance.

Although it is possible to suppress any error messages in a constructor using the @ operator, such as @new, this has no effect when using a &new statement. This is a limitation of the Zend engine and will cause a parsing error.

Warning

If a reference is assigned to a variable declared as global inside a function, the reference is only visible inside the function. This can be avoided by using the $GLOBALS array.

Example #2 Reference global variables within a function

The code is as follows:


$var1 = "Example variable";
$var2 = "";
function global_references($use_globals)
{
global $var1, $var2;
if (!$use_globals) {
$var2 =& $var1; // visible only inside the function
} else {
$GLOBALS["var2"] =& $var1; // visible also in global context
}
}
global_references(false);
echo "var2 is set to '$var2'n"; // var2 is set to ''
global_references(true);
echo "var2 is set to '$var2'n"; // var2 is set to 'Example variable'
?>

Think of global $var; as shorthand for $var =& $GLOBALS['var'];. Thus assigning another reference to $var only changes the reference to the local variable.
Note:

If a variable with a reference is assigned a value in a foreach statement, the referenced object is also changed.

Example #3 Quotation and foreach statement

The code is as follows:


$ref = 0;
$row =& $ref;
foreach (array(1, 2, 3) as $row) {
// do something
}
echo $ref; // 3 - last element of the iterated array
?>

The second thing a reference does is pass a variable by reference. This is accomplished by creating a local variable within the function and that variable references the same content in the calling scope. For example:

The code is as follows:


function foo(&$var)
{
$var++;
}

$a=5;
foo($a);
?>

will change $a to 6. This is because in function foo the variable $var points to the same thing that $a points to. See Passing by Reference for a more detailed explanation.

The third thing a reference does is reference return.

What quotes are not

As mentioned before, references are not pointers. This means that the following structure will not produce the expected effect:

The code is as follows:


function foo(&$var)
{
$var =& $GLOBALS["baz"];
}
foo($bar);
?>

This will cause the $var variable in the foo function to be bound to $bar when the function is called, but then re-bound to $GLOBALS["baz"]. It is not possible to bind $bar to another variable within the function call scope through the reference mechanism, because there is no variable $bar in function foo (it is represented as $var, but $var only has the variable content and no call symbol table name-to-value binding). You can use reference returns to reference variables selected by the function.

Pass by reference

You can pass a variable to a function by reference so that the function can modify the value of its argument. The syntax is as follows:

The code is as follows:


function foo(&$var)
{
$var++;
}
$a=5;
foo($a);
// $a is 6 here
?>

Note that there are no reference symbols in function calls - only in function definitions. The function definition alone is enough for parameters to be passed correctly by reference. In recent versions of PHP, if you use & in foo(&$a); you will get a warning that "Call-time pass-by-reference" is deprecated.

The following can be passed by reference:

Variable, such as foo($a)
New statement, such as foo(new foobar())
A reference returned from a function, for example:

The code is as follows:


function &bar()
{
$a = 5;
return $a;
}
foo(bar());
?>

For detailed explanation, see reference return.
Any other expression cannot be passed by reference, and the result is undefined. For example, the following example of passing by reference is invalid:

The code is as follows:


function bar() // Note the missing &
{
$a = 5;
return $a;
}
foo(bar()); // Causes fatal error since PHP 5.0.5
foo($a = 5) //Expression, not variable
foo(5) // Causes fatal error
?>

These conditions are available in PHP 4.0.4 and later versions.

Return by reference
Reference return is used when you want to use a function to find which variable the reference should be bound to. Don't use return references to increase performance, the engine is smart enough to optimize it itself. Only return references if there is a valid technical reason! To return a reference, use this syntax:

The code is as follows:


class foo {
public $value = 42;
public function &getValue() {
return $this->value;
}
}
$obj = new foo;
$myValue = &$obj->getValue(); // $myValue is a reference to $obj->value, which is 42.
$obj->value = 2;
echo $myValue; // prints the new value of $obj->value, i.e. 2.
?>

In this example, the properties of the object returned by the getValue function will be assigned values ​​instead of copied, just like without using reference syntax.

Note: Unlike parameter passing, the ampersand must be used in both places here - indicating that a reference is returned, not a usual copy, and also indicating that $myValue is bound as a reference, not Usual assignment.

Note: If you try to return a reference from a function like this: return ($this->value);, this will not work because you are trying to return the result of an expression rather than a referenced variable. You can only return reference variables from functions - there is no other way. If code attempts to return the result of a dynamic expression or the new operator, an E_NOTICE error is issued starting with PHP 4.4.0 and PHP 5.1.0.

The code is as follows:


function &test(){
static $b=0;//Declare a static variable
$b=$b+1;
echo $b;
return $b;
}
$a=test();//This statement will output the value of $b as 1
$a=5; $a=test();//This statement will output the value of $b as 2
$a=&test();//This statement will output the value of $b as 3
$a=5; $a=test();//This statement will output the value of $b as 6
?>

Calling a function using $a=test() only assigns the value of the function to $a, and any changes to $a will not affect $b in the function. However, through $a=&test( ) method, its function is to point the memory address of the $b variable in return $b and the memory address of the $a variable to the same place, which produces the equivalent of this effect ($a=&b;) So changing the value of $a also changes the value of $b, so after executing $a=&test(); $a=5;, the value of $b becomes 5.

Unquote

When you unset a reference, you just break the binding between the variable name and the variable content. This does not mean that the variable contents are destroyed. For example:

The code is as follows:


$a = 1;
$b =& $a;
unset($a);
?>

Won’t unset $b, just $a.

An analogy between this and Unix’s unlink call may help to understand.

Reference positioning

Many PHP syntax structures are implemented through the reference mechanism, so everything mentioned above about reference binding applies to these structures as well. Some constructs, such as pass-by-reference and return, have already been mentioned above. Other structures that use references are:

global quote

When you declare a variable with global $var you actually create a reference to the global variable. That is the same as doing this:

The code is as follows:


$var =& $GLOBALS["var"];
?>

This means that, for example, unset $var will not unset a global variable.

The results of using unset($a) and $a=null are different. If the block of memory has only one mapping of $a, then unset($a) is equivalent to $a=null. The reference count of the memory becomes 0 and it is automatically recycled; if the block of memory has two mappings of $a and $b , then unset($a) will cause $a=null and $b remains unchanged, and $a=null will cause $a=$b=null.

Cause: Assigning a variable to null will cause the reference count of the memory block corresponding to the variable to be directly set to 0 and automatically recycled.

$this
In an object method, $this is always a reference to the object that calls it.

The role of quotation

If the program is relatively large, there are many variables referencing the same object, and you want to clear it manually after using the object, I personally recommend using the "&" method, and then clearing it with $var=null. Other times, use it It's the default method of php5. In addition, for transferring large arrays in php5, it is recommended to use the "&" method, after all, it saves memory space.

Here’s another little episode. The pointing (similar to pointer) function of the address in PHP is not implemented by the user himself, but is implemented by the Zend core. The reference in PHP adopts the principle of "copy-on-write", that is, unless When a write operation occurs, variables or objects pointing to the same address will not be copied.

In layman terms

1: If there is the following code

The code is as follows:


$a="ABC";
$b=$a;
?>

In fact, at this time, $a and $b both point to the same memory address, rather than $a and $b occupying different memories.

2: If you add the following code to the above code

The code is as follows:


$a="EFG";

Since the data in the memory pointed to by $a and $b needs to be rewritten, the Zend core will automatically determine at this time to automatically produce a data copy of $a for $b and re-apply for a piece of memory for storage.

The above is all about PHP quotation, I hope you all like it.

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/966921.htmlTechArticleDetailed explanation of PHP citations. This article shows you a comprehensive introduction to PHP citations. It is very detailed and has examples. It is an article A very good article, I recommend it to friends in need. Quote...
Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn