Sin*_*ial 6 c# stack-overflow list
我想知道如果我给自己添加一个列表会发生什么.也许堆栈溢出,可能是编译器错误?
List<object> lstobj = new List<object>();
lstobj.Add(lstobj);
Run Code Online (Sandbox Code Playgroud)
所以我执行了代码并检查了局部变量:
该列表似乎包含无限数量的列表实例.为什么没有堆栈溢出?列表是否只是指向原始列表的指针?但即使列表只是指针,指针也不会占用内存吗?
定义是这样的:
Line 1) object[] arr = new object[4];
Line 2) arr[0] = arr;
Run Code Online (Sandbox Code Playgroud)
arr[0]现在是另一个别名,arr并且 和 都arr具有arr[0]相同的值,即数组数据的地址。
内存状态可能如下:
第 1 行之后:
Address Value
@100: 104 // arr variable
@104: 0 // cell[0] of array data
@108: 0 // cell[1] of array data
@112: 0 // cell[2] of array data
@116: 0 // cell[3] of array data
Run Code Online (Sandbox Code Playgroud)
第 2 行之后:
Address Value
@100: 104 // arr variable
@104: 104 // cell[0] of array data
@108: 0 // cell[1] of array data
@112: 0 // cell[2] of array data
@116: 0 // cell[3] of array data
Run Code Online (Sandbox Code Playgroud)