>백엔드 개발 >PHP 튜토리얼 >PHP의 참조, '&' 설명

PHP의 참조, '&' 설명

WBOY
WBOY원래의
2016-07-25 08:52:011064검색
  1. $a =& $b
  2. ?>
코드 복사

이는 $a와 $b가 동일한 변수를 가리킨다는 의미입니다. 참고: 여기서 $a와 $b는 정확히 동일합니다. $a가 $b를 가리키거나 그 반대가 아니라 $a와 $b가 같은 위치를 가리킵니다. 참조를 반환하는 함수와 new 연산자(PHP 4.0.4 이상)에서 동일한 구문을 사용할 수 있습니다.

  1. $bar =& new fooclass();
  2. $foo =& find_var($bar);
  3. ?>
코드 복사

참고: & 연산자를 사용하지 않으면 객체의 복사본이 생성됩니다. 클래스에서 $this를 사용하면 해당 클래스의 현재 인스턴스에 적용됩니다. &가 없는 할당은 인스턴스(예: 객체)를 복사하고 $this는 복사본에 적용되지만 항상 원하는 결과는 아닙니다. 성능 및 메모리 소비 문제로 인해 일반적으로 하나의 인스턴스에서만 작업하려고 합니다.

@ 연산자를 사용하여 생성자에서 @new와 같은 오류 메시지를 끌 수 있지만 &new 문을 사용할 때는 아무런 효과가 없습니다. 이는 Zend 엔진의 제한 사항이며 구문 분석 오류가 발생합니다.

참조가 하는 두 번째 일은 참조로 변수를 전달하는 것입니다. 이는 함수 내에서 지역 변수를 생성하여 수행되며 해당 변수는 호출 범위에서 동일한 내용을 참조합니다. 예를 들어:

  1. 함수 foo(&$var)

  2. {
  3. $var ;
  4. }

  5. $a=5;

  6. foo ($a);
  7. ?>
코드를 복사하면

$a가 6으로 변경됩니다. 이는 foo 함수에서 $var 변수가 $a가 가리키는 것과 동일한 것을 가리키기 때문입니다. 자세한 설명은 참조로 전달을 참조하세요. 참조가 하는 세 번째 일은 참조 반환입니다.

인용이 아닌 것은 무엇인가 앞서 언급했듯이 참조는 포인터가 아닙니다. 이는 다음 구문이 예상한 효과를 생성하지 않음을 의미합니다.

  1. 함수 foo(&$var)
  2. {
  3. $var =& $GLOBALS[ "baz "] ;
  4. }
  5. foo($bar);
  6. ?>
코드를 복사하세요

이렇게 하면 foo 함수가 만들어집니다. $var 변수는 함수가 호출될 때 $bar에 바인딩되지만 $GLOBALS[ "baz "]에 다시 바인딩됩니다. 참조 메커니즘을 통해 $bar를 함수 호출 범위 내의 다른 변수에 바인딩하는 것은 불가능합니다. 왜냐하면 foo 함수에는 $bar 변수가 없기 때문입니다($var로 표시되지만 $var에는 변수 내용만 있고 호출은 없습니다). 기호 테이블 이름-값 바인딩).

참조로 전달 함수가 인수 값을 수정할 수 있도록 함수를 참조하여 변수를 전달할 수 있습니다. 구문은 다음과 같습니다.

  1. 함수 foo(&$var)

  2. {
  3. $var ;
  4. }

  5. $a=5;

  6. foo ($a);
  7. // 여기서 $a는 6입니다
  8. ?>
  9. < /p>
코드 복사

함수 호출에는 참조 기호가 없으며 함수 정의에만 참조 기호가 있습니다. 함수 정의만으로도 매개변수가 참조로 올바르게 전달되기에 충분합니다.

다음을 참조로 전달할 수 있습니다. foo($a)

와 같은 변수

foo(new foobar())와 같은 새로운 문

함수에서 반환된 참조, 예:

  1. function &bar()
  2. {
  3. $a = 5;
  4. return $a;
  5. }
  6. foo(bar());
  7. ?>
코드 복사

자세한 설명은 참조 반환을 참조하세요.

다른 표현식은 참조로 전달할 수 없으며 결과는 정의되지 않습니다. 예를 들어, 참조로 전달하는 다음 예는 유효하지 않습니다.

  1. function bar() // 누락된 &
  2. {
  3. $에 주의하세요. a = 5;
  4. return $a;
  5. }
  6. foo(bar());

  7. foo($a = 5) // 변수가 아닌 표현식

  8. foo(5) // 변수가 아닌 상수
  9. ?>
코드 복사

이러한 조건은 PHP 4.0.4 이상 버전에서 사용할 수 있습니다.

참고로 반품 참조 반환은 참조가 바인딩되어야 하는 변수를 찾기 위해 함수를 사용하려는 경우에 사용됩니다. 참조를 반환할 때 다음 구문을 사용하세요.

  1. function &find_var($param)
  2. {
  3. return $found_var;
  4. }

  5. $foo =& find_var ($bar);

  6. $foo-> x = 2;
  7. ?>
코드 복사

이 예에서는 find_var 함수에 의해 반환된 객체의 속성이 설정됩니다(역자: $foo-> x = 2; 문 참조). 참조 구문을 사용하지 않는 것과 같습니다.

참고: 매개변수 전달과 달리 앰퍼샌드는 여기서 두 위치 모두에 사용되어야 합니다. 즉, 일반적인 복사본이 아닌 참조가 반환되었음을 나타내고 $foo가 일반적인 할당이 아닌 참조로 바인딩되었음을 나타내기 위한 것입니다.

참조 취소 참조 설정을 해제하면 변수 이름과 변수 내용 간의 바인딩이 끊어집니다. 이는 변수 내용이 삭제된다는 의미는 아닙니다. 예를 들어:

  1. $a = 1;
  2. $b =& $a;
  3. 설정 해제($a);
  4. ?>
코드

를 복사하면 $b가 설정 해제되지 않고 $a만 해제됩니다.

이것을 Unix의 연결 해제 호출과 비유하면 이해하는 데 도움이 될 수 있습니다.

견적 위치 지정 많은 PHP 구문 구조가 참조 메커니즘을 통해 구현되므로 위에서 참조 바인딩에 대해 언급한 모든 내용이 이러한 구조에도 적용됩니다. 참조에 의한 전달 및 반환과 같은 일부 구성은 이미 위에서 언급되었습니다. 참조를 사용하는 다른 구조는 다음과 같습니다.

글로벌 인용문 global $var를 사용하여 변수를 선언하면 실제로 전역 변수에 대한 참조가 생성됩니다. 이는 다음을 수행하는 것과 동일합니다.

  1. $var =& $GLOBALS[ "var "];
  2. ?>
코드 복사

예를 들어 unset $var는 전역 변수를 설정 해제하지 않는다는 의미입니다.

$이것 객체 메서드에서 $this는 항상 이를 호출하는 객체에 대한 참조입니다. 관심을 가질 만한 기사: 값으로 전달하는 PHP 참조에 대한 자세한 소개 예제를 통해 PHP에서 값 전달과 참조 전달의 차이점을 이해하세요 예제를 통해 PHP 주소 참조의 효율성 문제 살펴보기 php 참조주소 변수값 변경시 문제



성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.