PHP의 어설션 함수 사용법에 대한 간략한 토론
이 글에서는 PHP에서 어설션 함수를 사용하는 방법을 설명합니다. 도움이 필요한 친구들이 모두 참고할 수 있기를 바랍니다.
저는 원래 Assertion 관련 함수가 PHPUnit과 같은 단위 테스트 컴포넌트에서 제공되는 줄 알았는데, 매뉴얼을 읽다가 Assert() Assertion 함수가 PHP 자체에 포함된 함수라는 것을 알게 되었습니다. 즉, 코드에서 간단한 테스트를 수행할 때 전체 단위 테스트 구성 요소를 완전히 소개할 필요는 없습니다.
assert() 주장 함수
assert(1==1); assert(1==2); // assert.exception = 0 时,Warning: assert(): assert(1 == 2) // assert.exception = 1 时,Fatal error: Uncaught AssertionError: 验证不通过
분명히 두 번째 코드 부분은 주장 검증을 통과할 수 없습니다. 이때 PHP는 경고 또는 예외 오류를 반환합니다. 가능한 오류 형식이 두 가지인 이유는 무엇입니까? php.ini에서 Assert.Exception을 off 또는 0으로 설정하면, 즉 이 매개변수의 기능을 끄면 프로그램은 위 코드의 주석과 마찬가지로 여전히 PHP5 형식으로 경고를 반환합니다. 동시에 try...catch를 통해서는 예외를 포착할 수 없습니다. 이 매개변수는 실제 예외 객체를 발생시킬지 여부를 실제로 제어합니다. 이 매개변수를 기본값(on 또는 1로 설정)으로 유지하면 예외가 직접 발생하고 프로그램이 종료됩니다.
위 코드에서 볼 수 있듯이 어설션의 첫 번째 매개변수는 표현식이며, bool 유형의 객체를 반환하는 표현식이 필요합니다. 문자열이나 숫자를 전달하면 어떻게 될까요?
// 设置 assert.exception = 0 进行多条测试 assert(" "); // Deprecated: assert(): Calling assert() with a string argument is deprecated // Warning: assert(): Assertion " " failed assert("1"); // Deprecated: assert(): Calling assert() with a string argument is deprecated assert(0); // Warning: assert(): assert(0) failed assert(1); assert("1==2"); // Deprecated: assert(): Calling assert() with a string argument is deprecated // Warning: assert(): Assertion "1==2" failed
분명히 첫 번째 매개변수의 표현식은 유형 강제를 거치게 되지만, 문자열 유형에는 더 이상 사용되지 않는 알림이 표시됩니다. 이는 Assert() 함수에 전달된 문자열 유형의 표현식 유형이 더 이상 사용되지 않음을 나타냅니다. 현재 테스트 버전은 7.3입니다. 향후 작업을 종료하는 오류나 예외가 직접 보고될 수 있습니다. 가장 큰 문제는 전달된 문자열 자체도 표현식인 경우 이 표현식의 내용을 기준으로 판단이 이루어지므로 마지막 코드와 마찬가지로 쉽게 모호해질 수 있다는 것입니다. 물론, 오래된 사용법은 아직 권장되지 않습니다.
다음으로 Assert() 함수의 다른 매개변수를 살펴보겠습니다. 두 번째 매개변수는 오류 정보를 정의하는 데 사용되는 문자열 또는 예외를 발생시키는 데 사용되는 예외 클래스입니다.
assert(1==1, "验证不通过"); assert(1==2, "验证不通过"); // Warning: assert(): 验证不通过 failed
문자열을 직접 입력하면 우리가 정의한 오류 메시지의 내용이 경고 메시지에 표시됩니다. 이것은 이해하기 매우 쉽습니다.
// 注意 assert.exception 设置不同的区别 assert(1==1, new Exception("验证不通过")); assert(1==2, new Exception("验证不通过")); // assert.exception = 1 时,Fatal error: Uncaught Exception: 验证不通过 // assert.exception = 0 时,Warning: assert(): Exception: 验证不通过
물론, 어설션이 예외를 발생시키도록 예외 클래스를 제공할 수도 있습니다. 기본적으로 이 예외가 발생하면 프로그램 실행이 중단됩니다. 이는 일반적인 예외 발생 프로세스입니다. try...catch를 사용하여 예외를 잡을 수 있습니다.
try{ assert(1==2, new Exception("验证不通过")); }catch(Exception $e){ echo "验证失败!:", $e->getMessage(), PHP_EOL; } // 验证失败!:验证不通过
어설션의 전반적인 작동에 영향을 미치는 또 다른 매개변수가 있는데, 그것은 php.ini의 zend.assertions 매개변수입니다. 여기에는 세 가지 값이 포함됩니다.
- 1, 일반적으로 테스트 환경에서 사용되는 코드를 생성 및 실행합니다.
- 0, 코드를 생성하지만 런타임 중에 전달됩니다.
- -1, 코드를 생성하지 않으며, 일반적으로 공식 환경에서 사용됩니다.
이 매개변수를 직접 구성하고 테스트할 수 있습니다. php.ini의 기본값은 1이며, 이는 Assert() 함수가 정상적으로 실행된다는 의미입니다.
assert_options() 및 php.ini의 해당 매개변수 구성
PHP의 어설션 함수는 어설션 기능과 관련된 일부 매개변수를 쉽게 설정하고 얻을 수 있는 Assert_options() 함수도 제공합니다. 설정할 수 있는 플래그는 다음과 같습니다.
플래그 | 기본값 | 설명
- | :-: | -:
assert_options(ASSERT_ACTIVE, 1); assert_options(ASSERT_WARNING, 1); assert_options(ASSERT_BAIL, 1); assert_options(ASSERT_CALLBACK, function($params){ echo "====faild====", PHP_EOL; var_dump($params); echo "====faild====", PHP_EOL; }); assert(1!=1); // ====faild==== // string(105) ".../source/一起学习PHP中断言函数的使用.php" // ====faild====
요약
어설션 함수의 사용과 구성을 배우고 익히면 앞으로 PHPUnit 단위 테스트를 배울 수 있는 기반이 마련될 수 있습니다. 물론 이 기능을 갖춘 것은 많지 않으므로 기억해 두세요!测试代码: https://github.com/zhangyue0503/dev-blog/blob/master/php/202005/source/%E4%B8%80%E8%B5%B7%E5%AD%A6%E4%B9%A0PHP%E4%B8%AD%E6%96%AD%E8%A8%80%E5%87%BD%E6%95%B0%E7%9A%84%E4%BD%BF%E7%94%A8.php
PHP 비디오 튜토리얼"
위 내용은 PHP의 어설션 함수 사용법에 대한 간략한 토론의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는

CakePHP는 오픈 소스 MVC 프레임워크입니다. 이를 통해 애플리케이션 개발, 배포 및 유지 관리가 훨씬 쉬워집니다. CakePHP에는 가장 일반적인 작업의 과부하를 줄이기 위한 여러 라이브러리가 있습니다.

이 튜토리얼은 PHP를 사용하여 XML 문서를 효율적으로 처리하는 방법을 보여줍니다. XML (Extensible Markup Language)은 인간의 가독성과 기계 구문 분석을 위해 설계된 다목적 텍스트 기반 마크 업 언어입니다. 일반적으로 데이터 저장 AN에 사용됩니다
