4

根据Coldfusion文档...“数组通过值传递给用户定义的函数,因此函数获取数组数据的新副本,调用页面中的数组不被函数更改。

所以我正在做一个小练习项目。我首先获取一个数字列表,将其转换为数组(我称之为 cardArray),然后对数组进行排序,最后将数组传递给几个 UDF,它们将在数字中查找各种模式并进行操作(如果需要) 参数(又名传递的数组)。

我从不引用 UDF 中的原始数组,我只引用参数名称。仍然......如果我在调用函数后 cfdump 原始数组,我的原始数组已被更改。谁能告诉我为什么?

我很确定我可以解决这个问题。因此解决这个问题不是我的大问题。我的问题是,这种行为完全与我“认为”它会起作用的方式相矛盾,这让我发疯了!

    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>

结果是:

函数调用前的原始数组 [6,6,7,8,10,8,9]。

函数调用后的原始数组 [10,9,7,6,5]

数组已排序(我期望这是正确的)。然而,8s 也不见了。我没想到会这样。8 被第一个函数中的 arrayDeleteAt(pairArray, i) 和 arrayDeleteAt(pairArray, i-1) 方法删除。但是这应该只从数组参数(pairArray)中删除元素,而不是原始数组(或者我认为)。

4

2 回答 2

8

由于您在此处标记了 Lucee,我假设您在 Lucee 而不是 Adob​​e 的实现上运行它。在这种情况下,Lucee 不符合 Adob​​e 规范;数组像所有其他复杂对象一样通过引用传递。

于 2016-03-09T19:51:09.217 回答
1

这可能非常令人困惑,也涉及结构。执行 a<cfset arrayCopy = originalArray>然后使用某些函数修改 arrayCopy 并不能保证原始数组仍然受到保护。解决方案是像这样进行深层复制:

<cfset arrayCopy = Duplicate(originalArray)>
于 2016-03-10T09:18:17.160 回答