一、PHP基础语法 变量到数组
<?php //phpinfo(); /* 变量 $a=1;//不分配空间 echo "\$a=".$a; echo "<br/>"; var_dump($a);// 结果为NULL echo "hello worrld";*/ /* int型最大能表示多大 echo "<br/>".PHP_INT_SIZE; echo "<br/>".PHP_INT_MAX;//(2的31次方-1) 31:4*8-1个符号位 $a=-2147483648; echo "<br/>".$a; var_dump($a);//超过int型 范围 则会变为float类型*/ /* 布尔值 $d=0.0; if(!$d){ echo "!!"; }*/ /* 浮点数 浮点数精度是14(从左边开始,第一个非0就是精度的开始)*/ /*字符型 单引号和双引号区别 $d=90; $d1="$d"; $d2='$d'; echo $d1; echo $d2;*/ //$a=7/5.1; //echo $a; # === 包括类型也相等 /*$a=2; $b=2.0; if($a!=$b) { echo"!="; } if($a!==$b)# !== 包括类型也不相等 { echo "!=="; }*/ /* &&和||只要前面的一个为真假即不执行后一个 and 和 or 则不是 or的优先级比=低 所以 $e=false or true; //结果为false,因为此时$e先赋值为FALSE var_dump($e); $f=true and false;//结果为true,因为此时$e先赋值为true var_dump($f);*/ /*字符串拼接 $a="1";$b="2"; $c=$a.$b; */ /* 对象类型运算符 class Dog{} $dog=new Dog; var_dump($dog instanceof Dog); $a=3; echo $a++*3;//9*/ /*常量 define("TAX_INT",21); #$TAX_INT=9; echo TAX_INT; const TAX_TWO=0.3; echo "<br/>".TAX_TWO; */ /* #require 'other.php';//不会判断是否重复,可能导致重复输出 require_once 'other.php';// 先判断是否有重复引入 #include '111other.php'; #include_once 'other.php'; #require 和include区别: #include如果出现了错误会继续执行, #而require则会终止程序 #echo "22"; $i=2; $result=getNum($i);//传值,也可以传地址& echo $result;*/ /*全局变量 global $a=1; function get() { global $a;//可作用于局部内了 $a++; } get(); echo $a; */ /*数组初始化 //$array=array(1.2,12,"wrwe",true); //echo count($array); $arr=array("log"=>"daomul","mima"=>123); echo count($arr)."<br/>"; foreach($arr as $key=>$val) { echo $key."=".$val."<br/>"; } $arr2=array(""=>"32",1=>"fdsf",23,23); echo $arr2[""]."<br/>"; echo $arr2[2]."<br/>"; #使用true作为下标,即是1 ,false :0; null:"" $arr3=array(123.4=>"arr3"); echo $arr3[123]."<br/>"; #显示详细数组信息 print_r($arr3); echo "<br/>"; var_dump($arr3); #数组可以动态增长 $arr4=array(2,3); echo $arr4[1]."<br/>"; $arr4[2]='11 22 333 444'; #echo $arr4[2]; #字符串的拆分 explode $arr=explode(" ",$arr4[2]); print_r($arr); foreach($arr as $key=>$val)# (要循环的数组 as 数组下标变量) { echo "<br/>$key=>$val"; } echo "<br/>".$arr[1]; unset($arr[1]);#销毁数组元素后,关键字下标不会被重新填充组合 print_r($arr);*/ /*数组运算 叠加 $a=array("a"=>12,"b"=>23); $b=array("a"=>21,"c"=>43); $a=$a+$b; print_r($a);*/ ?>
二、数组
<html> <head> <meta http-equiv="content-type" content="text/html;charset=utf-8"> </head> <body> <h1 id="nbsp-同一个界面传输参数"> 同一个界面传输参数</h1> <?php /* 在 input中加 value="<?php echo $grades; ?>" 仿造百度搜索 */ error_reporting(E_ALL ^ E_NOTICE); $grades=$_REQUEST['grade']; $grade=explode(" ",$grades); $all=0; foreach($grade as $k=>$v) { $all+=$v; } ?> <form action="test.php" method="post"> <input type="text" name="grade" value="<?php echo $grades; ?>"/> <input type="submit" value="start"/> </form> <?php echo "总的:".$all; ?> </body> </html>
三、静态变量
<?php class Child { public static $num=0; public $name; function __construct($name) //只有new之后才能调用 { $this->name=$name; } //静态变量不能用this来访问 public function join() { self::$num+=1; //可以: Child::$num echo $this->name."you"; } } $child1=new Child("k"); $child1->join(); $child1=new Child("a"); $child1->join(); $child1=new Child("b"); $child1->join(); echo "<br/>".Child::$num; //类外只能是 类名::变量, //类内就能两种 ?>
四、继承/封装/多态/抽象
/*class Child { public static $num=0; public $name; //构造方法 function __construct($name) //只有new之后才能调用 { $this->name=$name; } //静态变量不能用this来访问 public function join($ifee) { self::ifee+=1; //可以: Child::$num echo $this->name."you"; } } $child1=new Child("k"); $child1->join(); $child1=new Child("a"); $child1->join(); $child1=new Child("b"); $child1->join(); echo "<br/>".Child::$num; //类外只能是 类名::变量, //类内就能两种*/ //静态方法不能采用非静态变量,只能使用非静态变量 // 成员函数之间相互调用,需要用 $this->text(); //继承 //1、子类只能继承一个父类 // 如果想多重继承可以考虑通过多次继承: /*class A{} class B extends A{} class C extends B{}*/ //2、父类中的构造方法,在创造一个子类的对象实例的时候不会默认自动调用 //3、 子类中调用父类的方法 //父类名::方法名(); / parent::方法名(); parent小写的 //覆盖: # 子类的方法和父类的方法名称和参数个数完全一样,但不要求参数名相同 # 但是修饰符可以不同,但是子的范围〉=父类范围 # 父类是private则不能覆盖 /*class A{ function F(){ echo " 父类在此!<br/>"; } } class B extends A{} class C extends B{ function F(){ echo "调用了父类了<br/>"; parent::F(); A::F(); } } $C1=new C(); $C1->F();*/ //抽象类:父类中不需要被实例化,只让子类继承,也可以被调用里面的;达到代码复用 #抽象类 abstract class name{} #抽象方法 abstract public cry(); #抽象类不一定也有抽象方法 #类包含抽象方法则必须为抽象类 #子类继承抽象父类,则必须为抽象类或者实现继承的所有,所有!方法 //接口:interfacde 接口{//属性 //方法} # 只能定义规范,让类去实现接口 ,不能自己实现, # class c implements 接口{} # 接口不能被实例化/接口能继承其他多个接口/不能不为public # 一个类实现了一个接口,必须把接口以及其继承的接口的方法全部实现 # (1 多个平级的类都要实现某个功能,只是实现方式不同,没有继承关系, #(2 项目经理定规范,让其他程序员实现 /*interface Stu { const A=90; public function add(); } interface Stu2{} class MyStu implements Stu,Stu2 { public function add() { echo "dddd".Stu::A."<br/>"; } } $mystu=new MyStu(); $mystu->add(); echo "OK".Stu::A; #获得接口中的常量*/ //final 使类中的方法不被覆盖 # final 不能修饰成员属性 /*class A { final public function get($salary) { return $salary*3; } } class B extends A { public function get($sal) { return $sal*2; } } $b=new B(); $b->get("21"); #Cannot override final method A::get() */ //const常量 # 要赋初始值;不能后面赋值;不能加$等修饰符 # self::A ; 类名::A ;接口名::A; 等方式获得常量A的值
五、文件操作以及错误处理
<?php // 文件操作 /*处理错的方式1 if(!file_exists("file1.txt")) { echo "not here"; exit(); } else { $fp=fopen("file1.txt","r"); echo "文件已打开"; fclose($fp); }*/ /* 处理错的方式2 if(!file_exists("a.txt")) { die("wenjianbucunzai"); } else {} echo "end";*/ /*处理错的方式1 file_exists("b.txt") or die("zhen de "); echo "end"; */ //定义错误函数 /*function my_error($error,$err_message) { echo "<font size='5' color='red'> $error </front><br/>";//2 //echo "错误信息是:".$err_message; exit(); } //改变系统默认的错误处理函数(“用户自己定义的错误输出函数”,“错误类型”) set_error_handler("my_error",E_WARNING); $fp=fopen("aa.txt",'r');*/ //错误触发器 function my_error3($error,$err_message) { echo "错误号:".$error; } function my_error4($error,$err_message) { echo "big big!"; } set_error_handler("my_error3",E_USER_WARNING);// set_error_handler("my_error4",E_USER_ERROR);//致命错误,不继续执行 $age=140; if($age>120) { //调用触发器的时候指定错误级别 trigger_error("输入的数字过大!",E_USER_ERROR); //trigger_error("输入的数字过大!",E_USER_WARNING); //exit(); } echo "ok"; ?>
六、错误日志
<?php //错误日志 php.ini 中的error_log的配置 function my_error5($error,$err_meaasge) { $err_info="错误信息:".$error."--".$err_meaasge; //echo time(); //输出 当前日期 // 调整时区:默认时期是UTC和中国差8小时 PRC 或者Asia/Chongqing date_default_timezone_set("PRC"); echo date("Y-m-d G-i-s"); echo "<br/>".$err_info; #将错误存入系统文件中 error_log("时间是:".date("Y-m-d G-i-s")."-".$err_info."\r\n",3,"myerror.txt");//3个参数 } set_error_handler("my_error5",E_USER_WARNING); $i=1; if($i<2) { trigger_error("输入的数字过小",E_USER_WARNING); } ?>
七、捕获异常
<?php //处理异常 #注意事项:异常抛出之后,得代码不会被继续执行 #抛出异常之后如果没用处理则会报错 try { addUser("1a"); } catch(Exception $e) { echo "失败信息:".$e->getMessage();//getLine() #可以继续抛出 throw $e; #也可以顶一个顶级异常处理 # $i=8/0 fopen("a.txt","r") 很难抛出异常 } function addUser($user) { if($user=="a") { echo "登陆成功!"; } else { throw new Exception("用户名错误!"); } } /*#顶级异常处理 function my_error() { echo "我是顶级异常处理!".e->getMeaasge(); } set_error_handler("my_error");*/ ?>
相关推荐:
Yii2中的场景(scenario)和验证规则(rule)的详解
MixPHP、Yii和CodeIgniter的并发压力测试的小结
위 내용은 PHP 기본 지식 코드 요약의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

TomakePhPapplicationSfaster, followthesesteps : 1) useopCodeCaching likeOpcachetOrpectipiledScriptBecode.2) MinimizedAtabaseQueriesByUsingQueryCachingandEfficientIndexing.3) leveragephp7 assistorBetterCodeeficiession.4) 구현 전략적 지시

