PHP--面试题

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的是主键时有效
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值