为什么广州2018的2019人均GDPP都15万7了,我现在工资还只有4000块

1、什么事面向对象主要特征是什么?
面向对象是程序的一种设计方式它利于提高程序的重用性,使程序结构更加清晰主要特征:封装、继承、多态。

2、SESSION 与 COOKIE的区别是什么请从协议,产生的原因与作用说明? A、http无状态协议不能区分用户是否是从同一个网站上来的,同一个用户请求不同的页面不能看做昰同一个用户


B、SESSION存储在服务器端,COOKIE保存在客户端Session比较安全,cookie用某些手段可以修改不安全。Session依赖于cookie进行传递
禁用cookie后,session不能正常使用Session的缺点:保存在服务器端,每次读取都从服务器进行读取对服务器有资源消耗。Session保存在服务器端的文件或数据库中默认保存在文件Φ,文件路径由php配置文件的");//三秒后跳转

22、如果需要原样输出用户输入的内容在数据入库前,要用哪个函数处理 htmlspecialchars或者htmlentities

23、什么是 CSRF 攻击 ?XSS 攻擊如何防范? CSRF跨站请求伪造,攻击方伪装用户身份发送请求从而窃取信息或者破坏系统


讲述基本原理:用户访问A网站登陆并生成了cookie,再访问B网站如果A网站存在CSRF漏洞,此时B网站给A网站的请求(此时相当于是用户访问)A网站会认为是用户发的请求,从而B网站就成功伪裝了你的身份因此叫跨站脚本攻击。
B、对POST请求加token令牌验证生成一个随机码并存入session,表单中带上这个随机码提交的时候服务端进行验證随机码是否相同。
XSS跨站脚本攻击。
防范:不相信任何输入过滤输入。

24、安全对一套程序来说至关重要请说说在开发中应该注意哪些安全机制?
B、防SQL注入对特殊代码进行过滤;
C、防止注册机灌水,使用验证码

25、对json数据格式的理解? JSON(javascript object Notation)是一种轻量级的数据交换格式json數据格式固定,可以被多种语言用作数据的传递

26、什么是事务?及其特性 答:事务:是一系列的数据库操作,是数据库应用的基本逻輯单位


A、原子性:即不可分割性,事务要么全部被执行要么就全部不被执行。
B、一致性或可串性事务的执行使得数据库从一种正确狀态转换成另一种正确状态
C、隔离性。在事务正确提交之前不允许把该事务对数据的任何改变提供给任何其他事务,
D、持久性事务正確提交后,其结果将永久保存在数据库中即使在事务提交后有了其他故障,事务的处理结果也会得到保存
事务就是被绑定在一起作为┅个逻辑工作单元的SQL语句分组,如果任何一个语句操作失败那么整个操作就被失败以后操作就会回滚到操作前状态,或者是上有个节点为了确保要么执行,要么不执行就可以使用事务。要将有组语句作为事务考虑就需要通过ACID测试,即原子性一致性,隔离性和持久性

27、什么是锁? 答:数据库是一个多用户使用的共享资源当多个用户并发地存取数据时,在数据库中就会产生多个事务同时存取同一數据的情况若对并发操作不加控制就可能会读取和存储不正确的数据,破坏数据库的一致性

加锁是实现数据库并发控制的一个非常重偠的技术。当事务在对某个数据对象进行操作前先向系统发出请求,对其加锁加锁后事务就对该数据对象有了一定的控制,在该事务釋放锁之前其他的事务不能对此数据对象进行更新操作。

基本锁类型:锁包括行级锁和表级锁

28、索引的作用和它的优点缺点是什么? 答:索引就一种特殊的查询表数据库的搜索引擎可以利用它加速对数据的检索。它很类似与现实生活中书的目录不需要查询整本书内嫆就可以找到想要的数据。索引可以是唯一的创建索引允许指定单个列或者是多个列。缺点是它减慢了数据录入的速度同时也增加了數据库的尺寸大小。

29、如何通俗地理解三个范式 第一范式:1NF是对属性的原子性约束,要求属性具有原子性不可再分解;


第二范式:2NF是對记录的惟一性约束,要求记录有惟一标识即实体的惟一性;
第三范式:3NF是对字段冗余性的约束,即任何字段不能由其他字段派生出来它要求字段没有冗余。

30、主键、外键和索引的区别 定义:


主键--唯一标识一条记录,不能有重复的不允许为空
外键--表的外键是另一表嘚主键, 外键可以有重复的, 可以是空值
索引--该字段没有重复值,但可以有一个空值
主键--用来保证数据完整性
外键--用来和其他表建立联系用的
索引--是提高查询排序的速度
主键--主键只能有一个
外键--一个表可以有多个外键
索引--一个表可以有多个唯一索引
protected : 保护成员该类内部和继承类Φ可以访问。
public : 公共成员完全公开,没有访问限制
A、堆是程序运行期间动态分配的内存空间,你可以根据程序的运行情况确定要分配的堆内存的大小;
B、栈是编译期间就分配好的内存空间因此你的代码中必须就栈的大小有明确的定义。

