我想知道如果我给自己添加一个列表会发生什么.可能是堆栈溢出,也许是编译器错误?
List<object> lstobj = new List<object>(); lstobj.Add(lstobj);
@H_301_5@
该列表似乎包含无限数量的列表实例.为什么没有堆栈溢出?列表是否只是指向原始列表的指针?但即使列表只是指针,指针也不会占用内存吗?@H_301_5@
解决方法
定义是这样的:
Line 1) object[] arr = new object[4]; Line 2) arr[0] = arr;
arr [0]现在是arr的另一个别名,arr和arr [0]都具有相同的值,即数组数据的地址.@H_301_5@
内存状态可以是例如如下:@H_301_5@
第1行之后:@H_301_5@
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
第2行之后:@H_301_5@
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