PHP注释、数据类型、算术运算(笔记13)
网络安全自学笔记13
继续学习PHP
因为代码是英文的、并且代码很长,时间长了人会忘。所以我们会加上注释
注释的功能有:
- 对重点进行标注
- 时间长了容易忘快速回忆,方便查找
- 让其他人看的时候快速看懂
- 还可以生成文档,代码写完相关的文档就写完了,提高工作效率
- 注释、空行、回车之后的代码看起来更优美
- 注释可用来排错。不确定代码中哪一块写错了,可以将一大段注释,确定错误区间
- 注释中间的部分的内容,电脑不会执行它
1、单行注释
// 表示单行注释
# #号也表示单行注释,用的比较少
单行注释
注释不显示
2、多行注释
/*
多行注释 这里是注释区域代码
*/
多行注释
注释不显示
PHP中一共有八种数据类型,包括4种标量数据类型,即boolean(布尔类型),integer(整型),float/double(浮点型)和string(字符串型);两种复合数据类型,即array(数组)和object(对象);两种特殊的数据类型:即resource(资源)与 null (无,空白)
1、布尔型数据
布尔型数据
显示输出
2、字符串数据
在PHP语言中声明字符串有三种方式:
- 用单引号声明
单引号声明
显示输出
- 用双引号声明
双引号声明
显示输出
- 用字界符声明(需要输入非常大段的字符串时使用)
①在变量后面的等号写三个小于号(<<<)
②然后在<<<后面写上字符(建议英文大写字符),如下例中的:ABC
③然后换行写上任意想写的字符
字界符声明
显示输出
3、整型数据
整型——整数也,英文称之:integer。英文简写:int
整型分为:
- 10进制
10进制
显示输出
- 8进制 (了解,基本不用)
8进制
显示输出
- 16进制(了解,基本不用)
16进制
显示输出
4、浮点型数据
所谓浮点类型,可以理解为:我们数学里面的小数。
声明方式分为两种:普通声明和科学声明
- 普通声明浮点数:
普通声明
显示输出
- 科学声明浮点数:
科学声明
显示输出
5、查看和判断数据类型
- gettype能够获得变量的类型
gettype
double
- var_dump输出变类型和值
var_dump
string
- is_* 系列函数判断数据类型,如果是这个类型返回真,不是这个类型返回假
is_int 是否为整型
is_float 是否是浮点
is_string 是否是字符串
is_array 是否是数组
is_object 是否是对象
is_null 是否为空
is_resource 是否为资源
is_scalar 是否为标量
is_numeric 是否为数值类型
is_callable 是否为函数
is_bool 是否为布尔
为假
赋值运算符
例:
1、php自加自减
自加自减,就是把自己加1,或者减1
例:
2、php比较运算
例:
3、php逻辑运算
例:
4、php位运算
$a & $b And(按位与) 将把 $a 和 $b 中都为 1 的位才设为 1,其他的的设为0
$a | $b Or(按位同或) 将把 $a 和 $b 中任何一个为 1 ,则设为1
$a ^ $b Xor(按位异或) 将把 $a 和 $b 中任意一个为 1 另一个为 0 的位设为 1,如果两个数一样则设为0
~ $a Not(按位取反) 将 $a 中0变1,1变0
$a << $b Shift left(左移) 将 $a 中的位向左移动 $b 次(每一次移动都表示“乘以 2”)
$a >> $b Shift right(右移) 将 $a 中的位向右移动 $b 次(每一次移动都表示“除以 2”)
$a | $b
显示输出
5、php三元运算符
三元条件运算符的基本语法如下:
条件表达式 ? 表达式1 : 表达式2;
条件表达式:这是一个需要评估的表达式,其结果将是布尔值(true 或 false)
表达式1:如果条件表达式的结果为 true,则执行并返回表达式1的结果
表达式2:如果条件表达式的结果为 false,则执行并返回表达式2的结果
三元条件运算符
显示输出
总结:
1、继续学习PHP语言
2、学习PHP注释、数据类型、算术运算
开源直播系统源码—为什么要使用PHP语言
开展开源直播系统源码的的开发工作的时候,开发人员们碰到的最多问题便是使用什么语言开发的,回答大多是PHP语言。而对于没有的开发经验的人而言,难以理解PHP语言究竟代表着什么,又有哪些作用。
实际上,PHP是一种开源脚本语言。语法吸收了C语言、java和Perl的特点,有利于学习,运用范围广,主要是适用于Web的开发领域。
PHP由内核Zend引擎和扩展层组成,PHP内核负责解决请求、进行文件流错误处理等操作,Zend引擎可以将PHP程序文件转化成刻在虚拟机上运作的机器语言,扩展层给予一些应用层操作要用到的函数类库等,例如数组和MySQL数据库的操作等。
开源直播系统源码Zend引擎是使用C语言进行的,将PHP代码根据词法语法解析成可执行的opcode并进行相对应的处理方法和基本的数据结构开展内存分配和管理等,对外给予相对应的能够调用的API方法。Zend引擎是PHP的核心,所有的外部功能全是围绕着它进行的。扩展层根据组件的方法给予各种各样的基础服务、内置函数,标准库全是根据它进行的。客户还可以撰写自己开源直播系统源码的扩展来进行指定的需求。服务器端运用编程接口,根据一连串钩子函数使得PHP能够和外部交互数据。大家平时开源直播系统源码撰写的PHP程序便是根据不一样的SAPI方法获得不一样的应用模式,如根据web进行的web应用和命令下运作的脚本等。
作为开源直播系统的开发语言,PHP语言的优点在于:
1.PHP的开发成本低,入门学习快,语法也相对简单,并且给予充足的类库
2.PHP与Linux、Nginx、Apache、MySQL能够方便快捷的搭建出一整套系统,支持直接调用系统命令,用代码进行很多操作Linux的工作
3.PHP支持运用多种数据库,这其中与MySQL的结合是较为流行的,PHP给予3种链接MySQL的扩展。PDO扩展是PHP退出的连接MySQL和其他类型的数据库的一类统一解决方案。可扩展性非常高,运用它能够灵活方便地切换不一样类型的数据库,并且不用变动更多的代码
4.PHP是解释执行的脚本语言,写完程序后,能够立即执行,因此它的开发效率非常高
编程新手看过来,一文教会你如何用PHP实现高并发服务器?
一提到高并发,就没有办法绕开I/O复用,再具体到特定的平台linux, 就没办法绕开epoll. epoll为啥高效的原理就不讲了,感兴趣的同学可以自行搜索研究一下。
01
php怎么玩epoll?
首先得安装个libevent库,再装个event扩展或者libevent扩展就可以愉快地玩耍了.
有些人搞不清楚libevent库跟libevent扩展的区别,简单来说:
libevent库是C语言对epoll的封装,跟PHP毛关系都没有;libevent扩展就是PHP跟libevent库的沟通桥梁。实际上PHP的很多扩展就是干这个事的,有一些优秀的C语言库,PHP想直接拿来用,就通过PHP扩展的方式接入到PHP。
libevent扩展和event扩展随便选一个装,我个人更喜欢event扩展,因为更面向对象一点。
自己去http://pecl.php.net里面搜跟自己PHP版本对应的扩展,下好编译安装一下就OK了。
电脑装了多个版本的PHP编译的时候注意一下,phpize的版本要对应上,别搞错了,典型的五步曲:
1 phpize
2 ./configure
3 make
4 make install
5 php -m | grep event #看看装上了没
02
如何用PHP实现高并发服务器?
我们要实现的服务器,传输层是TCP协议,应用层协议太多太复杂,限于篇幅,会简单地以HTTP服务器举个例子,HTTP协议本身就很复杂,要实现起来细节上有很多考究,我们也不会完全实现HTTP协议。
首先,创建一个socket三步曲:
socket_create、socket_bind、socket_listen,为什么是这三步曲呢?
很简单,不管你传输层协议是啥,你下面的网络层协议你得选个版本吧,IPV4还是IPV6,传输层工作方式你得选一个吧,全双工、半双工还是单工,TCP还是UDP你也得选一个吧,socket_create就是这三个选项;
确定了网络层和传输层,你得告诉我监听哪个端口吧,这就对应了socket_bind;
然后你得开启监听,并指定一个客户端的队列长度吧,这就是socket_listen干的事。
创建完了,同步阻塞咱就不介绍了,一个进程同时最多hold处一个连接,多几个连接同时请求,就得等呗,超过了socket_listen指定的队列长度,就得返回504了。
多进程也一样,几个进程就有几个并发,进程又是昂贵资源,而且进程的上下文切换费时费力,导致整个系统效率低下。
没关系,咱有epoll,hold住万千请求不是梦,先实现一个Reactor。libevent库就是Reactor模式,直接调用函数就是在使用Reactor模式,所以无需纠结到底php怎么实现Reactor模式。
上面的代码很简单,简单解释一下概念,EventBase就是个容器,里面装的Event实例,这么一说,上面的代码就非常好懂了。然后一个Server.
Connection
先创建Socket的三步曲,设置成非阻塞模式。然后把socket加到Reactor中监听可读事件,可读的意思就是,缓冲区有数据了,才可读。
可读事件发生,说明有新连接来了,用stream_socket_accept接收新连接Conn,把Conn放到Reactor中监听可读事件,可读事件发生,说明客户端有数据发送过来了,循环读直到没数据,然后把Conn放到Reactor中监听可写事件,可写事件发生,说明客户端数据发送完了,把协议组装一下写入响应。
应用层如果是HTTP协议要注意一下Connection: keep-alive头,因为要复用连接,不要一写完就关闭连接。
撸完收工,用ab测一下并发,加-k参数复用连接,i5+8G,3W的并发没啥问题,当然我们这儿没有磁盘I/O,实际情况要从磁盘读取文件,读文件要通过linux的系统调用,而且有几次的文件拷贝操作,花销比较大,常用的解决思路是sendfile,零拷贝直接从一个FD到另一个FD,效率比较高,缺点就是PHP没有现成的已经实现sendfile的扩展,得自己动手,开发成本有点高。
ab测试PO图:
这就是PHP实现高并发服务器的思路了,只要是用EPOLL解决的,思路都一样,都是三步曲,放到Reactor下监听FD事件。
当然这个只是最简单的模型,还有很多可以改进的地方,比如说多进程,抄袭一下nginx,一个主进程+N个工作进程,多进程的目的还是想利用多核并行工作。
C语言实现也是这样,只是你可能不用libevent库,自己封装EPOLL,毕竟libevent库有点重,你也用不到libevent的很多东西;
当然了,C语言有一堆的数据结构以及定义在数据结构上的操作要写,没有GC,自己管理内存,还要有良好的设计,上多进程还得搞一搞IPC进程间通信的东西,开发难度比PHP要大地多,开发周期也很长,有兴趣的同学可以自己撸一个玩。
如果你对作者的课程感兴趣,蓝桥云课上线了该老师的《PHP Socket 编程基础入门》课程,如果你是蓝桥云课的刷题会员或者是学习会员,可免费学习该课程。
《PHP Socket 编程基础入门》难度为中级,如果你完全没有接触过php编程语言,那么不推荐你学习该课程。你可以先从蓝桥云课上学习《PHP 编程入门》。
本文作者及来源:Renderbus瑞云渲染农场https://www.renderbus.com
文章为作者独立观点不代本网立场,未经允许不得转载。