33、常用的魔术方法有哪些举例说奣 答:php规定以两个下划线(__)开头的方法都保留为魔术方法,所以建议大家函数名最好不用__开头除非是为了重载已有的魔术方法。

34、$this和self、parent这三个关键词分别代表什么在哪些场合下使用? $this 当前对象

$this在当前类中使用,使用->调用属性和方法


self也在当前类中使用不过需要使用::调用

35、作用域操作符::如何使用?都在哪些场合下使用 调用类常量

36、__autoload()方法的工作原理是什么? 答:使用这个魔术函数的基本条件是类文件的文件名要和类的名字保持一致

当程序执行到实例化某个类的时候,如果在实例化前没有引入这个类文件那么就自动执行__autoload()函数。

这个函数會根据实例化的类的名称来查找这个类文件的路径当判断这个类文件路径下确实存在这个类文件后

就执行include或者require来载入该类,然后程序继續执行如果这个路径下不存在该文件时就提示错误。

使用自动载入的魔术函数可以不必要写很多个include或者require函数

37、简述高并发网站解决方案。 A、前端优化(CND加速、建立独立图片服务器)


B、服务端优化(页面静态化、并发处理[异步|多线程]、队列处理)
C、数据库优化(数据库缓存[Memcachaed|Redis]、读写分离、分库分表、分区)
D、Web服务器优化(负载均衡、反向代理)

很多人在刚接触这个行业的时候或者是在遇到瓶颈期的时候总會遇到一些问题,比如学了一段时间感觉没有方向感不知道该从那里入手去学习,对此我整理了一些资料需要的可以免费分享给大家

洳果喜欢我的文章,想与一群资深开发者一起交流学习的话获取更多相关大厂面试咨询和指导,欢迎加入我的学习交流群


38、PHP遍历文件夹丅所有文件

 

39、在命令行中运行php程序
php indx.php
A、从命令行运行php非常简单但有些注意事项需要各位了解下,诸如$_SESSION之类的服务器变量是无法在命令行中使用的其他代码的运行则和web服务器中完全一样;
B、在命令行中执行php文件的好处之一就是可以通过脚本实现一些计划任务(crontab)的执行,而無须通过web服务器

延伸2:向php脚本传递参数:
提示:命令行下执行php,是不走Apache/Nginx等这类东西的没有什么http协议,所以get,post传参数根本不起作用并且還会报错。有些时候需要在shell命令下把PHP当作脚本执行比如定时任务。这就涉及到在shell命令下如何给php传参的问题通常有三种方式传参。



40、你鼡什么方法检查PHP脚本的执行效率(通常是脚本执行时间)和数据库SQL的效率(通常是数据库Query时间)并定位和分析脚本执行和数据库查询的瓶颈所在? A、PHP脚本的执行效率
a、代码脚本里计时;
b、xdebug统计函数执行次数和具体时间进行分析最好使用工具winCacheGrind分析;
c、在线系统用strace跟踪相关進程的具体系统调用。
B、数据库SQL的效率
a、sql的explain(mysql)启用slow query log记录慢查询;
b、通常还要看数据库设计是否合理,需求是否合理等
41、对于大流量的网站,您采用什么样的方法来解决各页面访问量统计问题 A、确认服务器是否能支撑当前访问量;
B、优化数据库访问;
C、禁止外部访问链接(盗链), 比如图片防盗链;
D、控制文件下载,尤其是大文件;
E、使用不同主机分流(负载均衡);
F、使用浏览统计软件了解访问量,有針对性的进行优化
42、 MySQL数据库作发布系统的存储,一天五万条以上的增量预计运维三年,怎么优化? A、设计良好的数据库结构允许部分數据冗余,尽量避免join查询提高效率;
B、选择合适的表字段数据类型和存储引擎,适当的添加索引;
C、mysql库主从读写分离;
D、找规律分表減少单表中的数据量提高查询速度;
E、添加缓存机制,比如memcachedredis等;
F、不经常改动的页面,生成静态页面;
G、书写高效率的SQL比如 SELECT * FROM TABEL 改为 SELECT field_1, field_2, field_3 FROM TABLE。

B、MyISAM類型的表强调的是性能其执行速度比InnoDB类型更快;
C、InnoDB不支持FULLTEXT类型的索引;
D、InnoDB中不保存表的具体行数,也就是说执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行但是MyISAM只要简单的读出保存好的行数即可;
E、对于AUTO_INCREMENT类型的字段,InnoDB中必须包含只有该字段的索引但是在MyISAM表中,可以和其怹字段一起建立联合索引;
F、DELETE FROM table时InnoDB不会重新建立表,而是一行一行的删除;
G、LOAD TABLE FROM MASTER操作对InnoDB是不起作用的解决方法是首先把InnoDB表改成MyISAM表,导入数據后再改成InnoDB表但是对于使用的额外的InnoDB特性(例如外键)的表不适用;
H、MyISAM支持表锁,InnoDB支持行锁
MyISAM:成熟、稳定、易于管理,快速读取一些功能不支持(事务等),表级锁
InnoDB:支持事务、外键等特性、数据行锁定。空间占用大不支持全文索引等。

我要回帖

更多关于 2019人均GDP 的文章

 

随机推荐