`
LanderRooter
  • 浏览: 11473 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
最近访客 更多访客>>
社区版块
存档分类
最新评论

Collection的<T> T[] toArray(T[] a) 性能优化

阅读更多

最近在使用PMD进行代码缺陷扫描时,有一类问题PMD称为"call to Collection.toArray() may be optimizable"

下面一行为问题代码:

 

result = (IResearch[]) list.toArray(new IResearch[0]);

 

PMD对这类问题给出的解决方案如下:

 

class Foo {
 void bar(Collection x) {
   // A bit inefficient
   x.toArray(new Foo[0]);
   // Much better; this one sizes the destination array, avoiding
   // a reflection call in some Collection implementations
   x.toArray(new Foo[x.size()]);
 }
}

 

再看下ArrayList的<T> T[] toArray(T[] a) 源码:

public <T> T[] toArray(T[] a) {
        if (a.length < size)
            a = (T[])java.lang.reflect.Array.
		newInstance(a.getClass().getComponentType(), size);
	System.arraycopy(elementData, 0, a, 0, size);
        if (a.length > size)
            a[size] = null;
        return a;
    }

 

你就发现如果采用大家常用的把a的length设为0,就需要反射API来创建一个大小为size的数组,而这对性能有一定的影响.

 

所以最好的方式就是直接把a的length设为Collection的size从而避免调用反射API来达到一定的性能优化.

 

import java.util.ArrayList;

public class ToArrayTest {   

    public static void main(String[] args) {   
        ArrayList al = new ArrayList();   
        for (int i = 0; i < 10; i++) {   
            al.add(String.valueOf(i));   
        }   
        String[] s1 = (String[]) al.toArray(new String[15]);   
        for (int i = 0; i < s1.length; i++) {   
            System.out.println(i+","+s1[i]);   
        }   
        String[] s2 = (String[]) al.toArray(new String[5]);   
        for (int i = 0; i < s2.length; i++) {   
            System.out.println(i+","+s2[i]);   
        } 
        System.out.println("OptimizableToArrayCall");
        String[] s3 = (String[]) al.toArray(new String[al.size()]);   
        for (int i = 0; i < s3.length; i++) {   
            System.out.println(i+","+s3[i]);   
        } 
    }   
  
}  

 

 

 

分享到:
评论

相关推荐

    js模拟list和map

    Map&lt;br&gt;js文件为 js/utils.js&lt;br&gt;IE6.0 测试通过&lt;br&gt;&lt;br&gt;List:&lt;br&gt;add(var obj) //添加一个元素&lt;br&gt;remove(var index) //删除一个元素&lt;br&gt;get(var index) //获取一个元素&lt;br&gt;removeAll() //删除所有元素&lt;br&gt;toArray...

    C#中List和数组之间转换的方法

    List&lt;string&gt; listS=new List&lt;string&gt;(); listS.Add(str); listS.Add(hello); string[] str=listS.ToArray(); 二、数组转List (从string[]转到List&lt;string&gt;) string[] str={str,string,abc}; List&lt;string&gt; listS=...

    ICTC-6

    &lt;br&gt;&lt;br&gt;&lt;br&gt;&lt;br&gt;(图一)&lt;br&gt;&lt;br&gt;根据上篇文章内容,该图该可以等价于如下的二维表格表示:&lt;br&gt;&lt;br&gt;&lt;br&gt;&lt;br&gt;(图二)&lt;br&gt;&lt;br&gt;而对应于该表格的是一个ColumnFirstDynamicArray,共有10个结点,每个结点的取值如下表...

    asp 完全教程

    下面的代码从VBScript数组myVBArray创建JScript数组myJSArray: &lt;br&gt; var Temp = new VBArray(myVBArray)&lt;br&gt; var myJSArray&lt;br&gt; myJSArray = Temp.toArray()&lt;br&gt; 上述代码首先创建一个临时的VBArray对象,然后...

    Linq基础学习资料,通俗易懂

    4.3 System.Linq.Lookup &lt;TKey,TElement&gt; 10 4.4 System.Linq.Expressions.Expression 10 5 接口 10 5.1 IEnumerable 、IEnumerator 10 5.1.1 正常使用 10 5.1.2 C#的 yield 12 5.2 IEnumerable &lt;T&gt; 12 5.3 ...

    Jayrock(json字符串解析)

    public static string JsonSerializer&lt;T&gt;(T t) { DataContractJsonSerializer ser = new DataContractJsonSerializer(typeof(T)); MemoryStream ms = new MemoryStream(); ser.WriteObject(ms, t); string json...

    springmvc-jdbcTemplate

    return new DataStore&lt;Map&lt;String, Object&gt;&gt;(records, new ArrayList&lt;Map&lt;String, Object&gt;&gt;()); } return new DataStore&lt;Map&lt;String, Object&gt;&gt;(records, search(pagingSqlBuilder.getPagingSql(sql, ...

    教你如何设置动态下拉框

    List&lt;SelectItem&gt; tempLists = new ArrayList&lt;SelectItem&gt;(); for (CItemType initComboo : initComboos) { tempLists.add(new SelectItem(initComboo.getItemTypeNum(),initComboo.getItemTypeName())); }...

    对接openai接口,采用现有的开源前端实现ai对话(Java)

    AbstractSecurityInterceptor 中Collection&lt;ConfigAttribute&gt; attributes = this.obtainSecurityMetadataSource().getAttributes(object); //调用这个方法比较 DefaultFilterInvocationSecurityMetadataSource get...

    C#中压缩字符串

    /// &lt;param name="param"&gt;&lt;/param&gt; /// &lt;returns&gt;&lt;/returns&gt; public static string IC_Compress(string param) { byte[] data = System.Text.Encoding.UTF8.GetBytes(param); //byte[] data = Convert....

    TextBox拼音检索(textBox重新封装)源码

    List&lt;string&gt; list = new List&lt;string&gt;(); foreach (DataRow dr in dt.Rows) { if (!Convert.IsDBNull(dr["XlMc"])) list.Add(dr["XlMc"].ToString()); } return list.ToArray(); } 4,数据源绑定: ...

    asp.net 通用包

    /// &lt;param name="decryptKey"&gt;解密密钥,要求为8位,和加密密钥相同&lt;/param&gt; /// &lt;returns&gt;解密成功返回解密后的字符串,失败返源串&lt;/returns&gt; public static string Decode(string decryptString, string ...

    C#查找列表中所有重复出现元素的方法

    List&lt;T&gt; duplicates = new List&lt;T&gt;( ); for (int i = 0; i &lt; this.Count; i++) { if (this[i].Equals(inputValue)) { duplicates.Add(this[i]); } } return (duplicates.ToArray( )); } 希望本文所述对...

    生成二维码应用程序

    /// &lt;returns&gt;&lt;/returns&gt; public byte[] CreateQRcode(string UserName) { QRCodeEncoder qrCodeEncoder = new QRCodeEncoder(); qrCodeEncoder.QRCodeEncodeMode = QRCodeEncoder.ENCODE_MODE.BYTE; ...

    C# id in.pdf

    List&lt;string&gt; ids = new List&lt;string&gt;(); for (int i = 0; i &lt; this.myDataGrid_d.Items.Count; i++) { if (((CheckBox)myDataGrid_d.Items[i].FindControl("cb_choice")).Checked) { DataGridItem item = ...

    +Flex+集成到+Java+EE+应用程序的最佳实践(完整源代码)

    &lt;source&gt;org.expressme.employee.mgmt.flex.FlexServiceImpl&lt;/source&gt; &lt;scope&gt;application&lt;/scope&gt; &lt;/properties&gt; &lt;/destination&gt; 服务名称通过 destination 的 id 属性指定,Flex 前端通过该服务名称来...

    将 Flex 集成到 Java EE 应用程序的最佳实践(完整源代码)

    &lt;source&gt;org.expressme.employee.mgmt.flex.FlexServiceImpl&lt;/source&gt; &lt;scope&gt;application&lt;/scope&gt; &lt;/properties&gt; &lt;/destination&gt; 服务名称通过 destination 的 id 属性指定,Flex 前端通过该服务名称来...

    zip4j_1.3.2 java代码压缩、解压文件

    ArrayList&lt;File&gt; temp = new ArrayList&lt;File&gt;(); Collections.addAll(temp, subFiles); zipFile.addFiles(temp, parameters); return dest; } zipFile.addFolder(srcFile, parameters); } else { zipFile....

    visual studio 2013 C# DES 加密解密 asp.net 完整 源码 下载

    // &lt;param name="decryptKey"&gt;解密密钥,要求为8位,和加密密钥相同&lt;/param&gt; // &lt;returns&gt;解密成功返回解密后的字符串,失败返源串&lt;/returns&gt; public static string DecryptDES(string decryptString, string ...

    move-position:使用onemultips数组移动元素

    function move &lt; T&gt; ( arr: T[] = [], movingMap: ArrayRange | ArrayRange[], Opts &lt; T&gt; = { } ) ArrayRange对象包含: from: number -目标索引。 to: number -目标索引。 Opts对象包含: isMutate?: ...

Global site tag (gtag.js) - Google Analytics