博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PHP队列原理及基于队列的写文件案例
阅读量:6693 次
发布时间:2019-06-25

本文共 2669 字,大约阅读时间需要 8 分钟。

队列是一种线性表,按照先进先出的原则进行的:

入队:

出队:

PHP实现队列:第一个元素作为队头,最后一个元素作为队尾

1
2
3
4
5
6
7
8
9
<?php
/**
 
* 队列就是这么简单
 
*
 
* @link
 
*/
$array
=
array
(
'PHP'
,
'JAVA'
);
array_push
(
$array
,
'PYTHON'
);
//入队列
array_shift
(
$array
);
//出队列

什么是双端队列(或双向队列)Deque,全名double-ended queue?

即元素可以在队列的任意一段入队或出队,如果我们把这些方法叫做insertLeft()和insertRight(),以及removeLeft()和removeRight()。如果严格禁止调用insertLeft()和removeLeft()方法(或禁用右段的操作),双端队列功能就和栈一样。禁止调用insertLeft()和removeRight()(或相反的另一对方法),它的功能就和队列一样了。双端队列与栈或队列相比,是一种多用途的数据结构。

PHP实现双端队列

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
<?php
class
Deque
{
  
public
$queue
=
array
();
  
/**(尾部)入队 **/
  
public
function
addLast(
$value
)
  
{
    
return
array_push
(
$this
->queue,
$value
);
  
}
  
/**(尾部)出队**/
  
public
function
removeLast()
  
{
    
return
array_pop
(
$this
->queue);
  
}
  
/**(头部)入队**/
  
public
function
addFirst(
$value
)
  
{
    
return
array_unshift
(
$this
->queue,
$value
);
  
}
  
/**(头部)出队**/
  
public
function
removeFirst()
  
{
    
return
array_shift
(
$this
->queue);
  
}
  
/**清空队列**/
  
public
function
makeEmpty()
  
{
    
unset(
$this
->queue);
  
}
  
/**获取列头**/
  
public
function
getFirst()
  
{
    
return
reset(
$this
->queue);
  
}
  
/** 获取列尾 **/
  
public
function
getLast()
  
{
    
return
end
(
$this
->queue);
  
}
  
/** 获取长度 **/
  
public
function
getLength()
  
{
    
return
count
(
$this
->queue);
  
}
}

队列的用途:

队列可以很好地异步处理数据传送和存储,当你频繁地向数据库中插入数据、频繁地向搜索引擎提交数据,就可采取队列来异步插入。另外,还可以将较慢的处理逻辑、有并发数量限制的处理逻辑,通过消息队列放在后台处理,例如FLV视频转换、发送手机短信、发送电子邮件等。

项目案例

这里有个项目,因为服务器权限问题,没办法安装安装队列程序,而且并发300+,服务商的数据库最大连接数是300,为了解决这个问题所以编写了一个简单的队列程序,代码如下

读队列代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
<?php
set_time_limit(0);
$file_name3
=
'3.txt'
;
//这个地方是讲队列文件读出的内容写入文件,test中代替的是mysql数据库操作
$file3
=
fopen
(
$file_name3
,
'a'
);
while
(true)
{
  
$c
= FALSE;
  
$file_name
=
'1.txt'
;
//队列文件
  
$file
=
fopen
(
$file_name
,
'r'
);
  
if
(!
feof
(
$f
))
  
{
    
//获得第一条数据
    
$a
=
fgets
(
$file
);
    
if
(!
empty
(
$a
))
    
{
      
$c
= TRUE;
      
fwrite(
$file3
,
$a
);
//这里可以改为数据库操作
    
}
  
}
  
fclose(
$file
);
  
if
(
$c
)
  
{
    
//将文件的第一条数据删除
    
exec
(
'sed -i \'1d\' /var/www/csv_sql/1.txt'
);
  
}
  
sleep(1);
  
if
(time()>=
strtotime
(
'20160416150000'
))
  
{
    
exit
;
  
}
}
fclose(
$file3
);

读队列程序其实就是一个死循环程序,如不设置关闭点,则一直循环读取文件

写入队列程序比较简单,就是写文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<?php
set_time_limit(0);
$file_name2
=
'2.txt'
;
//test中用来比对队列程序是否正常的
$file2
=
fopen
(
$file_name2
,
'a'
);
for
(
$i
=1;
$i
<11;
$i
++)
{
  
$file_name
=
'1.txt'
;
//队列文件
  
$file
=
fopen
(
$file_name
,
'a'
);
//fopen的mode属性必须是a或a+
  
$str
=
$i
.
'--'
.rand(100001,999999);
  
fwrite(
$file
,
$str
.
"\n"
);
  
fwrite(
$file2
,
$str
.
"\n"
);
  
sleep(1);
  
fclose(
$file
);
}
fclose(
$file2
);

转载于:https://www.cnblogs.com/zyiii/p/8821888.html

你可能感兴趣的文章
并查集(Union-Find)算法介绍
查看>>
MySQL主从配置
查看>>
java实现的web网络书店
查看>>
Shell脚本介绍(资源)
查看>>
分享HTML5自动化构建工具gulp使用方法步骤
查看>>
BootStrap 资源汇总
查看>>
一次、二次、三次指数平滑计算思想及代码
查看>>
13.2管理网络冗余与数据存储群集
查看>>
阿里开源的 java 诊断工具—— Arthas
查看>>
Angular CLI 创建你的第一个 Angular 示例程序
查看>>
深入理解javascript原型和闭包(16)——完结
查看>>
如何点击每一列的时候alert其index
查看>>
【原创翻译】类型
查看>>
深入解读Windows Azure VM 实例级 IP
查看>>
C++ 一个自己实现的字符串类
查看>>
大型网站架构演变和知识体系
查看>>
Nginx配置文件nginx.conf中文详解
查看>>
DITA vs DocBook
查看>>
python笔记二 基础
查看>>
mysqlbinlog 使用
查看>>