美文网首页
PHP面试题

PHP面试题

作者: 煜明will | 来源:发表于2017-04-21 17:54 被阅读0次

    1、双引号和单引号区别

    • 双引号解释变量,单引号不解释变量。
    • 双引号里插入单引号,其中单引号里如果有变量的话,变量解释
    • 双引号的变量名后面必须要有一个非数字、字母、下划线的特殊字符,或者用{}讲变量括起来,否则会将变量名后面的部分当做一个整体,引起语法错误
    • 双引号解释转义字符,单引号不解释转义字符,但是解释'\和\
    • 能使单引号字符尽量使用单引号,单引号的效率比双引号要高(因为双引号要先遍历一遍,判断里面有没有变量,然后再进行操作,而单引号则不需要判断)

    2、常用的超全局变量

    $_GET,$POST,$REQUEST,$GLOBALS,$FILE,$SERVER,$SESSION,$COOKIE

    3、HTTP中POST、GET、PUT、DELETE区别

    4、echo、print_r、print、var_dump区别

    • echo、print是PHP语句,var_dump是函数
    • echo输出一个或多个字符串,中间以逗号隔开,没有返回值是语言结构而不是真正的函数,因此不能作为表达式的一部分使用。
    • print只能打印简单的变量(int,string),有返回值,显示成功则返回true
    • print_r可以打印复杂类型变量的值以列表形式显示,但输出布尔值和null结果没有意义,都是打印“\n”
    • var_dump 判断一个变量的类型和长度,并输出变量的数值

    5、HTTP状态码

    状态码分类:

    • 1** 信息,服务器收到的请求,需要请求者继续执行操作
    • 2** 成功,操作被成功接收并处理
    • 3** 重定向,需要进一步的操作以完成请求
    • 4** 客户端错误,请求包含语法错误或者无法完成请求
    • 5** 服务器错误,服务器在处理请求的过程中发生了错误
      常见状态码:
    • 200 请求成功
    • 301 资源(网页等)被永久转义到其他URL
    • 404 请求的资源不存在
    • 505 内部服务器错误

    6、include和require区别

    • require是无条件包含,也就是如果一个流程里加入require,无论条件成立与否都会先执行require,当文件不存在或者无法打开时,会提示错误,并且终止程序
    • include有返回值,如果被包含的文件不存在,那么会提示一个错误,但是程序会继续执行下去

    7、如何获取客户端IP

    客户端IP:$_SERVER["REMOTE_ADDR"];getenv('REMOTE_ADDR')
    ip2long进行转换
    服务端ip:gethostbyname('www.baidu.com')

    8、isset、empty、is_null的区别

    • isset判断变量是否定义或者是否为空(不存在,不赋值,赋值为null)

    变量存在返回true,否则返回false
    变量定义不赋值返回FALSE
    unset一个变量,返回FALSE
    变量赋值为null,返回FALSE

    • empty判断变量是否为空能转换为false的否为空,为空返回true,反之返回false

    "",0,"0",null,false都认为为空,返回true

    没有任何属性的对象都认为是空

    • is_null 检测传入的值是否为null(不存在(true并且警告),没赋值,赋值null)

    定义了,但是赋值为null或者没有赋值
    unset一个变量

    9、简述MySQL数据库中MySIAM和InnoDB的区别

    • 存储结构

    MyISAM:每个MyISAM在磁盘上存储成单个文件,.frm文件存储表定义, .MYD文件存储表数据, .MYI文件存储索引文件
    InnoDB:所有的表都存在同一个数据文件中,InnoDB表大小受限于操作系统文件的大小,一般为2GB。

    • 存储空间

    MyISAM:可被压缩,存储空间较小。支持三种不同的存储格式:静态表、动态表、压缩表。
    InnoDB:需要更多地内存和存储,他会在内存中建立起专用的缓冲池用于高速缓冲数据和索引

    • 可移植性、备份及恢复

    MyISAM:数据是以文件的形式存储,所以在跨平台的数据转移中会很方便。在备份和恢复时可单独针对某个表进行操作。
    InnoDB:拷贝数据文件、备份binlog、MySQLdump

    • 事务支持

    MyISAM:不支持

    InnoDB:支持

    • 全文索引

    MyISAM:支持
    InnoDB:不支持

    • 外键:

    MyISAM:不支持
    InnoDB:支持

    • 表行数

    MyISAM:保存表的总行数,如果select count() from table;会直接取出该值。
    InnoDB:没有保存表的总行数,如果select count(
    ) from table;会遍历整个表,消耗大。如果添加where条件,myisam和innodb处理的方式都一样。

    • AUTO_INCREMENT

    MyISAM:可以和其他字段一起建立联合索引。
    InnoDB:必须包含只有该字段的索引。

    • 表锁差异

    MyISAM:支持表级锁
    InnoDB:支持行锁,但是只在where的是主键时有效

    相关文章

      网友评论

          本文标题:PHP面试题

          本文链接:https://www.haomeiwen.com/subject/jacdzttx.html