面试不要怂,咱们是去找工作的,等价互换而已,你只需要对知识谦卑而已,手里活好就行。
一:引用
定义:引用即别名,PHP 的引用允许你用两个变量来指向同一个内容
使用方法:
1.$a = range(0,100); //声明一个0-100个范围数字的数组 在内存里面开辟一块内存空间 $a执向$a
$b = $a; //通过赋值可以达到使$a与$b都执向$a的空间(cow机制:写时复制,可以使用memory_get_usage()查看内存)
$c = &$a; //通过引用可以使$c与$a都指向一块空间(cow失效),两个变量都会改变内存内容
2.可以使用 xdebug_debug_zval('a') 查看变量内存占用(几个指向,是否为引用,数值);
3.对象复制即为引用复制,
二:php基础数据类型(8种)
1.基础数据类型:
boolean(布尔类型)
integer(整形)
float/double(浮点型)
string(字符串)
2.复合类型
array():数组类型
object():对象
4.特殊类型
resource
null
注:浮点型不可以用来进行==判断(if(a(f)+b(f) == c(f)))因为浮点类型转化二进制的时候会有损耗导致不准确
false7种情况:NULL,' ',0,“0”,0.0,false,array(),
三:超全局变量
$GLOBALS,$_SERVER,$_GET,$_POST,$_COOKIE,$_FILES,$_SESSION,$_REQUEST,$_ENV
$GLOBALS:
一个包含了全部变量的全局组合数组。变量的名字就是数组的键。
$_SERVER
'PHP_SELF'
当前执行脚本的文件名,与 document root 有关。例如,在地址为 http://example.com/foo/bar.php 的脚本中使用 $_SERVER['PHP_SELF'] 将得到 /foo/bar.php。__FILE__ 常量包含当前(例如包含)文件的完整路径和文件名。 从 PHP 4.3.0 版本开始,如果 PHP 以命令行模式运行,这个变量将包含脚本名。之前的版本该变量不可用。
'argv'
传递给该脚本的参数的数组。当脚本以命令行方式运行时,argv 变量传递给程序 C 语言样式的命令行参数。当通过 GET 方式调用时,该变量包含query string。
'SERVER_ADDR'
当前运行脚本所在的服务器的 IP 地址。
'SERVER_NAME'
当前运行脚本所在的服务器的主机名。如果脚本运行于虚拟主机中,该名称是由那个虚拟主机所设置的值决定。
'SERVER_SOFTWARE'
服务器标识字符串,在响应请求时的头信息中给出。
'REQUEST_METHOD'
访问页面使用的请求方法;例如,“GET”, “HEAD”,“POST”,“PUT”。
'REQUEST_TIME'
请求开始时的时间戳。从 PHP 5.1.0 起可用。
'REQUEST_TIME_FLOAT'
请求开始时的时间戳,微秒级别的精准度。 自 PHP 5.4.0 开始生效。
'QUERY_STRING'
query string(查询字符串),如果有的话,通过它进行页面访问。
'DOCUMENT_ROOT'
当前运行脚本所在的文档根目录。在服务器配置文件中定义。
'HTTP_HOST'
当前请求头中 Host: 项的内容,如果存在的话。
'REMOTE_ADDR'
浏览当前页面的用户的 IP 地址。
'REMOTE_HOST'
浏览当前页面的用户的主机名。DNS 反向解析不依赖于用户的 REMOTE_ADDR。
'REMOTE_PORT'
用户机器上连接到 Web 服务器所使用的端口号。
'REMOTE_USER'
经验证的用户
'SCRIPT_FILENAME'
当前执行脚本的绝对路径。
'SERVER_ADMIN'
该值指明了 Apache 服务器配置文件中的 SERVER_ADMIN 参数。如果脚本运行在一个虚拟主机上,则该值是那个虚拟主机的值。
'SERVER_PORT'
Web 服务器使用的端口。默认值为 “80”。如果使用 SSL 安全连接,则这个值为用户设置的 HTTP 端口。
'SERVER_SIGNATURE'
包含了服务器版本和虚拟主机名的字符串。
'PATH_TRANSLATED'
当前脚本所在文件系统(非文档根目录)的基本路径。这是在服务器进行虚拟到真实路径的映像后的结果。
'SCRIPT_NAME'
包含当前脚本的路径。这在页面需要指向自己时非常有用。__FILE__ 常量包含当前脚本(例如包含文件)的完整路径和文件名。
'REQUEST_URI'
URI 用来指定要访问的页面。例如 “/index.html”。
'PHP_AUTH_DIGEST'
当作为 Apache 模块运行时,进行 HTTP Digest 认证的过程中,此变量被设置成客户端发送的“Authorization” HTTP 头内容(以便作进一步的认证操作)。
'PHP_AUTH_USER'
当 PHP 运行在 Apache 或 IIS(PHP 5 是 ISAPI)模块方式下,并且正在使用 HTTP 认证功能,这个变量便是用户输入的用户名。
'PHP_AUTH_PW'
当 PHP 运行在 Apache 或 IIS(PHP 5 是 ISAPI)模块方式下,并且正在使用 HTTP 认证功能,这个变量便是用户输入的密码。
$_REQUEST
此超全局变量包含$_POST,$_GET,$_SESSION,不推荐使用。因为等于万能钥匙,能用$_POST 与 $_GET取的数据就用它取就行。
@
作用:该表达式可能产生的任何错误信息都被忽略掉。
对象:@ 运算符只对表达式有效。
<?PHP
(@include("file.php"))
OR die("Could not find file.php!");
原理:如果触发错误,错误处理程序仍被调用,只是暂时将该行的错误报告级别设置为0
注意:影响性能,避免使用