>백엔드 개발 >PHP 튜토리얼 >PHP 고급 객체 구성에서 여러 생성자의 사용 사례 분석

PHP 고급 객체 구성에서 여러 생성자의 사용 사례 분석

黄舟
黄舟원래의
2017-07-02 09:58:221262검색

객체 구성은 PHP 객체 지향 프로그래밍 설계에서 중요한 주제입니다. 가장 간단한 경우에는 일반적인 생성자로도 충분하지만, 더 복잡한 디자인을 수행하려는 경우 생성자 관리가 어려워질 수 있습니다

다음은 PHP 고급 객체를 보여주기 위한 코드 예제입니다. 다중 사용 원리 건설 중 객체 건설을 위한 생성자.

<?php 
class classUtil {//这是一个参数处理的类 
public static function typeof($var){ 
if (is_object($var)) return get_class($var);//如果是对象,获取类名 
if (is_array($var)) return "array";//如果是数组,返回"array" 
if (is_numeric($var)) return "numeric";//如果是数字,返回"numeric" 
return "string";//
字符串
返回 "string" 
} 
public static function typelist($args){ 
return 
array_map
(array("self","typeof"),$args);//数组循环通过调用self::typeof处理$args中的每个元素 
} 
public static function callMethodForArgs($object,$args,$name="construct"){ 
$method=$name."_".implode("_",self::typelist($args));//implode 是把数组元素用"_"连接成一个字符串 
if (!is_callable(array($object,$method))){//is_callable()函数测试$object::$method是不是可调用的结构 
echo sprintf("Class %s has no methd &#39;$name&#39; that takes". 
"arguments (%s)",get_class($object),implode(",",self::typelist($args))); 
call_user_func_array(array($object,$method),$args);//call_user_func_array函数调用$object::$method($args) 
} 
} 
} 
class dateAndTime { 
private $timetamp; 
public function construct(){//自身的构造函数 
$args=func_get_args();//获取参数 
classUtil::callMethodForArgs($this,$args);//调用参数处理类的方法 
} 
public function construct_(){//参数为空的时候 
$this->timetamp=time(); 
} 
public function construct_dateAndTime($datetime){//为类自身的时候 
$this->timetamp=$datetime->getTimetamp(); 
} 
public function construct_number($timestamp){//为数字的时候 
$this->timetamp=$timestamp; 
} 
public function construct_string($string){//为时间型字符串时候 
$this->timetamp=strtotime($string); 
} 
public function getTimetamp(){//获取
时间戳
的方法 
return $this->timetamp; 
} 
} 
?>

사실 가장 중요한 것은 매개변수를 처리하는 것입니다. 매개변수가 문자이든 숫자이든 클래스이든 다양한 처리가 고급화되어 코드의 유연성이 높아집니다.

위 내용은 PHP 고급 객체 구성에서 여러 생성자의 사용 사례 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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