1. static 关键字
class A{
public static $num=0;
public function __construct(){
self::$num++; }
}
new A();
new A();
new A();
echo A::$num;
结果为 3,因为static属性常驻内存,不会立即回收。且静态属性不能通过一个类已实例化的对象来访问。在类的内部使用 self:: num 来访问。而不是A->$num
2. 继承类
<?php
class A{
public function __construct(){
echo "Class A...<br/>";
}
}
class B extends A{
public function __construct(){
echo "Class B...<br/>";
}
}
new B();
?>
输出结果为:Class B…
A 子类继承父类,子类的构造函数会覆盖父类的构造函数,子类 没有定义 构造 函数时,默认继承父类的构造方法
- 对象变量赋值
<?php
class A{
public $num=100;
}
$a = new A();
$b = $a;
$a->num=200;
echo $b->num;
?>
输出结果为:200
在php5,一个对象变量已经不再保存整个对象的值。只是保存一个标识符来访问真正的对象内容。 当对象作为参数传递,作为结果返回,或者赋值给另外一个变量,另外一个变量跟原来的不是引用的关系,只是他们都保存着同一个标识符的拷贝,这个标识符指向同一个对象的真正内容。
对象的复制是通过引用来实现的,
$a=new A();$b=$a;
//相当于
$a=new A();$b=&$a;
-
date()函数支持
1.Y 4位数字完整表示年份,y两位数字表示年份
2.a/A:表示上午或者下午,以am或者AM表示 -
以读写模式打开文件 "FILE.txt"的正确方法是
fopen(“FILE.txt”,“r+”); ,该函数没有rw参数,用r+表示读写
'r' 只读方式打开,将文件指针指向文件头。
'r+' 读写方式打开,将文件指针指向文件头。
'w' 写入方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建之。
'w+' 读写方式打开,将文件指针指向文件头并将文件大小截为零。如果文件不存在则尝试创建之。
'a' 写入方式打开,将文件指针指向文件末尾。如果文件不存在则尝试创建之。
'a+' 读写方式打开,将文件指针指向文件末尾。如果文件不存在则尝试创建之。
'x' 创建并以写入方式打开,将文件指针指向文件头。如果文件已存在,则 fopen() 调用失败并返回 FALSE,并生成一条 E_WARNING 级别的错误信息。如果文件不存在则尝试创建之。这和给 底层的 open(2) 系统调用指定 O_EXCL|O_CREAT 标记是等价的。
'x+' 创建并以读写方式打开,其他的行为和 'x' 一样。
- 以下代码执行结果
$a = 12;
$b = 012
$c = 0x12;
echo $a,"\n",$b,"\n",$c;
结果:12 10 18
0 开头代表8进制
0x 开头代表16进制
- 字符串转整型
echo 1+2+"3+4+5";
结果:6;
解析:一旦遇到 + 相当于将后面的字符串强转整型。
- unset 删除概念
$a =6;
$b = &$a;
unset($a);
echo $b
结果:6
解析:unset 只是删除值的引用,不删除内存空间本身的值。
- PHP字符串定义方式及各自区别
单引号:
1.单引号不能解析变量
2.单引号不能解析转义字符,只能解析单引号和反斜线本身
3.变量和变量、变量和字符串、字符串和字符串之间可以用 . 连接
双引号:
双引号可以解析变量,变量可以使用特殊字符和{}包含
双引号可以解析所有转义字符
变量和变量、变量和字符串、字符串和字符串之间可以用 . 连接
区别:
单引号效率高于双引号
heredoc的功能类似于双引号 nowdoc 功能类似与单引号
10.浮点类型不能用于精确的计算判断
浮点类型,在计算机进行计算交给cup进行计算,转成2进制,会有一定损耗。
- $_SERVER 详解
$_SERVER['SERVE_ADDR'] //服务端 IP 。
$_SERVER['REMOTE_ADDR'] //客户端 IP 。
$_SERVER['REMOTE_HOST'] //当前用户主机名
$_SERVER['REQUEST_URI'] //URL
$_SERVER['HTTP_REFERER'] //链接到当前页面的前一页面的 URL 地址
$_SERVER['HTTP_USER_AGENT'] //当前请求的 User_Agent: 头部的内容。
- foo()和@foo()函数的区别
结果:@foo()控制错误输出,foo()正常表达
解析:@ 符号在 PHP 中可以忽略错误报告,对于表达式有提示类错误的,又不影响语句的执行的,可以在表达式前面加 @
- 运算符优先级,逻辑短路,
解析:先执行3>0 为true 执行 || 为true,后面不执行。
注意:
$a = true,$a++; 此时var_dump($a),$a为bool类型,echo $a ,$a = 1;
$a = true,$a=$a+1; 此时var_dump($a),$a为int类型,echo $a ,$a = 2;
- 变量作用域
$outer ='outer'; //全局变量
function fun(){
// global $outer;
// $outer = $GLOBALS['outer'];
return $outer; //局部变量
}
echo fun();
解析:外部定义的全局变量要在内部使用,需要使用global关键字,或者$GLOBALS数组使用。否则取不到值。
- static 静态关键字
$count =5;
function get_count(){
static $count; //null
return $count++; //1 - 2
}
echo $count; //5
++$count; //6
echo get_count(); //null
echo get_count(); //1
结果:51
解析:
static关键字
1.仅初始化一次,初始化需赋值(不赋值则为null)。
2.每次执行函数后,该值都会保留。
3.static 修饰的变量是局部的,只在函数内部能够使用。
4.可以记录函数调用次数,从而可以在某些条件下终止递归。
- include 和 require
相同:
1.include/require 语句包含并运行指定文件。
2.如果给出路径名按照路径来找,否则从include_path中查找
3.如果include_path中也没有,则从调用脚本文件所在目录和当前工作目录下查找。
不同:
1.require一个文件存在错误的话,那么程序就会中断执行了,并显示致命错误。
include一个文件存在错误的话,那么程序不会中端,而是继续执行,并显示一个警告错误。
include_once(require_once)和 include/require差别
include_once(require_once)需要查询一遍已加载的文件列表, 确认是否存在, 然后再加载。
- 抽象类,接口
接口:
interface 接口名称{
//使用interface关键字声明接口
常量成员 //接口中的成员属性只能是常量,不能是变量
抽象方法 //接口中的所有方法必须是抽象方法,不能有非抽象的方法存在
}
//eg:
interface IAction {
public function eat($food);
public function swim();
}
//子类实现一个接口,用关键字 implements
//子类可以实现多个接口,用逗号来分隔多个接口的名称
//子类中必须实现接口中定义的所有方法,否则会报一个致命错误
class Whale implements IAction{
public function eat($food){
return $food;
}
public function swim(){
return 1;
}
}
注意!!
抽象方法没有方法体,而且方法结束使用 ; 号,非抽象方法必须有方法体即{},可以不写具体内容)
函数体内不能写任何东西,连两个大括号都不能写!!!
抽象类:
abstract class AbstractClass
{
// 强制要求子类定义这些方法
abstract protected function getValue();
abstract protected function prefixValue($prefix);
// 普通方法(非抽象方法)
public function printOut() {
print $this->getValue() . "\n";
}
}
//子类用 extends 继承父类
class ConcreteClass1 extends AbstractClass
{
protected function getValue() {
return "ConcreteClass1";
}
public function prefixValue($prefix) {
return "{$prefix}ConcreteClass1";
}
}
继承一个抽象类的时候,子类必须定义父类中的所有抽象方法;
另外,这些方法的访问控制必须和父类中一样(或者更为宽松)
抽象类和接口的区别:
1.接口没有数据成员,但是抽象类有数据成员,抽象类可以实现数据的封装。
2.接口没有构造函数,抽象类可以有构造函数。
3.接口中的方法都是public类型,而抽象类中的方法可以使用private、protected或public来修饰。
4.一个类可以同时实现多个接口,但是只能实现一个抽象类。
18.http协议和https区别
https 是基于SSL/TLS的HTTP协议,所有的http数据都是在SSL/TLS协议封装之上传输的。
https协议在http协议基础上,添加了SSL/TLS握手,以及数据加密传输,也属于应用层协议。
- MYSQL 数据类型表达的意义
整型:
TINYINT 带符号最大值127 最小值 -128
INT
BIGINT
整型格式:
unsigned:无符号的,表示只允许正数,所以取值范围取绝对值且最大值*2
zerofill: 填充0(如果声明了zerofill,该列会自动设为unsigned)
每个整型类型可以指定一个最小显示宽度
栗子:
int(3) 此时存入12333,是可以存入,但是显示宽度只会为123,这个宽度并不表示存储的值有多大
设置了 zerofill int(3) 此时存入12 会在前面自动补0,存储为012
定点小数 decimal:
DECIMAL数据类型用于在数据库中存储精确的数值。我们经常将DECIMAL数据类型用于保留准确精确度的列,例如会计系统中的货币数据
字符串:
char(n):固定长度,最多255个字符
varchar(n):可变长度,最多65535个字符
char是固定长度字符串,其长度范围为0~255且与编码方式无关,无论字符实际长度是多少,都会按照指定长度存储,不够的用空格补足
char 一般用于存储密码之类长度固定的字符串,char的字符串检索速度要比varchar类型的快
- 魔术方法,魔术常量
1。__construct()
实例化对象时被调用,当__construct和以类名为函数名的函数同时存在时,__construct将被调用,另一个不被调用。
2。__destruct()
当删除一个对象或对象操作终止时被调用。
3。__call()
对象调用某个方法,若方法存在,则直接调用;若不存在,则会去调用__call函数。
4。__get()
读取一个对象的属性时,若属性存在,则直接返回属性值;若不存在,则会调用__get函数。
5。__set()
设置一个对象的属性时,若属性存在,则直接赋值;若不存在,则会调用__set函数。
6。__toString()
打印一个对象的时被调用。如echo $obj;或print $obj;
7。__clone()
克隆对象时被调用。如:$t=new Test();$t1=clone $t;
8。__sleep()
serialize之前被调用。若对象比较大,想删减一点东东再序列化,可考虑一下此函数。
9。__wakeup()
unserialize时被调用,做些对象的初始化工作。
10。__isset()
检测一个对象的属性是否存在时被调用。如:isset($c->name)。
11。__unset()
unset一个对象的属性时被调用。如:unset($c->name)。
12。__set_state()
调用var_export时,被调用。用__set_state的返回值做为var_export的返回值。
13。__autoload()
实例化一个对象时,如果对应的类不存在,则该方法被调用。