java代码测试集合,数组等最大存储大小
2011-11-21 19:00
459 查看
其实java里面的集合,数组等他们的存储容量我们是可以预估的。1、存储原始类型,这种存储大小是固定的。2、存储对象,由于内容大小有变化,但是我们可以通过测试获取到大慨存储容量。
还有就是我们扩容内存,会影响集合或数组存储大小。
1、List<Integer>
int judgeListmaxCount = 0;
try {
for (int i = 0; i <= 50000000; i++) {
judgeListmaxCount = i;
dataList.add(i);
}
} catch (Exception e) {
System.out.println("judgeListmaxCount:" + judgeListmaxCount);
} finally {
System.out.println("judgeListmaxCount:" + judgeListmaxCount);
}
异常消息:
Exception in thread "main" judgeListmaxCount:38647475
java.lang.OutOfMemoryError: Java heap space
at java.util.ArrayList.ensureCapacity(ArrayList.java:169)
at java.util.ArrayList.add(ArrayList.java:351)
at com.yxie.test.CreateDichotoSearchData.main(CreateDichotoSearchData.java:21)
xieyun@xieyun-OptiPlex-760:~/work/dichotomy/bin$ java -Xms1024m -Xmx1024m com.yxie.test.CreateDichotoSearchData
judgeListmaxCount:38647475
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at java.util.Arrays.copyOf(Arrays.java:2760)
at java.util.Arrays.copyOf(Arrays.java:2734)
at java.util.ArrayList.ensureCapacity(ArrayList.java:167)
at java.util.ArrayList.add(ArrayList.java:351)
at com.yxie.test.CreateDichotoSearchData.main(CreateDichotoSearchData.java:21)
2、int[]
int intSize = 0;
try {
for (int i = 191059999; i <= 191160000; i++) {
intSize = i;
int[] allInt = new int[i];
System.out.println("allInt:" + allInt.length);
}
} catch (Exception e) {
} finally {
System.out.println("intSize:" + intSize);
}
异常消息:
intSize:191060000
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at com.yxie.test.CreateDichotoSearchData.main(CreateDichotoSearchData.java:54)
改变java虚拟机内存大小,会影响int[]数组大小。
xieyun@xieyun-OptiPlex-760:~/work/dichotomy/bin$ java -Xms1024m -Xmx1024m com.yxie.test.CreateDichotoSearchData
Integer max:2147483647
fileSize:4000000000
spareFileSize:1852516353
intSize:191059999
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at com.yxie.test.CreateDichotoSearchData.main(CreateDichotoSearchData.java:54)
xieyun@xieyun-OptiPlex-760:~/work/dichotomy/bin$
xieyun@xieyun-OptiPlex-760:~/work/dichotomy/bin$ java -Xms2024m -Xmx2024m com.yxie.test.CreateDichotoSearchData
Integer max:2147483647
fileSize:4000000000
spareFileSize:1852516353
allInt:191059999
allInt:191060000
allInt:191060001
还有就是我们扩容内存,会影响集合或数组存储大小。
1、List<Integer>
int judgeListmaxCount = 0;
try {
for (int i = 0; i <= 50000000; i++) {
judgeListmaxCount = i;
dataList.add(i);
}
} catch (Exception e) {
System.out.println("judgeListmaxCount:" + judgeListmaxCount);
} finally {
System.out.println("judgeListmaxCount:" + judgeListmaxCount);
}
异常消息:
Exception in thread "main" judgeListmaxCount:38647475
java.lang.OutOfMemoryError: Java heap space
at java.util.ArrayList.ensureCapacity(ArrayList.java:169)
at java.util.ArrayList.add(ArrayList.java:351)
at com.yxie.test.CreateDichotoSearchData.main(CreateDichotoSearchData.java:21)
xieyun@xieyun-OptiPlex-760:~/work/dichotomy/bin$ java -Xms1024m -Xmx1024m com.yxie.test.CreateDichotoSearchData
judgeListmaxCount:38647475
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at java.util.Arrays.copyOf(Arrays.java:2760)
at java.util.Arrays.copyOf(Arrays.java:2734)
at java.util.ArrayList.ensureCapacity(ArrayList.java:167)
at java.util.ArrayList.add(ArrayList.java:351)
at com.yxie.test.CreateDichotoSearchData.main(CreateDichotoSearchData.java:21)
2、int[]
int intSize = 0;
try {
for (int i = 191059999; i <= 191160000; i++) {
intSize = i;
int[] allInt = new int[i];
System.out.println("allInt:" + allInt.length);
}
} catch (Exception e) {
} finally {
System.out.println("intSize:" + intSize);
}
异常消息:
intSize:191060000
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at com.yxie.test.CreateDichotoSearchData.main(CreateDichotoSearchData.java:54)
改变java虚拟机内存大小,会影响int[]数组大小。
xieyun@xieyun-OptiPlex-760:~/work/dichotomy/bin$ java -Xms1024m -Xmx1024m com.yxie.test.CreateDichotoSearchData
Integer max:2147483647
fileSize:4000000000
spareFileSize:1852516353
intSize:191059999
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space
at com.yxie.test.CreateDichotoSearchData.main(CreateDichotoSearchData.java:54)
xieyun@xieyun-OptiPlex-760:~/work/dichotomy/bin$
xieyun@xieyun-OptiPlex-760:~/work/dichotomy/bin$ java -Xms2024m -Xmx2024m com.yxie.test.CreateDichotoSearchData
Integer max:2147483647
fileSize:4000000000
spareFileSize:1852516353
allInt:191059999
allInt:191060000
allInt:191060001
相关文章推荐
- 遍历查找集合或者数组中的某个元素的值 java代码 详解 Android开发
- JAVA代码—算法基础:子数组的最大累加和问题
- Java 数组的最大长度 位图集合的最大长度
- 编写高质量代码:改善Java程序的151个建议(第5章:数组和集合___建议79~82)
- java代码数组求平均值,最大值,最小值
- java 实现BufferedImage和ImageReader两种方式获取图片宽高、判断图片类型、获取图片大小工具类代码以及测试响应结果
- 编写高质量代码:改善Java程序的151个建议(第5章:数组和集合___建议75~78)
- JAVA代码—算法基础:最大连续子数组乘积问题
- java实现最大堆及代码测试
- 算法导论书,page41,最大子数组,java代码实现
- 详解JAVA高质量代码之数组与集合
- 编写高质量代码:改善Java的151个建议七(数组和集合)60-82
- 获取字符串、数组、集合大小--Java
- Java编程数组中最大子矩阵简便解法实现代码
- 分享非常有用的Java程序 (关键代码)(四)---动态改变数组的大小
- java遍历整数list集合或者整数数组得到最大重复数字次数如果次数相同取较小的值
- [置顶] 遍历查找集合或者数组中的某个元素的值 java代码 详解 Android开发
- [置顶] Android java程序员必备技能,集合与数组中遍历元素,增强for循环的使用详解及代码
- java代码:双色球用数组和集合编写
- 【Core Java Volume 5】集合算法---查找数组、集合最大值的通用方法