以前常常会遇到将java中的两个数组合并成一个的需求,解决办法很傻瓜, 创建一个新的数组,用for语句把两个数组中的item都拷贝到新的中。
这样不仅性能不好,而且代码很丑。
今天在看HttpServlet的源码时,看到这么一段:
我试图去查看System.arraycopy这个方法的源码,却发现是一个native方法,也就是根据系统来实现的底层代码。
根据一贯的想法,底层代码实现的方法通常都比较快。 所以我认为这个方法还是非常适合被加入程序员的工具库里面的。
这样不仅性能不好,而且代码很丑。
今天在看HttpServlet的源码时,看到这么一段:
Method[] parentMethods = getAllDeclaredMethods(c.getSuperclass());
Method[] thisMethods = c.getDeclaredMethods();
if ((parentMethods != null) && (parentMethods.length > 0)) {
Method[] allMethods =
new Method[parentMethods.length + thisMethods.length];
System.arraycopy(parentMethods, 0, allMethods, 0,
parentMethods.length);
System.arraycopy(thisMethods, 0, allMethods, parentMethods.length,
thisMethods.length);
thisMethods = allMethods;
我试图去查看System.arraycopy这个方法的源码,却发现是一个native方法,也就是根据系统来实现的底层代码。
根据一贯的想法,底层代码实现的方法通常都比较快。 所以我认为这个方法还是非常适合被加入程序员的工具库里面的。