toImprovePhPapplicationSpeed, followthesesteps : 1) enableOpCodeCachingWithApcuTeCeScripteXecutionTime.2) 구현 구현

의존성 주입 (DI)은 명시 적으로 전이적 종속성에 의해 PHP 코드의 테스트 가능성을 크게 향상시킵니다. 1) DI 디퍼 커플 링 클래스 및 특정 구현은 테스트 및 유지 보수를보다 유연하게 만듭니다. 2) 세 가지 유형 중에서, 생성자는 상태를 일관성있게 유지하기 위해 명시 적 표현 의존성을 주입합니다. 3) DI 컨테이너를 사용하여 복잡한 종속성을 관리하여 코드 품질 및 개발 효율성을 향상시킵니다.

DatabaseQuesyOptimizationInphPinVolvesVesstoigiestoInsperferferferferformance.1) SelectOnlyNecessaryColumnstoredAtatatransfer.2) useinDexingTeSpeedUpdatarretieval.3) ubstractOrerEresultSoffRequeries.4) UtilizePreDstatements Offeffi

phpisusedforendingemailsduetoitsbuitsbuitsbuit-inmail () functionandsupportivelibraries lifephpmailerandswiftmailer.1) usethemail () functionforbasicemails, butithaslimitations.2) EmployPhpmailerforAdvancedFeatirehtMailsAndAtachments.3))

의존성 (di) inphpenhancescodeflexibility 및 testability는 theiredections 의존성에 대한 classessecouplassessecouplesseviaconstructors, useconstructorinjectionsforpostforpost-creationdencecanchanges, t

간단한 프로젝트에는 Pimple이 권장되며 Symfony의 종속성은 복잡한 프로젝트에 권장됩니다. 1) Pimple은 단순성과 유연성으로 인해 소규모 프로젝트에 적합합니다. 2) Symfony의 종속성 주입은 강력한 기능으로 인해 대규모 프로젝트에 적합합니다. 선택할 때 프로젝트 규모, 성능 요구 사항 및 학습 곡선을 고려해야합니다.

의존성 (di) inphpisadesignpatternwhereclassdectionsearepassedtoittratherthathertancreatedincreatedincreatedincreatedincreatedincreatedincreatedincecreatedincecreatedince.itimprovessoftwarequalityby : 1) 향상된 testability througheasydectionmocking, 2) lextibility oca


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

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

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경