向字符串末尾追加字符时, 使用 String#concat 或 << 运算符(String#<<)
s = 'abc'
s.concat('def')
p s #=> "abcdef"
s = 'abc'
s << 'def'
p s #=> "abcdef"
<< 运算符还可以有以下的写法
s = ''
s << 'abc' << 'def'
p s #=> "abcdef"
当然,如果使用 += 运算符也会达到以上的相同效果,
但是 ruby 中并不建意使用此方 法。
为什么呢? 让我们来看看内存是如何工作的,就会明白了。
+= 方法 |
concat 方法 |
XXX| |
XXX| |
XXX| XXX|XXX| |
XXX|XXX| |
XXX| XXX|XXX| XXX|XXX|XXX| |
XXX|XXX|XXX| |
+= 方法是先复制原字符串后,在复本字符串尾部追加。 这种方法会吃掉大量的内存。
而 concat 方法是直接在原字符串尾部追加。
我们在来测试一下两种方法的速度
# 约 30 秒
box = ''
50000.times{ box += 'xxx|' }
# 约 0.05 秒
box = ''
50000.times{ box.concat('xxx|') }
分享到:
相关推荐
output += inputs[i] ``` 这段代码展示了如何将多个输入特征图进行逐元素相加。 **Concatenation(拼接融合)**,如在DenseNet中使用,它涉及将多个特征图沿着某个轴(通常是通道轴)连接起来,形成一个新的特征...
Oracle新版中不支持 WM_CONCAT的处理方法,直接创建一个自定义函数代替
JavaScript中的`concat()`方法是一个非常实用的工具,用于合并两个或更多数组,或者将值添加到数组中。这个方法不会改变原始数组,而是返回一个新的合并后的数组。这使得`concat()`成为一种安全的方式,可以在不破坏...
在Oracle数据库环境中,`WM_CONCAT`函数是一个非常实用的工具,用于将多个行的数据合并成单个字符串。然而,自Oracle 11g R2版本开始,这个函数被标记为弃用,导致许多用户在使用时遇到问题。标题中的"wm_concat函数...
综上所述,JavaScript中的字符串拼接有多种策略,包括连续使用`+=`、分块拼接、数组`concat`方法以及利用DOM对象。对于大型字符串,使用数组和DOM操作通常能提供更好的性能。在实际应用中,应根据具体场景选择最合适...
其中,push()、pop() 和 concat() 方法是三种常用的数组操作方法。 push() 方法 push() 方法用于将一个或多个元素添加到数组的末尾,并返回数组的新长度。该方法的语法为: `arrayObj.push([item1 [, item2 [, .....
`push` 和 `concat` 是两种常见的数组操作方法,它们都能用于向数组添加元素,但有着本质的区别。了解这些区别有助于更有效地编写代码。 首先,让我们来看一下 `push` 方法。`push` 方法用于在数组的末尾添加一个或...
在CODESYS编程环境中,CONCAT函数是...在编写涉及字符串处理的CODESYS程序时,熟练掌握CONCAT函数的使用方法是提高效率的关键。通过深入了解和实践,你将能够自如地应对各种字符串处理挑战,为你的项目增添更多可能性。
然而,与MySQL等其他数据库系统不同,SQL Server原生并不支持`GroupConcat`。因此,为了在SQL Server中实现类似的功能,我们需要依赖一些额外的工具或方法,如使用CLR(公共语言运行时)存储过程。 `SqlServer ...
这篇文章主要介绍了JS合并两个数组的3种方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,...这里有一个问题,concat方法连接a、b两个数组后,a、b两个数组的数据不变,同时会返
在JavaScript中,数组是常用的数据结构之一,有时我们需要将两个或更多的数组合并成一个数组。...希望这篇关于 JS 数组合并 push 与 concat 区别的分析能够帮助你在 JavaScript 程序设计中更加得心应手。
使用`+=`运算符也可以达到相同效果,且在连续连接多个字符串时更高效: ```java String str3 = ""; str3 += "Hello"; str3 += " "; str3 += "World"; ``` `concat()`方法的使用如下: ```java String str4 = ...
`concat()`函数是Pandas用于组合DataFrame对象的一种方法,它允许你在垂直(行)或水平(列)方向上拼接数据。 首先,我们要理解`concat()`的基本用法。当你有多个包含相同列名的Excel文件(即具有相同结构的数据集...
是处理wm_concat中以varchar处理合并列字段过小。 clob 可以加大处理。 oracle 9I oracle 10G 必备
自定义`wm_concat`函数的一种常见方法是创建一个聚合函数,通常使用PL/SQL实现。以下是一个简单的例子: ```sql CREATE OR REPLACE FUNCTION WM_CONCAT (p_val VARCHAR2) RETURN VARCHAR2 PARALLEL_ENABLE ...
在Oracle中,如果没有WM_CONCAT函数,可以有以下几种替代方法: 1. 使用LISTAGG函数:从Oracle 11g开始,官方提供了LISTAGG函数,它可以按照指定的分隔符连接字符串。例如: ```sql SELECT LISTAGG(column, ', ')...
如果压缩包中的文件是自定义函数,那么在你的环境中部署这个函数后,你就可以继续使用与WM_CONCAT类似的功能,但要注意,这种方法可能会影响性能,因此在生产环境中使用前需要进行充分的测试。 总之,面对"ORA-...
本文实例讲述了JavaScript使用concat连接数组的方法。分享给大家供大家参考。具体如下: 下面的代码演示了JS中如何通过concat函数链接多个数组 <!DOCTYPE html> <html> <body> [removed] var ...
没有WMSYS.WM_CONCAT方法 需要的文件 owmctab.plb owmaggrs.plb owmaggrb.plb 拷贝三个文件到 $ORACLE_HOME\RDBMS\ADMIN\ 目录下 打开命令行 sqlpus , 用sys 登陆 执行命令 @$ORACLE_HOME\RDBMS\ADMIN\owmctab.plb...
通过以上步骤,可以在Oracle 10G及更早版本中实现与内置`wm_concat`函数类似的功能。这种方法不仅可以帮助我们在早期版本的Oracle数据库中实现字符串连接功能,还可以加深我们对Oracle数据库内部机制的理解。