基于Coldfusion文档..." Arrays are passed to user-defined functions by value, so the function gets a new copy of the array data, and the array in the calling page is unchanged by the function."
所以我正在做一个小练习项目。我首先获取一个数字列表,将其转换为数组(我称之为cardArray),然后对数组进行排序,最后将数组传递给几个UDF,这些UDF将查找数字中的各种模式,并进行操作(如果需要)参数(也就是传递的数组)。
我从不在UDF中引用原始数组,我只引用参数名称。仍然...如果我在调用函数后cfdump原始数组,我的原始数组已被更改。谁能告诉我为什么?
我很确定我可以解决这个问题。因此,解决这个问题不是我的大问题。我的问题是,这种行为完全违背了我的思想和#34;这会起作用,它让我发疯!
function hasPair(pairArray) {
pairCount = 0;
for (i=2; i lte arrayLen(pairArray); i++){
if(pairArray[i] is pairArray[i-1]){
pairCount++
arrayDeleteAt(pairArray, i)
arrayDeleteAt(pairArray, i-1)
i=2
}
}
return pairCount;
}
function hasStraight(straightArray){
sequenceCards = 0;
for (i=2; i lte arrayLen(straightArray); i++){
if(straightArray[i] - straightArray[i-1] is 1){
sequenceCards++
}
}
if (sequenceCards GTE 4){
return 1;
}
else{
return 0;
}
}
</cfscript>
<cfoutput>
<cfset cardList = "5,6,7,8,10,8,9">
<cfset cardArray = listToArray(cardList)>
<cfdump var="#cardArray#" label="Original Array Before">
<cfset arraySort(cardArray, "numeric", "desc")>
#hasPair(cardArray)# <br/>
#hasStraight(cardArray)# <br/>
<cfdump var="#cardArray#" label="Original Array After">
</cfoutput>
结果:
原始数组BEFORE函数调用[6,6,7,8,10,8,9]。
原始数组AFTER函数调用[10,9,7,6,5]
数组已排序(我期望,并且是正确的)。 但是,8s也不见了。我没想到这一点。 8s由第一个函数中的arrayDeleteAt(pairArray,i)和arrayDeleteAt(pairArray,i-1)方法删除。但这应该只是从数组参数(pairArray)中删除元素,而不是原始数组(或者我认为)。
答案 0 :(得分:8)
由于你在这里标记了Lucee,我假设你在Lucee上运行它而不是Adobe的实现。 Lucee在这种情况下不符合Adobe规范; arrays are passed by reference和所有其他复杂对象一样。
答案 1 :(得分:1)
这可能非常令人困惑,担忧结构也是如此。执行<cfset arrayCopy = originalArray>
然后使用某些函数修改arrayCopy将无法保证原始数组仍然受到保护。解决方案是制作这样的深层副本:
<cfset arrayCopy = Duplicate(originalArray)>