首页 > 编程知识 正文

php最好的语言 梗,php程序开发知识点

时间:2023-05-06 04:40:16 阅读:17449 作者:3332

百度面试,特别是初次见面,整体面试并不困难。 前两次技术面试需要手写编码,主要涉及的类别有语言基础、设计模式、算法基础、数据库。 最重要的是基础,基础,还是基础。 虽然涉及面比较广,但也是程序员应该知道的东东。 答案请作为参考。 (摘自文章网络)现整理10个问题如下:

1、PHP整容溢出问题是什么样的

2、如何理解OOP

3、你对设计模式和MVC的理解

4、HTTP协议1.0与1.1的区别,简要说明HTTP协议

5、简述Apache的rewrite机制和PHP框架的URI路由机制

6、MySQL的索引机制,复合索引的使用原则

7、MySQL的表类型与MyISAM和InnoDB的区别

8、快速排序算法简述

9、awk、sed、sort的基本使用(通过实例考察) )

10、Memcached、redis的使用与理解

=====================================

【1】PHP的整型溢出问题是怎样的

PHP整数类型数的字长与平台有关,在32位操作系统中,最大整数类型为20亿以上,实际为2的31次方,最小为-2的31次方,PHP不支持无符号整数。 如果一个数超出了整数的范围,则自动解释为浮点。 如果执行的运算结果超出了integer的范围,也会返回浮动。 java、c的整数型溢出会怎么样)

【2】如何理解OOP

OOP、面向对象编程包括继承性、封装性、多态性三个方面,其中最根本的是抽象。

继承性(可扩展性)在子类中扩展已存在的父类。

封装属性要求外部不能随意访问对象的内部数据,即封装该类中的具体实现。 用户不需要知道内部的具体实现,只要知道它在做什么,如何使用就可以了。

多态性是类的抽象和接口,它是同一类处理多种类型对象的能力。

我们现实中,看到的东方都可以看作一个对象,然后再抽象为类,类又可以发展成很多类似的对象。 举个简单的例子,把我们看到的房子抽象成ROOM类。 包括基本的门、窗、桌子等对象、人可以出入等功能。 现在我们将ROOM类继承为Classroom。 有门、大窗户、桌椅,还只包括黑白和一个讲台,老师和同学可以上课。 目前,这个Classroom类是Classroom_621对象,包括两扇门、四个大窗户、30套桌椅,供学生上毛概课。

【3】你对于设计模式和MVC的理解

一想到Model-View-Controller、模型、视图、控制器和MVC,就会想到JAVA。 由于JAVA是一种完整的面向对象的语言,因此MVC最先出现在smalltalk中。 其核心是试图与数据模型分离,可以表明不同的程序是不同的。

模型是程序员编写的功能、算法、数据模型,是系统业务的逻辑层。

视图,也就是前端,图形界面。 给用户看了。

控制器。 主要负责请求的处理、传输和视图的加载。

设计模式,简言之,就是代码设计经验的总结和分类。 设计模式最先应用于建筑行业,编程设计模式如第一个GoF所述,包含23种设计模式,主要用于面向对象编程。 遵循一些设计原则:开关原则、单一职责原则、xydjqm置换原则、依赖注入、接口隔离、大气甜瓜原则、优先使用组合而非继承等。 有作成型模式、结构型模式、行动模式三种。

【4】HTTP协议1.0及1.1的区别,并简单说下HTTP协议

HTTP,超文本传输协议。 定义浏览器和服务器的通信规则。 HTTP协议是基于TCP/IP的TCP协议,当前www使用的是HTTP版本1.1。 其特点是C/S模式、请求简单性(GET/POST/HEAD )、灵活性(可传输任何类型数据的HTML、XML、JSON、自定义等)、无连接) )每个连接

对HTTP协议的考察主要包括响应消息格式、请求消息格式、状态代码等知识点。

典型的HTTP协议包括三个部分:起跑线、页眉和主体。

[响应消息格式]

HTTP/1.1 200 0K

连接lon :关闭

Date: Thu,13 Oct 2005 03:17:33 GMT

服务器: Apache/2.0.54 (UNIX )。

Last—Nodified:Mon,22 Jun 1998 09; 23; 24 GMT

内容—length :682 l

内容—type : text/html

该响应消息分为三个部分,一个开头的状态行status line、开头和一个包含所请求的对象

本身的附属体。状态行有3个字段:协议版本字段、状态码字段、原因短语字段。

[请求消息格式]

GET /somedir/page.html HTTP/1.1

Host:www.chinaitlab.com

Connection:close

User-agent:Mozilla/4.0

Accept-language:zh-cn

(额外的回车符和换行符)

该请求消息的第一行称为请求行 (request line),后续各行都称为头部行(header)。请求行有3个字段:方法字段、URL字段、HTTP版本字段。

[状态码]参见http://www.cnblogs.com/TankXiao/archive/2013/01/08/2818542.html

1xx 消息

2xx 成功

3xx 重定向

4xx 请求错误

5xx 服务器错误

[常见状态码]

200 OK。请求已成功,请求所希望的响应头或数据体将随此响应返回。

300 Multiple Choices。请求资源有多个选择,如请求文本有法语版、英语版等等。

301 Moved Permanently。表示请求的网页已永久转移到新位置

302 Found。表示页面在做临时跳转时返回的状态。

304 Not Modified。客户的缓存资源是最新的, 要客户端使用缓存。

400 Bad Request。错误的请求。

403 Forbidden。请求被服务器拒绝了。

404 Not Found。表示服务器找不到请求的网页,服务器上不存在的网页经常会返回的HTTP状态码。

500 Internal Server Error。

