理解抽象类最快的方法就是使用场景,最近在看布尔PHP视频中看到这样的讲解非常容易懂,分享出来。
假设如下场景:
团队准备开发某网站,表建好了,页面设计好了.
A组负责开发底层数据库操作类(DB)(多个DB类,操作Mysql类,操作SQLSERVER,SQLlite......).
B级负责调用DB类.
A组发生了争执,MySQL? Oracle? DB2? sqlite?规范是什么?
B组.... 在争执中漫长等待.
能否让B组不等待?
解决:
A组和B组先定1个数据库类的模板:
模板中对 方法名,参数,返回值,都做严格的规定
此时不管A组选用什么数据库,对于B组来说,没有任何影响;
代码如下:(只需要知道抽象类是一种规范,具体实现由子类来做。)
//定义一个抽象类,相当于模板 abstract class DB{ /* * 连接数据库,从配置文件读取配置信息 * */ abstract public function conn(); /* * 执行参数中的sql语句 * */ abstract public function query($sql); /* * 获取多行数据 * */ abstract public function getAll(); /* * 获取单条数据 * */ abstract public function getOne(); /* * 自定义创建Sql语句执行 (数据关联数组,表名字,动作,条件) * */ abstract public function Exce($data,$table,$act='insert',$where='0'); /* * 返回上一条insert语句产生的主键值 * */ abstract public function lastId(); /* * 返回上一条语句影响的行数 * */ abstract public function affectRows(); } //01.使用抽象类先来创建一个Mysql操作类 class Mysql extends DB{ public function __construct(){ } public function conn(){ } public function query($sql){ } public function getAll(){ } public function getOne(){ } public function Exce($data,$table,$act='insert',$where='0'){ } public function lastId(){ } public function affectRows(){ } } //02.使用抽象类先来创建一个Mssql操作类 class Mssql extends DB{ public function __construct(){ } public function conn(){ } public function query($sql){ } public function getAll(){ } public function getOne(){ } public function Exce($data,$table,$act='insert',$where='0'){ } public function lastId(){ } public function affectRows(){ } }
//$ak开发密钥,$cityname城市名称(支持省县乡详细地址) public function getposition($ak,$cityname){ $callback=array('lng'=>0,'l...
逛公众号文章看到文章"php实现事件监听与触发的方法,你用过吗?",我就好奇了,php又不是asp.net的webform,哪里来的服务端事件监听。于是学习了一波。先看下监听类:class Event { /** &nbs...
主要原理是通过PHP创建多个子进程,在子进程中发送进程闹钟信号,然后再监听闹钟信号中继续发送闹钟信号。同时通过父进程设置非阻塞运行。代码如下:<?php /** * 订单任务 */ class Order { &n...
参数中包含gb2312的字符串,返回结果是false或者null(不同PHP版本具有差异性)代码:<?php $dbms = 'mysql'; $host = '192.168.8.8'; $dbName =&n...
为什么使用队列?因为pop取队列具有原子性。假如我们需要秒杀一个商品id,我们先将商品的库存保存到一个队列。例如:<?php $redis = new Redis(); $redis->connect('127.0.0.1', 6...
PHP7中,通过生成器委托(yield from),可以将其他生成器、可迭代的对象、数组委托给外层生成器。外层的生成器会先顺序 yield 委托出来的值,然后继续 yield 本身中定义的值。同时yield from也能获取到生成器的返回值...