swoole_table->__construct [编辑本页]

创建内存表。

swoole_table->__construct(int $size)
  • $size参数指定表格的最大行数,如果$size不是为2的N次方,如10248192,65536等,底层会自动调整为接近的一个数字
  • table占用的内存总数为 (结构体长度 + KEY长度64字节 + 行尺寸$size) * (1.2预留20%作为hash冲突) * (列尺寸),如果机器内存不足table会创建失败
  • set操作能存储的最大行数与$size无关,如$size为1024实际可存储的行数小于1024

swoole_table基于行锁,所以单次set/get/del在多线程/多进程的环境下是安全的
set/get/del是原子操作,用户代码中不需要担心数据加锁和同步的问题

容量计算

Table底层是建立在共享内存之上的HashTable数据结构。$size最大行数,决定了HashTable的总行数。由于Table是在共享内存之上,所以无法动态扩容。这个$size必须在创建前设置好。

Table能存储的总数据行数,取决于数据的Key冲突率。如果冲突率超过20%,预留的hash冲突内存块容量不足,就会报Unable to allocate memory错误,并返回false,存储失败。


  • 丰灵

    这里的size有问题啊,我设置了size为10的话 在插入第五行数据过后就会出现 Unable to allocate memory 这个错误,如果设置为20行的话 在第11行插入过后就会出现错误,求指教!!

  • 小宇

    我测试时候也发现这个size不对,当我设为200000时,最多只能加42048条记录,超过就会提示Warning: swoole_table::set(): Unable to allocate memory,麻烦开发人员看看怎么回事。

  • 周振忠

    必须为2的指数

  • 屏风山下的猎人

    swoole_table的生命周期是不是随着进程的存在而存在?