为什么我的原始数组会被更改?

时间:2016-03-09 19:17:29

标签: arrays coldfusion user-defined-functions udf lucee

基于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)中删除元素,而不是原始数组(或者我认为)。

2 个答案:

答案 0 :(得分:8)

由于你在这里标记了Lucee,我假设你在Lucee上运行它而不是Adobe的实现。 Lucee在这种情况下不符合Adobe规范; arrays are passed by reference和所有其他复杂对象一样。

答案 1 :(得分:1)

这可能非常令人困惑,担忧结构也是如此。执行<cfset arrayCopy = originalArray>然后使用某些函数修改arrayCopy将无法保证原始数组仍然受到保护。解决方案是制作这样的深层副本:

<cfset arrayCopy = Duplicate(originalArray)>