php gc_collect_cycles,php – 什么gc_collect_cycles函数是有用的?

默认情况下,PHP已启用“垃圾收集器”.它用于释放“垃圾”使用的内存.

gc_collect_cycles()强制收集任何现有的垃圾循环.它返回收集(释放)循环的数量(对象,变量值…).启用垃圾收集器不时调用此函数来释放资源.在大多数情况下,PHP脚本生活的时间很短.在这种情况下,所有垃圾将在工作结束时被破坏,而不会收集任何垃圾.

有时需要手动管理GC:

> gc_disable()可以加快一些长时间的操作,但也会导致一些内存开销.

> gc_collect_cycles()可用于指定GC的正确时刻.

另一个使用gc_collect_cycles()的原因 – 调试.假设你想知道memory_get_usage()的一些代码块的内存消耗是多少.您需要首先禁用GC,否则您会得到错误的结果.之后,您需要分离GC和应用程序所消耗的时间.所以调用gc_collect_cycles()并测量前后的时间/内存.

小例子

class A {

public $ref;

public $name;

public function __construct($name) {

$this->name = $name;

echo($this->name.'->__construct();'.PHP_EOL);

}

public function __destruct() {

echo($this->name.'->__destruct();'.PHP_EOL);

}

}

gc_disable();

$a1 = new A('$a1');

$a2 = new A('$a2');

$a1->ref = $a2;

$a2->ref = $a1;

$b = new A('$b');

$b->ref = $a1;

echo('$a1 = $a2 = $b = NULL;'.PHP_EOL);

$a1 = $a2 = $b = NULL;

echo('gc_collect_cycles();'.PHP_EOL);

echo('// removed cycles: '.gc_collect_cycles().PHP_EOL);

echo('exit();'.PHP_EOL);

会输出:

$a1->__construct();

$a2->__construct();

$b->__construct();

$a1 = $a2 => $b = NULL;

$b->__destruct();

gc_collect_cycles();

$a2->__destruct();

$a1->__destruct();

// removed cycles: 4

这意味着当被问及时,只有b $b被销毁.其他$a1和$a2具有循环引用,它的名称属性也消耗内存.两个对象两个字符串= 4(由gc_collect_cycles()删除).

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: concat_ws函数是一个字符串函数,用于将多个字符串连接成一个字符串,其中可以指定一个分隔符。 collect_set函数是一个聚合函数,用于将一个列中的所有不同的值收集到一个集合中,返回一个包含所有不同值的集合。 ### 回答2: concat_ws函数collect_set函数都是在Hive中使用的函数。 我们先来介绍一下concat_ws函数。concat_ws函数的作用是将多个字符串连接成一个字符串,以特定的分隔符分隔。其中,ws的意思是with separator。这个函数的语法如下: concat_ws(string delimiter, string str1, string str2,...) 其中,delimiter表示分隔符,可以是一个字符串或者是字符集,str1表示要连接的第一个字符串,str2表示要连接的第二个字符串,以此类推。这个函数会将给定的所有字符串连接成一个字符串,字符串之间用delimiter分隔。如果给定的字符串中含有null,则这个函数会将null视为一个空串。 接下来我们来介绍一下collect_set函数collect_set函数的作用是将指定列中的值收集到一个集合中,并返回不重复的值。这个函数的语法如下: collect_set(col) 其中,col表示要执行收集操作的列。这个函数会将这个列中所有不重复的值收集到一个集合中。我们可以将collect_set和group by一起使用,这样可以将指定列中每个分组中的不重复的值都收集起来。 比如说,我们可以使用collect_set函数来查找每个卖家所售卖的不同商品的品类: SELECT sellerid, collect_set(category) FROM sales GROUP BY sellerid; 以上就是concat_ws函数collect_set函数的详细介绍了。这两个函数在Hive中使用非常频繁,对于数据处理和分析非常有用,也可以节省我们写复杂SQL语句的时间和精力。 ### 回答3: concat_ws函数collect_set函数都是在Hive中使用的函数,可以方便地对数据进行处理。 concat_ws函数 concat_ws函数用于将多个字符串连接起来,使用指定的分隔符。其中,concat表示合并函数,ws表示with separator,即使用分隔符连接。 语法: concat_ws(separator,str1,str2,….)    其中separator表示分隔符,str1、str2表示要连接起来的字符串。 示例: concat_ws(',', 'Apple', 'Orange', 'Banana') 将返回字符串 "Apple,Orange,Banana"。 在SQL语句中可以使用该函数处理数据,使各列数据连接起来。 collect_set函数 collect_set函数用于返回一个集合,该集合包含去重后的某个字段的值。比如对于一个表中的某个字段,执行collect_set函数后,返回的是去重后该字段的所有值的集合。 语法: collect_set(col) 其中col表示要去重的字段。 示例: SELECT collect_set(id) FROM table1; 该语句会返回去重后的id集合。 注:由于collect_set使用了集合的数据结构,因此该函数只能够用来处理数值型或者字符串类型的数据,不能用来处理复杂类型的数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值