时间:2021-05-26
只是做记录,osc本站应该有重复的
semWrapper.class.php
/* * 信号量(Semaphore)。 * 这是一个包装类,用于解决不同平台下对“信号量”的不同实现方式。 * 目前这个类只是象征性的,在 Windows 平台下实际是空跑(并没有真的实现互斥)。 */class SemWrapper{ private $hasSemSupport; private $sem; const SEM_KEY = 1; public function __construct() { $this->hasSemSupport = function_exists( 'sem_get' ); if ( $this->hasSemSupport ) { $this->sem = sem_get( self::SEM_KEY ); } } public function acquire() { if ( $this->hasSemSupport ) { return sem_acquire( $this->sem ); } return true; } public function release() { if ( $this->hasSemSupport ) { return sem_release( $this->sem ); } return true; }}SeqGenerator.class.php
/* * 顺序号发生器。 */class SeqGenerator{ const SHM_KEY = 1; /** * 对顺序号发生器进行初始化。 * 仅在服务器启动后的第一次调用有效,此后再调用此方法没有实际作用。 * @param int $start 产生顺序号的起始值。 * @return boolean 返回 true 表示成功。 */ static public function init( $start = 1 ) { // 通过信号量实现互斥,避免对共享内存的访问冲突 $sw = new SemWrapper; if ( ! $sw->acquire() ) { return false; } // 打开共享内存 $shm_id = shmop_open( self::SHM_KEY, 'n', 0644, 4 ); if ( empty($shm_id) ) { // 因使用了 'n' 模式,如果无法打开共享内存,可以认为该共享内存已经创建,无需再次初始化 $sw->release(); return true; } // 在共享内存中写入初始值 $size = shmop_write( $shm_id, pack( 'L', $start ), 0 ); if ( $size != 4 ) { shmop_close( $shm_id ); $sw->release(); return false; } // 关闭共享内存,释放信号量 shmop_close( $shm_id ); $sw->release(); return true; } /** * 产生下一个顺序号。 * @return int 产生的顺序号 */ static public function next() { // 通过信号量实现互斥,避免对共享内存的访问冲突 $sw = new SemWrapper; if ( ! $sw->acquire() ) { return 0; } // 打开共享内存 $shm_id = shmop_open( self::SHM_KEY, 'w', 0, 0 ); if ( empty($shm_id) ) { $sw->release(); return 0; } // 从共享内存中读出顺序号 $data = shmop_read( $shm_id, 0, 4 ); if ( empty($data) ) { $sw->release(); return 0; } $arr = unpack( 'L', $data ); $seq = $arr[1]; // 把下一个顺序号写入共享内存 $size = shmop_write( $shm_id, pack( 'L', $seq + 1 ), 0 ); if ( $size != 4 ) { $sw->release(); return 0; } // 关闭共享内存,释放信号量 shmop_close( $shm_id ); $sw->release(); return $seq; }}page.php
//使用方法 $seq = SeqGenerator::next(); var_dump($seq);以上所述就是本文的全部内容了,希望大家能够喜欢。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
使用PHP读取日志文件,当文件比较大的时候,会报内存不足,因此应该部分读取,读取指定的行数的数据PHP代码:readLogs(self::LOG_PATH,se
最近导出的时候出现一个php内存溢出的问题,原因就是在于下载的时候读取生成的临时文件过大,PHP内存无法容纳,一开如是想到更改PHP内存限制,但是这个只是一个缓
cpu读取数据的顺序是先Cache后内存。cache叫做高速缓冲存储器,是集成在CPU中的,存取速度最快,其次是内存,速度最慢的是外存,也就是硬盘。 CPU缓
笔记本能装2个硬盘,2个内存。硬盘的读写是采用半随机存取的方式,可以以任意顺序读取硬盘中的数据,但读取不同位置的资料速度不相同。 硬盘(英语:HardDisk
本文实例讲述了php实现读取和写入tab分割的文件。分享给大家供大家参考。具体分析如下:这段php代码实现读取和写入tab分割的文件,包含两个独立的函数,一个读