503 Service Unavailable。服务器目前无法为请求提供服务,但过一段时间就可以恢复服务。

504 Gateway Timeout。与状态吗408类似, 但是响应来自网关或代理,此网关或代理在等待另一台服务器的响应时出现了超时。

505 HTTP Version not supported。 HTTP协议版本不支持。

【5】简单说下Apache中rewrite机制和PHP框架中URI路由机制

1)URL重写,其实就是把用户通过浏览器请求的URL,到了后台,apache根据预先配置的重写规则将该请求指向真正的资源路径,说白了就是打马虎眼,把真正的路径改头换面后给用户访问,可问题是这样做有啥用处呢。

1、SEO方面。将动态的URL静态化,以满足搜索引擎的胃口。

2、访问控制。比如,通过重写规则后,客户端不易判断后台程序类型等。

3、URL重定向。当网站更改域名或增加别名URL后,可以通过规则轻松的指向要访问的URL。

mod_rewrite 使用基于正则表达式动态的修改传入请求的URL。它可以将URL映射到文件系统路径,也可以将一个URL映射到另一个URL。它使用了没有限制数量的规则来操纵URL,每条规则可以包括没有限制数量的附加条件。你可以通过多种方式来检测,如,服务器变量、环境变量、HTTP头、时间戳等。

mod_rewrite 操作整个URL路径,包括path-info的部分。一个重写规则可以被设置在http.conf或者.htaccess中。一个重写规则生成的路径可以包括一个请求字符串,或者内部的子程序处理,外部请求的重定向,或者穿透内部代理等。

2)PHP框架中的URI路由机制,与apache重写类似,一般包括通配符和正则两种规则。让用户可以重新定向(remap)URI处理程序. 设定你自己的路由规则。

【6】MySQL的索引机制,复合索引的使用原则

(深入浅出MySQL一书中对索引的使用讲的比较细致)

一般都会用书本中的目录来介绍索引机制,包括有些书本会有专门的快速检索附录,就很类似于数据库的索引。

MySQL的索引包括4类:主键索引(primary key)、唯一索引(unique)、常规索引(index)、全文索引(fullindex)。

Show index from table_name; –查看表中的索引

Show status like ‘Handler_read%’ –查看索引的使用情况

复合索引,一般遵循最左前缀原则,如table_a 的 a b c 三列建复合索引

create index ind_table_a on table_a(a,b,c);

那么,只有在条件中用到a,或者a、b,或者a、b、c这样的情况下,才会用到刚建的复合索引。

【7】MySQL的表类型及MyISAM与InnoDB的区别

MySQL常见的表类型(即存储引擎)

show engines查看支持表类型配置。常见包括:MyISAM/Innodb/Memory/Merge/NDB

其中,MyISAM和Innodb是最常用的两个表类型,各有优势,我们可以根据需求情况选择适合自己的表类型。

[MyISAM]

1)每个数据库存储包括3个文件:.frm(表定义)、MYD(数据文件)、MYI(索引文件)

2)数据文件或索引文件可以指向多个磁盘

3)Linux的默认引擎,win默认InnoDB

4)面向非事务类型,避免事务型额外的开销

5)适用于select、insert密集的表

6)MyISAM默认锁的调度机制是写优先,可以通过LOW_PRIORITY_UPDATES设置

7)MyISAM类型的数据文件可以在不同操作系统中COPY,这点很重要,布署的时候方便点。

[Innodb]

1)用于事务应用程序

2)适用于update、delete密集的操作。执行select count() from table时,InnoDB要扫描一遍整个表来计算有多少行,但是MyISAM只要简单的读出保存好的行数即可。注意的是,当count()语句包含 where条件时,两种表的操作是一样的。DELETE FROM table时,InnoDB不会重新建立表,而是一行一行的删除。

3)引入行级锁和外键的约束

4)InnoDB不支持FULLTEXT类型的索引

【8】简单说下快速排序算法

基本思想:通过一趟排序将待排序列分割成两部分,其中一部分比另一部分记录小,再分别对这两部分继续快速排序,以达到有序。

算法实现:设有两个指针low和high,初值为low=1,high=n,设基准值为key(通常选第一个),则首先从high位置开始向前搜索,找到第一个比key小的记录与key交换,然后从low位置向后搜索,找到第一个比key大的记录与基准值交换,重复直至low=high为止。

第一趟排序结果,key之前的记录值比key之后的记录值小。

11 25 9 3 16 2 //选择11为key

2 25 9 3 16 11

2 11 9 3 16 25

2 3 9 11 16 25

【9】awk、sed、sort的基本使用(用实例考察的)

[例]:有如下文件test,请统计每个网址出现次数,用一句shell实现。

a www.baidu.com 20:00

b www.qq.com 19:30

c www.baidu.com 14:00

d www.baidu.com 23:00

e www.qq.com 20:30

f www.360.com 20:30

cat test| awk -F’ ‘ ‘{print $2}’ |sort | uniq -c | sort -rn

【10】Memcached、redis的使用和理解

Memcached和redis 都是一个key-value的内存式存储系统,通过hash表来存储检索结果,做到强大的缓存机制。像新浪的微博、淘宝等大流量站点都必须的使用了这些东东。

下面是从百科中摘录的介绍。具体实践和使用后续再详细介绍。

Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。简单的说就是将数据调用到内存中,然后从内存中读取,从而大大提高读取速度。

redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)和zset(有序集合)。

题外话:

整个面试流程感觉非常nice,觉得面试官都比较随意的。没有像别人说的那样高傲的。百度的面试是开放式的,整个面试过程中附近都有人在讨论问题和方案。

本文参考地址为:https://www.php.cn/toutiao-351845.html

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。