java ArrayList 遍历比较

通过三种不同的方式遍历ArrayList,测试的结果时间相差比较大,三种遍历方式不管怎么调整顺序,第一种遍历的方式总是时间会多出很多,不知道为什么,求大神指点。

 public static void compare() {
        List<String> list = new ArrayList<String>();
        Set<String> set = new HashSet<String>();
        for(int i=0;i<100000;i++) {
            list.add("a"+i);
        }
        long t1=0L,t2=0L;

        ////two
        t1 = System.currentTimeMillis();
        for(int i=0; i<list.size(); i++) {
            set.add(list.get(i));
        }
        t2 = System.currentTimeMillis();
        System.out.println("size遍历的时间为:"+(t2-t1)+"mm");
        ////three
        t1 = System.currentTimeMillis();
        Iterator<String> iterator = list.iterator();
        while(iterator.hasNext()) {
            set.add((String)iterator.next());
        }
        t2 = System.currentTimeMillis();
        System.out.println("iterator遍历的时间为:"+(t2-t1)+"mm");
        ////one
        t1 = System.currentTimeMillis();
        for(String s : list) {
            set.add(s);
        }
        t2 = System.currentTimeMillis();
        System.out.println("forEach遍历的时间为:"+(t2-t1)+"mm");
    }

这是测试的时间:
size遍历的时间为:112mm
iterator遍历的时间为:20mm
forEach遍历的时间为:18mm

3个回答

无论第一种是one/two/three哪种,set都要判断保存list里的元素,而其它两种,只需判断set里面有没有这元素即可。
所以第一种的时间总是比其它两种的时间长。

Myc_CSDN
和Java狼狈为奸 soga.thanks
3 年多之前 回复

第一种方法时间最长的原因是由于每次循环都会执行一次list.size()方法
改进 int len=list.size()

for(int i=0;i<len;i++)时间就会和下面的方法持平

Myc_CSDN
和Java狼狈为奸 你没理解我的意思。如果把forEach遍历放在第一个进行遍历,那么forEach的时间就会变得最长。(ps:你有进行过测试吗?)
3 年多之前 回复

对于这种没有礼貌的人,见一次喷一次!别人最起码有回答你的问题,不管对或者错!最起码的尊重应该有吧

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
java iterator遍历的问题
定义了一个list, List l = new ArrayList(); 使用iterator遍历 Iterator it=l.iterator(); while (it.hasNext()) { System.out.println(it.next()); } 这样正常, 但是不把l.iterator赋给变量, while(l.iterator().hasNext()){ System.out.println(l.iterator().next()); } 这样就无限循环,为什么? 各位大神求赐教
java List里面放的很多map, map的key,value都不一样,如何遍历效率最高
java 有很多ArrayList,并且每个list里面放的很多map , 并且map的key,value都不一样,如何遍历获取每个list中想要的几个map,效率最高
java的ArrayList与print方法的问题
ArrayList arr = new ArrayList(); arr.add("aaa"); arr.add("bbb"); arr.add("ccc"); arr.add(10); System.out.println(arr); 为什么结果是:[aaa, bbb, ccc, 10] 我猜测:因为print遇到ArrayList类型时会自动遍历该集合,并且调用集合的tostring方法进行打印。这里面前三个元素是String类型,调用toString()方法后打印出字符串的值,而对于int类型,调用toString方法打印出int的值。(但是都是object类型,object的toString方法不应该这样啊。) 所以到底是什么原因?
list集合遍历采用的是ArrayList还是LinkList问题?
想问下,我返回一个linklist,用list接收后,我没有手动转换成ArrayList的情况下,继续拿着这个list去遍历,那么程序遍历的时候会采用哪种集合类型去遍历? ArrayList 还是 LinkList public List<MarkerInfoUtil> sort(List<MarkerInfoUtil> list) { LinkedList<MarkerInfoUtil> linkedList = new LinkedList<>(); linkedList.addAll(list); MarkerInfoUtil markerInfoUtil = null; for (int j = 0; j < linkedList.size(); j++) { if (linkedList.get(j).getMacid().equals(macId)) { markerInfoUtil = linkedList.get(j); linkedList.remove(); j--; } } linkedList.addLast(markerInfoUtil); return linkedList; //排序 List<MarkerInfoUtil> sort =sort(infos); for (MarkerInfoUtil info : sort) { }
java获取AD域用户信息 获取的信息只遍历出了1000条
java获取AD域用户信息 ,获取的信息只遍历出了1000条,想知道实在哪里被限制了吗,正常应该大于1000条 ``` SearchControls searchCtls = new SearchControls(); // Specify the search scope searchCtls.setSearchScope(SearchControls.SUBTREE_SCOPE); // specify the LDAP search filter String searchFilter = "objectclass=*"; // Specify the Base for the search 搜索域节点 String searchBase = "DC=wer,DC=com"; int totalResults = 0; String returnedAtts[] = { "objectGUID", "name", "userPrincipalName", "DisplayName", "Mail", "telephoneNumber", "FacsimileTelephoneNumber", "Title", "Department", "userAccountControl" }; // 定制返回属性 searchCtls.setReturningAttributes(returnedAtts); // 设置返回属性集 ArrayList<ArrayList<HashMap<String,String>>> dataList=new ArrayList<ArrayList<HashMap<String,String>>>(); try { NamingEnumeration answer = dc.search(searchBase, searchFilter,searchCtls); ArrayList<HashMap<String,String>> grouplist=new ArrayList<HashMap<String,String>>(); ArrayList<HashMap<String,String>> userlist=new ArrayList<HashMap<String,String>>(); if (answer == null || answer.equals(null)) { System.out.println("answer is null"); } else { System.out.println("answer not null"); } int a= 0; while (answer.hasMoreElements()) { a++; SearchResult sr = (SearchResult) answer.next(); System.out.println(sr.getName()); if(sr.getName().contains("OU=qwer")){//只检索带qwer的 if(sr.getName().indexOf("OU=") < 0) { continue; } // System.out.println("getname=" + sr.getName()); if(!sr.getName().contains("CN=")){//代表是用户组 //遍历节点及属性 grouplist.add(GroupTag(sr)); }else{//是用户 //遍历节点及属性 userlist.add(UserTag(sr)); } } } System.out.println("一共循环了 :"+a +"次"); `` 最后输出结果 一共循环了1000次,为什么是1000次呢?那个地方限制住了?求大神帮忙解答
java 两个for循环一个遍历list 一个遍历数组 只要输出list的内数据
``` public static void main(String[] args) { String s[]={"1","2","3","4"}; List<String> k = new ArrayList<String>(); k.add("1"); k.add("2"); k.add("3"); k.add("4"); k.add("5"); k.add("6"); for (String ss : k) { for (String d : s) { if(d.equals(ss)){ System.out.println("相同:"+ss); }else{ System.out.println("不相同:"+ss); } } } } ```
java编程, 遍历一个集合, 每个五个元素打印一遍, 不足五个打印全部
java编程, 已知有一个集合, 里面存放了十二个字符串元素, 现在遍历集合, 每个五个元素打印一遍, 不足五个打印全部. 请问如何解决? List<String> strings = new ArrayList<>(); strings.add("a"); strings.add("b"); strings.add("c"); strings.add("d"); strings.add("e"); strings.add("f"); strings.add("g"); strings.add("h"); strings.add("i"); strings.add("j"); strings.add("k"); strings.add("r"); strings.add("m"); strings.add("n");
Java ListIterator关于逆向迭代器的问题?
``` List list=new ArrayList(); list.add(new Student("list1",16)); list.add(new Studetn("list2",17)); ListIterator it=list.ListIterator(); //hasNext()返回的值 System.out.println(it.hasNext()); //正向遍历列表 while(it.hasNext()){ Student stu=(Student)it.next(); if(stu.getName().equals("list1")) it.add(new Student("list2",17)); System.out.println(stu); } /* it.add(new Student("list4"),19); System.out.println(it.hasPrevious()); */ //逆向遍历列表 while(it.hasPrevious){ Student stu=(Student)it.previous(); System.out.println(stu); } ``` 这段代码,运行结果为: ``` true Student [name=list1,age=16] Student [name=list2,age=17] Student [name=list3,age=18] //如果保留那段注释,程序到这里就结束了 //如果去掉注释,那么 true Student [name=list4,age=19] ``` 所以为什么正向迭代返回true,逆向需要再用迭代器add一次后才可以返回 true
java 多次嵌套数据,如何遍历获取到最内层的数据?
``` [ { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U00-U49 对新发生的不明原因疾病的或紧急情况的临时安排", "partnum":"22", "children":[ { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U04 严重急性呼吸道综合征[SARS]", "partnum":"22", "children":[ { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U04.9 未特指的严重急性呼吸道综合征", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U04.9", "icdPid":"119f028c-7938-11e9-9611-8cec4bd010f3", "icdName":"未特指的严重急性呼吸道综合征", "icdId":"119f0307-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 } ], "isParent":"false", "level":2, "icdCode":"U04", "icdPid":"69b8458e-8034-11e9-b519-8cec4bd010f3", "icdName":"严重急性呼吸道综合征[SARS]", "icdId":"119f028c-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":3 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U06 紧急使用U06", "partnum":"22", "children":[ { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U06.0 紧急使用U06.0", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U06.0", "icdPid":"119f0404-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U06.0", "icdId":"119f047b-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U06.1 紧急使用U06.1", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U06.1", "icdPid":"119f0404-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U06.1", "icdId":"119f04f6-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U06.2 紧急使用U06.2", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U06.2", "icdPid":"119f0404-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U06.2", "icdId":"119f056d-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U06.3 紧急使用U06.3", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U06.3", "icdPid":"119f0404-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U06.3", "icdId":"119f05ec-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U06.4 紧急使用U06.4", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U06.4", "icdPid":"119f0404-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U06.4", "icdId":"119f0671-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U06.5 紧急使用U06.5", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U06.5", "icdPid":"119f0404-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U06.5", "icdId":"119f06e5-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U06.6 紧急使用U06.6", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U06.6", "icdPid":"119f0404-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U06.6", "icdId":"119f075c-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U06.7 紧急使用U06.7", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U06.7", "icdPid":"119f0404-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U06.7", "icdId":"119f07db-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U06.8 紧急使用U06.8", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U06.8", "icdPid":"119f0404-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U06.8", "icdId":"119f0852-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U06.9 紧急使用U06.9", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U06.9", "icdPid":"119f0404-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U06.9", "icdId":"119f08cd-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 } ], "isParent":"false", "level":2, "icdCode":"U06", "icdPid":"69b8458e-8034-11e9-b519-8cec4bd010f3", "icdName":"紧急使用U06", "icdId":"119f0404-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":3 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U07 紧急使用U07", "partnum":"22", "children":[ { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U07.0 紧急使用U07.0", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U07.0", "icdPid":"119f09bf-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U07.0", "icdId":"119f0a3a-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U07.1 紧急使用U07.1", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U07.1", "icdPid":"119f09bf-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U07.1", "icdId":"119f0ab2-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U07.2 紧急使用U07.2", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U07.2", "icdPid":"119f09bf-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U07.2", "icdId":"119f0b2d-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U07.3 紧急使用U07.3", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U07.3", "icdPid":"119f09bf-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U07.3", "icdId":"119f0ba7-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U07.4 紧急使用U07.4", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U07.4", "icdPid":"119f09bf-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U07.4", "icdId":"119f0c22-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U07.5 紧急使用U07.5", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U07.5", "icdPid":"119f09bf-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U07.5", "icdId":"119f0c9a-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U07.6 紧急使用U07.6", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U07.6", "icdPid":"119f09bf-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U07.6", "icdId":"119f0d15-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U07.7 紧急使用U07.7", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U07.7", "icdPid":"119f09bf-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U07.7", "icdId":"119f0d90-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U07.8 紧急使用U07.8", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U07.8", "icdPid":"119f09bf-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U07.8", "icdId":"119f0e0a-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U07.9 紧急使用U07.9", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U07.9", "icdPid":"119f09bf-7938-11e9-9611-8cec4bd010f3", "icdName":"紧急使用U07.9", "icdId":"119f0e96-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 } ], "isParent":"false", "level":2, "icdCode":"U07", "icdPid":"69b8458e-8034-11e9-b519-8cec4bd010f3", "icdName":"紧急使用U07", "icdId":"119f09bf-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":3 } ], "isParent":"true", "level":1, "icdCode":"U00-U49", "icdPid":"f514142c-795f-11e9-9611-8cec4bd010f3", "icdName":"对新发生的不明原因疾病的或紧急情况的临时安排", "icdId":"69b8458e-8034-11e9-b519-8cec4bd010f3", "open":"false", "codelength":0 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U82-U85 对微生物和抗肿瘤药物产生的抗药性", "partnum":"22", "children":[ { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U82 对β-内酰胺类抗生素耐药", "partnum":"22", "children":[ { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U82.0 对青霉素耐药", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U82.0", "icdPid":"119f0f18-7938-11e9-9611-8cec4bd010f3", "icdName":"对青霉素耐药", "icdId":"119f0f93-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U82.1 对甲氧苯青霉素耐药", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U82.1", "icdPid":"119f0f18-7938-11e9-9611-8cec4bd010f3", "icdName":"对甲氧苯青霉素耐药", "icdId":"119f1178-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U82.2 对β-内酰胺(ESBL)类耐药", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U82.2", "icdPid":"119f0f18-7938-11e9-9611-8cec4bd010f3", "icdName":"对β-内酰胺(ESBL)类耐药", "icdId":"119f144b-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U82.8 对其他β-内酰胺类抗生素耐药", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U82.8", "icdPid":"119f0f18-7938-11e9-9611-8cec4bd010f3", "icdName":"对其他β-内酰胺类抗生素耐药", "icdId":"119f163e-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U82.9 对β-内酰胺类抗生素耐药,未特指", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U82.9", "icdPid":"119f0f18-7938-11e9-9611-8cec4bd010f3", "icdName":"对β-内酰胺类抗生素耐药,未特指", "icdId":"119f18a7-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 } ], "isParent":"false", "level":2, "icdCode":"U82", "icdPid":"69b852ad-8034-11e9-b519-8cec4bd010f3", "icdName":"对β-内酰胺类抗生素耐药", "icdId":"119f0f18-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":3 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U83 对其他抗生素耐药", "partnum":"22", "children":[ { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U83.0 对万古霉素耐药", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U83.0", "icdPid":"119f19a4-7938-11e9-9611-8cec4bd010f3", "icdName":"对万古霉素耐药", "icdId":"119f1a1c-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U83.1 对其他与万古霉素有关的抗生素耐药", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U83.1", "icdPid":"119f19a4-7938-11e9-9611-8cec4bd010f3", "icdName":"对其他与万古霉素有关的抗生素耐药", "icdId":"119f1b85-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U83.2 对喹诺酮耐药", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U83.2", "icdPid":"119f19a4-7938-11e9-9611-8cec4bd010f3", "icdName":"对喹诺酮耐药", "icdId":"119f1c74-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U83.7 对多种抗生素耐药", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U83.7", "icdPid":"119f19a4-7938-11e9-9611-8cec4bd010f3", "icdName":"对多种抗生素耐药", "icdId":"119f1d6d-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U83.8 对其他单一指定抗生素耐药", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U83.8", "icdPid":"119f19a4-7938-11e9-9611-8cec4bd010f3", "icdName":"对其他单一指定抗生素耐药", "icdId":"119f1e63-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U83.9 对未特指的抗生素耐药", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U83.9", "icdPid":"119f19a4-7938-11e9-9611-8cec4bd010f3", "icdName":"对未特指的抗生素耐药", "icdId":"119f1fef-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 } ], "isParent":"false", "level":2, "icdCode":"U83", "icdPid":"69b852ad-8034-11e9-b519-8cec4bd010f3", "icdName":"对其他抗生素耐药", "icdId":"119f19a4-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":3 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U84 对其他抗菌药耐药", "partnum":"22", "children":[ { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U84.0 对抗寄生虫药物耐药", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U84.0", "icdPid":"119f20ec-7938-11e9-9611-8cec4bd010f3", "icdName":"对抗寄生虫药物耐药", "icdId":"119f216a-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U84.1 对抗真菌药物耐药", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U84.1", "icdPid":"119f20ec-7938-11e9-9611-8cec4bd010f3", "icdName":"对抗真菌药物耐药", "icdId":"119f2259-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U84.2 对抗病毒药物耐药", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U84.2", "icdPid":"119f20ec-7938-11e9-9611-8cec4bd010f3", "icdName":"对抗病毒药物耐药", "icdId":"119f237f-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U84.3 抗结核病药物耐药", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U84.3", "icdPid":"119f20ec-7938-11e9-9611-8cec4bd010f3", "icdName":"抗结核病药物耐药", "icdId":"119f2471-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U84.7 对多种抗菌药物耐药", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U84.7", "icdPid":"119f20ec-7938-11e9-9611-8cec4bd010f3", "icdName":"对多种抗菌药物耐药", "icdId":"119f25ec-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U84.8 对其他特指抗菌药耐药", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U84.8", "icdPid":"119f20ec-7938-11e9-9611-8cec4bd010f3", "icdName":"对其他特指抗菌药耐药", "icdId":"119f2704-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U84.9 对未特指的抗菌药物耐药", "partnum":"22", "isParent":"true", "level":3, "icdCode":"U84.9", "icdPid":"119f20ec-7938-11e9-9611-8cec4bd010f3", "icdName":"对未特指的抗菌药物耐药", "icdId":"119f2801-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":5 } ], "isParent":"false", "level":2, "icdCode":"U84", "icdPid":"69b852ad-8034-11e9-b519-8cec4bd010f3", "icdName":"对其他抗菌药耐药", "icdId":"119f20ec-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":3 }, { "isclinical":-1, "isusing":1, "mid":"", "remark":"", "className":"U85 对抗肿瘤药物耐药", "partnum":"22", "isParent":"false", "level":2, "icdCode":"U85", "icdPid":"69b852ad-8034-11e9-b519-8cec4bd010f3", "icdName":"对抗肿瘤药物耐药", "icdId":"119f297f-7938-11e9-9611-8cec4bd010f3", "open":"false", "codelength":3 } ], "isParent":"true", "level":1, "icdCode":"U82-U85", "icdPid":"f514142c-795f-11e9-9611-8cec4bd010f3", "icdName":"对微生物和抗肿瘤药物产生的抗药性", "icdId":"69b852ad-8034-11e9-b519-8cec4bd010f3", "open":"false", "codelength":0 } ] ``` ![图片说明](https://img-ask.csdn.net/upload/201911/23/1574521364_679491.png) 如图,获取最内层的children节点下的值。 ``` public static List<Map<String, Object>> getLastChildren(List<Map<String, Object>> list,String key) { List<Map<String, Object>> lastChildrenList = new ArrayList<Map<String,Object>>(); for(int i=0;i<list.size();i++) { Map<String,Object> map = list.get(i); /*判断是否存在key*/ boolean containsKey = map.containsKey(key); /*如果存在则继续遍历*/ if(containsKey && map.get(key)!= null) { List<Map<String, Object>> childrenList = (List<Map<String, Object>>) map.get(key); getLastChildren(childrenList,key); }else {/*如果不存在则获取到key值 返回数据*/ lastChildrenList.add(map); } } return lastChildrenList; } ```
java循环 想在每个循环输出前加入不同字符串应该怎么搞
部分关键代码如下: List<String> line; String str; for(int i=0;i<strs.size();i++){ line = strs.get(i); for(int j=0;j<line.size();j++){ str = line.get(j); System.out.println(str);//遍历 } List<String> find_result = new ArrayList<>(); if (result) { matchTime++; for(int i=1; i <=m.groupCount(); i++){ find_result.add(m.group(i)); } strs.add(find_result); } return matchTime; ![图片说明](https://img-ask.csdn.net/upload/201809/21/1537516093_294644.png) 就是在每行前面加一个小标题
关于jsp用session传递list 在另一页面获取并遍历输出list
如题 ``` List<shuxing> list = new ArrayList<shuxing>(); shuxing s=new shuxing(); while(rs.next()){ s.setsShopName(rs.getString("sShopName")); s.setiNumbHj(rs.getString("iNumbHj")); s.setrMoneyHj(rs.getString("rMoneyHj")); list.add(s); } session.setAttribute("rs",list); response.sendRedirect("dian.jsp"); conn.close(); 获取 <c:forEach items="rs" var="user" > <c:out value="${user.sShopName}"/> </c:forEach> ``` 这样写报错HTTP Status 500 - type Exception report message description The server encountered an internal error () that prevented it from fulfilling this request. exception org.apache.jasper.JasperException: An exception occurred processing JSP page /dian.jsp at line 55 52: <!-- Codrops top bar --><!--/ Codrops top bar --> 53: <!-- <td><%Object q=session.getAttribute("rs"); %><%=q %></td>--> 54: <c:forEach items="rs" var="user" > 55: <c:out value="${user.sShopName}"/> 56: 57: </c:forEach> 58: </div> Stacktrace: org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:524) org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:435) org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:320) org.apache.jasper.servlet.JspServlet.service(JspServlet.java:266) javax.servlet.http.HttpServlet.service(HttpServlet.java:803)
new ArrayList<>(map.entrySet());
listArrayList《Map.Entry《Integer,Integer》》 entryList = new ArrayList《》(map.entrySet());这样写是将map转list吗?直接转了?不用遍历吗?
arraylist集合如何取zhi
![图片说明](https://img-ask.csdn.net/upload/201906/29/1561819485_411693.png) gid是商品编码 goods是商品类 里面有商品的价格 我想拿商品编码里的价格和goods类里的属性 价格 来做一个比较 然后得出结果再返回 所以想拿g.get到goods里面的值 苦于goods又被arraylist封装了 不知道该怎么下手了 我知道arraylist要得值的话需要遍历 然后用get(index)方法取值 但是 不知道往里传什么索引.. 一个arraylist搞不定 下面的重写方法就全GG 不知道是不是我思路错了
泛型集合的遍历,返回什么类型
import java.lang.reflect.Field; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.ResultSetMetaData; import java.sql.SQLException; import java.util.ArrayList; import java.util.List; import com.sun.org.apache.commons.beanutils.BeanUtils; public class DBOperateTUtilts { 方法1 public static <E> List<E> query(String sql, Class<E> clazz) { Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; Object tempStr = null; List<T> list = new ArrayList<T>(); try { conn = DBConnectUtils.getConnection(); pstmt = conn.prepareStatement(sql); rs = pstmt.executeQuery(); while (rs.next()) { // newInstance实际上是把new这个方式分解为两步,即,首先调用class的加载方法加载某个类,然后实例化。 // 我们可以在调用class的静态加载方法forName时获得更好的灵活性,提供给了我们降耦的手段。 // newInstance: 弱类型。低效率。只能调用无参构造。 // new: 强类型。相对高效。能调用任何public构造。 E obj = clazz.newInstance(); if (obj instanceof String) { // ResultSet的下标从1开始 obj = (E) rs.getString(1); } else { // Field 提供有关类或接口的单个字段的信息,以及对它的动态访问权限 // getDeclaredFields()返回Class中所有的字段,包括私有字段 // getFields 只返回公共字段,即有public修饰的字段 // field,域是一种属性,可以是一个类变量,一个对象变量,一个对象方法变量或者是一个函数的参数。 Field[] fields = obj.getClass().getDeclaredFields(); // 遍历域 for (Field field : fields) { try { // 反射获取对象成员的字段值 tempStr = rs.getObject(field.getName()); } catch (SQLException e) { tempStr = ""; } // 置是否允许访问,而不是修改原来的访问权限修饰词 field.setAccessible(true); // 把对象的属性数据封装到对象中 BeanUtils.setProperty(obj, field.getName(), tempStr); } } list.add(obj); } } catch (Exception e) { e.printStackTrace(); throw new RuntimeException(e); } finally { DBCloseUtils.closeCSR(conn, pstmt, rs); } return list; } 方法2 public static <T> List<T> query(String sql, Class<T> clazz, Object[] parameters) { Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; ResultSetMetaData metaData = null; List<T> list = new ArrayList<T>(); int index = 1; try { pstmt = conn.prepareStatement(sql); } catch (SQLException e) { e.printStackTrace(); } if (parameters != null && parameters.length != 0) { for (int i = 0; i < parameters.length; i++) { try { // pstmt.setObject(第几个参数, 替换成什么); pstmt.setObject(index, parameters[i]); } catch (SQLException e) { e.printStackTrace(); } } } try { rs = pstmt.executeQuery(sql); } catch (SQLException e) { e.printStackTrace(); } // 封装resultset try { metaData = rs.getMetaData(); } catch (SQLException e) { e.printStackTrace(); }// 取出列的信息 int columnLength = 0; try { columnLength = metaData.getColumnCount(); } catch (SQLException e) { e.printStackTrace(); }// 获取列数 try { while (rs.next()) { // 通过反射机制创建一个对象 T result = clazz.newInstance(); for (int i = 0; i < columnLength; i++) { String metaDataKey = metaData.getColumnName(i + 1); Object resultsetValue = rs.getObject(metaDataKey); if (resultsetValue == null) { resultsetValue = ""; } Field field = clazz.getDeclaredField(metaDataKey); field.setAccessible(true); field.set(result, resultsetValue); } list.add(result); } } catch (Exception e) { e.printStackTrace(); throw new RuntimeException(e); } return list; } }
利用递归方法遍历文件存储到指定文件,为何不能遍历尽所有的指定文件?源码如下:
import java.io.*; import java.util.*; class FileDemo { public static void main(String[] args) { File dir=new File("D:"); //showDir(dir,0); //sop(getSum(10)); //delFile(dir); List<File> list=new ArrayList<File>(); fileToList(dir,list); File file=new File(dir,"java文件列表.txt"); writeToFile(list,file.toString()); } public static void writeToFile(List<File> list,String javaListFile){//创建文件写入输出流,将集合内文件的据对路径储到指定文件 BufferedWriter bw=null; try{ bw=new BufferedWriter(new FileWriter(javaListFile)); for(File file:list){ String path=file.getAbsolutePath(); bw.write(path); bw.newLine(); bw.flush(); } } catch(IOException e){ throw new RuntimeException("写入文件失败"); } finally{ try{ if(bw!=null) bw.close(); } catch(IOException ex){ throw new RuntimeException("流文件不存在"); } } } public static void fileToList(File dir,List<File> list){//遍历目录,将指定文件存入到参数集合中 File[] files=dir.listFiles(); for(File file:files){ if(file.isDirectory()) fileToList(file,list); else{ if(file.getName().endsWith(".java")) list.add(file); } } } }
java poi导出excel文档 后台报下标越界 但文档正常导出且损坏
public static SXSSFWorkbook createCSVUtil2(int startRow, String sheetName, SXSSFWorkbook wb, Map<String, List<CellModel>> cellListMap, Integer cellRowNum, List<LinkedHashMap> exportData, int[] columnWidth, int totalcolumn, GgreportingtemplateDto ggreportingtemplateDto, int countRow) throws Exception { // 设置表格名称 SXSSFSheet sheet = (SXSSFSheet) wb.createSheet(sheetName); sheet.trackAllColumnsForAutoSizing(); // 设置表格标题 一般都是第一行第一个格子 // 标题样式 if (ggreportingtemplateDto.getTitle() != null) { XSSFCellStyle cellStyleTitle = (XSSFCellStyle) wb.createCellStyle(); cellStyleTitle.setWrapText(true); SXSSFRow rowTitle = (SXSSFRow) sheet.createRow(0); XSSFFont fontTitle = (XSSFFont) wb.createFont(); fontTitle.setFontHeightInPoints((short) 16); cellStyleTitle.setFont(fontTitle); // 合并标题单元格 sheet.addMergedRegion(new CellRangeAddress(0, 0, 0, totalcolumn - 1)); for (int i = 0; i < totalcolumn; i++) { if (i == 0) { SXSSFCell cell = (SXSSFCell) rowTitle.createCell(0); cell.setCellValue(ggreportingtemplateDto.getTitle()); cell.setCellStyle(cellStyleTitle); } else { SXSSFCell cell = (SXSSFCell) rowTitle.createCell(i); cell.setCellStyle(cellStyleTitle); } } } if (ggreportingtemplateDto.getCondition() != null) { // 设置筛选条件格子 一般是第二行第一列 // 条件样式 XSSFCellStyle cellStyleCondition = (XSSFCellStyle) wb.createCellStyle(); cellStyleCondition.setWrapText(true); SXSSFRow rowCondition = (SXSSFRow) sheet.createRow(1); XSSFFont fontCondition = (XSSFFont) wb.createFont(); fontCondition.setFontHeightInPoints((short) 16); cellStyleCondition.setFont(fontCondition); // 合并条件单元格 sheet.addMergedRegion(new CellRangeAddress(1, 1, 0, 4)); for (int i = 0; i < 4; i++) { if (i == 0) { SXSSFCell cell = (SXSSFCell) rowCondition.createCell(0); cell.setCellValue(ggreportingtemplateDto.getCondition()); cell.setCellStyle(cellStyleCondition); } else { SXSSFCell cell = (SXSSFCell) rowCondition.createCell(i); cell.setCellStyle(cellStyleCondition); } } } // 设置表格通用样式 XSSFCellStyle cellStyle = (XSSFCellStyle) wb.createCellStyle(); // 设置边框 // 设置单元格内容水平对齐 cellStyle.setAlignment(XSSFCellStyle.ALIGN_CENTER); // 设置单元格内容垂直对齐 cellStyle.setVerticalAlignment(XSSFCellStyle.VERTICAL_CENTER); // 设置自动换行 cellStyle.setWrapText(true); // 设置双边框 XSSFCellStyle cellStyleDouble = (XSSFCellStyle) wb.createCellStyle(); // 设置边框 // 设置单元格内容水平对齐 cellStyleDouble.setAlignment(XSSFCellStyle.ALIGN_CENTER); // 设置单元格内容垂直对齐 cellStyleDouble.setVerticalAlignment(XSSFCellStyle.VERTICAL_CENTER); // 设置自动换行 cellStyleDouble.setWrapText(true); // 合并单元格 for (int t = 0; t < cellRowNum; t++) { SXSSFRow row = (SXSSFRow) sheet.createRow(t + startRow); List<CellModel> cellNameList = cellListMap.get(String.valueOf(t)); for (CellModel cellModel : cellNameList) { // 如果被合并的元素只占用了一个单元格则不进行合并 if (cellModel.getStartColumn() == cellModel.getEndColumn() && cellModel.getEndRow() == cellModel.getStartRow()) { continue; } sheet.addMergedRegion(new CellRangeAddress(cellModel.getStartRow(), cellModel.getEndRow(), cellModel.getStartColumn(), cellModel.getEndColumn())); } // create的cell Set<Integer> create = new HashSet<Integer>(); for (int i = 0; i < cellNameList.size(); i++) { CellModel cellModel = cellNameList.get(i); // 遍历插入表头 SXSSFCell cell = (SXSSFCell) row.createCell(cellModel.getStartColumn()); // 设置字体 XSSFFont font = (XSSFFont) wb.createFont(); font.setFontName("Times New Roman"); font.setFontHeightInPoints((short) 8); // 设置行高 if (i == 1) { row.setHeight((short) 500); } cellStyle.setFont(font); cell.setCellValue(cellModel.getCellName()); cell.setCellStyle(cellStyle); create.add(cellModel.getStartColumn()); } // 把所有没有create的cell都create for (int i = 0; i < totalcolumn; i++) { if (!(create.contains(i))) { // 设置字体 XSSFFont font = (XSSFFont) wb.createFont(); font.setFontName("Times New Roman"); font.setFontHeightInPoints((short) 8); cellStyle.setFont(font); SXSSFCell cell = (SXSSFCell) row.createCell(i); cell.setCellStyle(cellStyle); } } } for (LinkedHashMap hashMap : exportData) { SXSSFRow rowValue = (SXSSFRow) sheet.createRow(cellRowNum + startRow); Iterator<Map.Entry> iteratorRow = hashMap.entrySet().iterator(); while (iteratorRow.hasNext()) { Map.Entry entryRow = iteratorRow.next(); Integer key = Integer.valueOf(entryRow.getKey().toString()); String value = ""; if (entryRow.getValue() != null) { value = entryRow.getValue().toString(); } else { value = ""; } SXSSFCell cellValue = (SXSSFCell) rowValue.createCell(key - 1); // 设置字体 XSSFFont font = (XSSFFont) wb.createFont(); font.setFontName("Times New Roman"); font.setFontHeightInPoints((short) 8); cellValue.setCellValue(value); cellStyle.setFont(font); cellValue.setCellStyle(cellStyle); } cellRowNum++; } // 设置备注栏 List<String> reMarkList = ggreportingtemplateDto.getRemake(); if (reMarkList != null) { for (int i = 0; i < reMarkList.size() + 1; i++) { int rowNum = i + startRow + cellRowNum + 1; XSSFCellStyle cellStyleRemake = (XSSFCellStyle) wb.createCellStyle(); SXSSFRow rowRemake = (SXSSFRow) sheet.createRow(rowNum); XSSFFont fontRemake = (XSSFFont) wb.createFont(); fontRemake.setFontHeightInPoints((short) 8); cellStyleRemake.setFont(fontRemake); String cellValue = "Notes:"; // 合并条件单元格 if (i != 0) { sheet.addMergedRegion(new CellRangeAddress(rowNum, rowNum, 0, 4)); cellValue = reMarkList.get(i - 1); SXSSFCell cell = (SXSSFCell) rowRemake.createCell(0); cell.setCellValue(cellValue); cell.setCellStyle(cellStyleRemake); } else { SXSSFCell cell = (SXSSFCell) rowRemake.createCell(0); cell.setCellValue(cellValue); cell.setCellStyle(cellStyleRemake); } } } // 设置列宽 if (columnWidth != null) { for (int i = 0; i < columnWidth.length; i++) { sheet.setColumnWidth(i, columnWidth[i]); } } return wb; } 以上是我生成sheet表的内容 //exceptional Rpt public SXSSFWorkbook exceptionalRpt (GgreportingtemplateDto ggreportingtemplateDto, String startInputDate,String endInputDate) throws Exception { // 设置最大数据行数 SXSSFWorkbook wb = new SXSSFWorkbook(5050);//这里之前看到是说能设置这个表格最多能含有多少数据 Map<String, List<CellModel>> map = new HashMap<String, List<CellModel>>(); // 设置数据 // 第一级表头 List<CellModel> firstRow = new ArrayList<CellModel>(); CellModel cellModel1 = new CellModel(); // 总占用1行 Integer cellRow = 1; cellModel1.setCellName("Member English Name"); cellModel1.setStartRow(0); cellModel1.setEndRow(0); cellModel1.setStartColumn(0); cellModel1.setEndColumn(0); CellModel cellModel2 = new CellModel(); cellModel2.setCellName("Member Chinese Name"); cellModel2.setStartRow(0); cellModel2.setEndRow(0); cellModel2.setStartColumn(1); cellModel2.setEndColumn(1); CellModel cellModel3 = new CellModel(); cellModel3.setCellName("Staff No."); cellModel3.setStartRow(0); cellModel3.setEndRow(0); cellModel3.setStartColumn(2); cellModel3.setEndColumn(2); CellModel cellModel4 = new CellModel(); cellModel4.setCellName("HKID/Passport No."); cellModel4.setStartRow(0); cellModel4.setEndRow(0); cellModel4.setStartColumn(3); cellModel4.setEndColumn(3); CellModel cellModel5 = new CellModel(); cellModel5.setCellName("Sex"); cellModel5.setStartRow(0); cellModel5.setEndRow(0); cellModel5.setStartColumn(4); cellModel5.setEndColumn(4); CellModel cellModel6 = new CellModel(); cellModel6.setCellName("Plan Code"); cellModel6.setStartRow(0); cellModel6.setEndRow(0); cellModel6.setStartColumn(5); cellModel6.setEndColumn(5); CellModel cellModel7 = new CellModel(); cellModel7.setCellName("Plan Description"); cellModel7.setStartRow(0); cellModel7.setEndRow(0); cellModel7.setStartColumn(6); cellModel7.setEndColumn(6); CellModel cellModel8 = new CellModel(); cellModel8.setCellName("Effective Date"); cellModel8.setStartRow(0); cellModel8.setEndRow(0); cellModel8.setStartColumn(7); cellModel8.setEndColumn(7); CellModel cellModel9 = new CellModel(); cellModel9.setCellName("Status"); cellModel9.setStartRow(0); cellModel9.setEndRow(0); cellModel9.setStartColumn(8); cellModel9.setEndColumn(8); firstRow.add(cellModel1); firstRow.add(cellModel2); firstRow.add(cellModel3); firstRow.add(cellModel4); firstRow.add(cellModel5); firstRow.add(cellModel6); firstRow.add(cellModel7); firstRow.add(cellModel8); firstRow.add(cellModel9); map.put("0", firstRow); // 业务数据 List<LinkedHashMap> exportData = new ArrayList<LinkedHashMap>(); GuPolicyCopyItemMedgMembDto guPolicyCopyItemMedgMembDto = new GuPolicyCopyItemMedgMembDto(); List<GuPolicyCopyItemMedgMembDto> list = ServiceManager.prpall.getGuPolicyCopyItemMedgMembService().findALL(guPolicyCopyItemMedgMembDto, null);//这里查询出来是295条 //增加数据 用这端代码增加5000条数据 /*for (int i = 0; i < 5000; i++) { list.add((GuPolicyCopyItemMedgMembDto)list.get(0)); }*/ int countRow = 0; for (int i = 0; i < list.size(); i++) { GuPolicyCopyItemMedgMembDto data = (GuPolicyCopyItemMedgMembDto) list.get(i); LinkedHashMap<String,String> row = new LinkedHashMap<String,String>(); String struts = ""; String ename = ""; String cname = ""; String idno = ""; String staffno = ""; String sex = ""; String rationType = ""; String rationName = ""; String entryDate = ""; String chineseName = ""; String hKIDandPassportNo = ""; if(data.getFlag()==null||data.getFlag().equals("I")) { struts = "Add"; }else if(data.getFlag().equals("U")){ struts = "Amendment"; }else if(data.getFlag().equals("D")){ struts = "Deletion"; }else if(data.getFlag().equals("B")){ struts = "Cancellation"; } if(data.getClientEName() != null&&!(data.getClientEName().equals(""))) { ename = data.getClientEName(); } if(data.getClientCName() != null&&!(data.getClientCName().equals(""))) { cname = data.getClientCName(); } if(data.getIdNo() != null&&!(data.getIdNo().equals(""))) { idno = data.getIdNo(); } if(data.getStaffNo() != null&&!(data.getStaffNo().equals(""))) { staffno = data.getStaffNo(); } if(data.getSex() != null&&!(data.getSex().equals(""))) { sex = data.getSex(); } if(data.getRationType() != null&&!(data.getRationType().equals(""))) { rationType = data.getRationType(); } if(data.getRationName() != null&&!(data.getRationName().equals(""))) { rationName = data.getRationName(); } if(data.getEntryDate() != null) { entryDate = sim.format(data.getEntryDate()); } /*row.put("1", ""+ename+""); row.put("2", ""+cname+""); row.put("3", ""+staffno+""); row.put("4", ""+idno+""); row.put("5", ""+sex+""); row.put("6", ""+rationType+""); row.put("7", ""+rationName+""); row.put("8", ""+entryDate+""); row.put("9", ""+struts+"");*/ row.put("1", "1"); row.put("2", "2"); row.put("3", "3"); row.put("4", "4"); row.put("5", "5"); row.put("6", "6"); row.put("7", "7"); row.put("8", "8"); row.put("9", "9"); exportData.add(row); countRow++; } // 用于写入文件 // 列宽数组 int[] columnWidth = { 10000, 7500, 5000, 7500, 5000, 7500, 10000, 5000, 5000 }; // 报表标题 ggreportingtemplateDto.setTitle(null); List<String> remakeList = null; // 报表备注 ggreportingtemplateDto.setRemake(remakeList); ggreportingtemplateDto.setCondition(null); //数据分页 if(exportData.size()>5000) { double size = exportData.size(); double divisor = size/5000; int forNumber = (new Double(Math.ceil(divisor))).intValue(); for (int i = 0; i < forNumber; i++) { if((i+1)==forNumber) { List<LinkedHashMap> exportDataTemp = exportData.subList(0+(i*5000), exportData.size()-1); wb = this.createCSVUtil2(0, "Exceptional Rpt"+(i+1), wb, map, cellRow, exportDataTemp, columnWidth, columnWidth.length, ggreportingtemplateDto, 0); }else { List<LinkedHashMap> exportDataTemp = exportData.subList(0+(i*5000), 5000+(i*5000 )); wb = this.createCSVUtil2(0, "Exceptional Rpt"+(i+1), wb, map, cellRow, exportDataTemp, columnWidth, columnWidth.length, ggreportingtemplateDto, 0); } } }else { wb = this.createCSVUtil2(0, "Exceptional Rpt", wb, map, cellRow, exportData, columnWidth, columnWidth.length, ggreportingtemplateDto, 0); } /*wb = this.createCSVUtil2(0, "Exceptional Rpt", wb, map, cellRow, exportData, columnWidth, columnWidth.length, ggreportingtemplateDto, 0);*/ return wb; } 一开始SXSSFWorkbook wb = new SXSSFWorkbook(5050)这里的值给的5000 ,然后当数据量大于5000时直接报错,文件不能正常导出,然后我把5000改成7000,会报错但是文件能导出,是损坏文件,一条数据都没有,后来修改成分页导出,自己测试的时候任然报了数组下标越界,且越界的下标为负值,文件能正常导出,但导出的文件显示已损坏,看不到数据。报错代码图片以上传,求大神解答,解答有效我微信转账请大神喝奶茶 java.lang.ArrayIndexOutOfBoundsException: -20527 at java.util.ArrayList.elementData(ArrayList.java:418) at java.util.ArrayList.get(ArrayList.java:431) at org.apache.poi.xssf.model.StylesTable.getFontAt(StylesTable.java:386) at org.apache.poi.xssf.usermodel.XSSFWorkbook.getFontAt(XSSFWorkbook.java:954) at org.apache.poi.xssf.streaming.SXSSFWorkbook.getFontAt(SXSSFWorkbook.java:857) at org.apache.poi.ss.util.SheetUtil.getCellWidth(SheetUtil.java:148) at org.apache.poi.xssf.streaming.AutoSizeColumnTracker.updateColumnWidth(AutoSizeColumnTracker.java:367) at org.apache.poi.xssf.streaming.AutoSizeColumnTracker.updateColumnWidths(AutoSizeColumnTracker.java:333) at org.apache.poi.xssf.streaming.SXSSFSheet.flushOneRow(SXSSFSheet.java:1892) at org.apache.poi.xssf.streaming.SXSSFSheet.flushRows(SXSSFSheet.java:1871) at org.apache.poi.xssf.streaming.SXSSFSheet.flushRows(SXSSFSheet.java:1882) at org.apache.poi.xssf.streaming.SXSSFWorkbook.write(SXSSFWorkbook.java:931) at com.sinosoft.application.platform.web.action.GgReportingTemplateAction.download(GgReportingTemplateAction.java:267) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:498) at com.sinosoft.application.common.BaseProcessAction.execute(BaseProcessAction.java:213) at org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:216) at org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:117) at org.apache.struts.action.ActionServlet.process(ActionServlet.java:1196) at org.apache.struts.action.ActionServlet.doPost(ActionServlet.java:432) at javax.servlet.http.HttpServlet.service(HttpServlet.java:661) at javax.servlet.http.HttpServlet.service(HttpServlet.java:742) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at net.bull.javamelody.MonitoringFilter.doFilter(MonitoringFilter.java:198) at net.bull.javamelody.MonitoringFilter.doFilter(MonitoringFilter.java:176) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:265) at org.acegisecurity.intercept.web.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:107) at org.acegisecurity.intercept.web.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:72) at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:275) at org.acegisecurity.ui.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:124) at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:275) at org.acegisecurity.providers.anonymous.AnonymousProcessingFilter.doFilter(AnonymousProcessingFilter.java:125) at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:275) at org.acegisecurity.ui.rememberme.RememberMeProcessingFilter.doFilter(RememberMeProcessingFilter.java:142) at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:275) at org.acegisecurity.wrapper.SecurityContextHolderAwareRequestFilter.doFilter(SecurityContextHolderAwareRequestFilter.java:81) at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:275) at org.acegisecurity.ui.AbstractProcessingFilter.doFilter(AbstractProcessingFilter.java:271) at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:275) at org.acegisecurity.ui.logout.LogoutFilter.doFilter(LogoutFilter.java:110) at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:275) at org.acegisecurity.context.HttpSessionContextIntegrationFilter.doFilter(HttpSessionContextIntegrationFilter.java:249) at org.acegisecurity.util.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:275) at org.acegisecurity.util.FilterChainProxy.doFilter(FilterChainProxy.java:149) at org.acegisecurity.util.FilterToBeanProxy.doFilter(FilterToBeanProxy.java:98) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at com.sinosoft.application.common.CAS_LANGUATE.doFilter(CAS_LANGUATE.java:35) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at com.sinosoft.sysframework.web.control.SetCharacterEncodingFilter.doFilter(SetCharacterEncodingFilter.java:99) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at com.sinosoft.application.common.CompatibleFilter.doFilter(CompatibleFilter.java:29) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at com.sinosoft.application.common.ValidateSalt.doFilter(ValidateSalt.java:56) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at net.bull.javamelody.MonitoringFilter.doFilter(MonitoringFilter.java:160) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at com.sinosoft.application.common.LoadSalt.doFilter(LoadSalt.java:41) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:199) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96) at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:493) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:137) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:81) at org.apache.catalina.valves.AbstractAccessLogValve.invoke(AbstractAccessLogValve.java:660) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:87) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343) at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:798) at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66) at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:808) at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1498) at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61) at java.lang.Thread.run(Thread.java:748) 此问题已解决,导致报错的原因是sheet.trackAllColumnsForAutoSizing();poi自动设置列宽的代码,注释这行之后问题解决。
遍历泛型List,应该返回什么类型
泛型不支持 用《T》代替了 方法一 public static 《T》 List《T》 query(String sql, Class《T》 clazz) { Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; Object tempStr = null; List《T》 list = new ArrayList《T》(); try { conn = DBConnectUtils.getConnection(); pstmt = conn.prepareStatement(sql); rs = pstmt.executeQuery(); while (rs.next()) { // newInstance实际上是把new这个方式分解为两步,即,首先调用class的加载方法加载某个类,然后实例化。 // 我们可以在调用class的静态加载方法forName时获得更好的灵活性,提供给了我们降耦的手段。 // newInstance: 弱类型。低效率。只能调用无参构造。 // new: 强类型。相对高效。能调用任何public构造。 T obj = clazz.newInstance(); if (obj instanceof String) { // ResultSet的下标从1开始 obj = (T) rs.getString(1); } else { // Field 提供有关类或接口的单个字段的信息,以及对它的动态访问权限 // getDeclaredFields()返回Class中所有的字段,包括私有字段 // getFields 只返回公共字段,即有public修饰的字段 // field,域是一种属性,可以是一个类变量,一个对象变量,一个对象方法变量或者是一个函数的参数。 Field[] fields = obj.getClass().getDeclaredFields(); // 遍历域 for (Field field : fields) { try { // 反射获取对象成员的字段值 tempStr = rs.getObject(field.getName()); } catch (SQLException e) { tempStr = ""; } // 置是否允许访问,而不是修改原来的访问权限修饰词 field.setAccessible(true); // 把对象的属性数据封装到对象中 BeanUtils.setProperty(obj, field.getName(), tempStr); } } list.add(obj); } } catch (Exception e) { e.printStackTrace(); } finally { DBCloseUtils.closeCSR(conn, pstmt, rs); } return list; } 方法二 public static 《T》 List《T》 query(String sql, Class《T》 clazz, Object[] parameters) { Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; ResultSetMetaData metaData = null; List《T》 list = new ArrayList《T》(); int index = 1; try { pstmt = conn.prepareStatement(sql); if (parameters != null && parameters.length != 0) { for (int i = 0; i < parameters.length; i++) { // pstmt.setObject(第几个参数, 替换成什么); pstmt.setObject(index, parameters[i]); } } rs = pstmt.executeQuery(sql); // 封装resultset metaData = rs.getMetaData(); // 取出列的信息 int columnLength = metaData.getColumnCount(); // 获取列数 while (rs.next()) { // 通过反射机制创建一个对象 T result = clazz.newInstance(); for (int i = 0; i < columnLength; i++) { String metaDataKey = metaData.getColumnName(i + 1); Object resultsetValue = rs.getObject(metaDataKey); if (resultsetValue == null) { resultsetValue = ""; } Field field = clazz.getDeclaredField(metaDataKey); field.setAccessible(true); field.set(result, resultsetValue); } list.add(result); } } catch (Exception e) { e.printStackTrace(); } finally { DBCloseUtils.closeCSR(conn, pstmt, rs); } return list; }
Java新手请教各位大神
如何通过Scanner类往一个arraylist中添加数据?也就是如何从键盘往一个链表中添加多个数据?是多个,然后再遍历打印出来?
java对象属性的默认值影响sql查询语句的拼接,该如何处理。
1、问题描述: 想做一个通用的sql查询语句,通过传入对象的属性赋值情况,拼接查询语句。比如Admin类,有int id,String name,int age,boolean isLeader 4个属性,如果给Admin的对象的某几个属性赋值,比如:setAge(32);setName(“张”)。那么语句拼接为select * from admin where age=32 and name like '%张%'。我在拼接时本来想通过属性是否为null,或者是否为空字符来判断是否作为查询条件,但是由于默认值的存在,导致拼接错误。 2、代码 ``` /*** * 约定: * 1、类名与表名对应,表名全小写。 * 2、类属性与列名一致。 * 3、ID列的类属性和列名为=表名(第一个字母小写)+“Id” * * 4、暂不支持联表查询。 *类名:BaseDao * ***/ public <T> List<T> query(T t) throws IllegalArgumentException, IllegalAccessException, SQLException{ StringBuilder sql=new StringBuilder(); StringBuilder whereString=new StringBuilder(); List<Object> parameters=new ArrayList<Object>(); Class clazz=t.getClass(); //获取类名 String classSimpleName=clazz.getSimpleName(); //获取表名 String tableName=classSimpleName.toLowerCase(); //拼接select语句前半部分 sql.append("select * from "+tableName); //获取所有类属性 Field[] fields=clazz.getDeclaredFields(); //遍历所有属性 for(Field field:fields) { field.setAccessible(true); //得到属性值 Object fieldValue=field.get(t); if(fieldValue!=null) { //如果属性值不为null,获取属性名(字段名)。 String fieldName=field.getName(); //判断是否为String类型 if(fieldValue instanceof String) { // 如果是String,判断是否为空字符 if(!("".equals(((String)fieldValue).trim()))) { //不是空字符串,作为where条件,并将参数加入列表。 whereString.append(fieldName+" like ? and "); parameters.add("%"+(String)fieldValue+"%"); } }else if("Integer".equals(fieldValue.getClass().getSimpleName())){ /***判断是否为int,如果int>0,认为参数有效---这个也是为了处理默认值为0的情况,想的办法,但是有时候表里面字段值可能<=0,所以我觉得处理得不**好*/ if((int)fieldValue>0) { whereString.append(fieldName+"=? and "); parameters.add(fieldValue); } }else{ /*其他情况直接作为where查询条件,但是运行发现boolean值默认false,也会直接当成是有效条件,影响条件设置*/ whereString.append(fieldName+"=? and "); parameters.add(fieldValue); } } } //判断是否有有效条件,有的话拼接where语句。 if(parameters.size()>0) { whereString.delete(whereString.length()-5, whereString.length()-1); sql.append(" where "); sql.append(whereString); } System.out.println(sql.toString()); System.out.println(parameters); //连接数据库,查询。 QueryRunner qr=JdbcPool.getQueryRunner(); // return null; return qr.query(sql.toString(), new BeanListHandler<T>(clazz), parameters.toArray()); } ``` 3、测试代码 ``` @Test public void BaseDao() throws Exception, IllegalAccessException { IpAddress ipObj=new IpAddress(); //只设置了一个条件。 ipObj.setIpAddress("192.168.1"); BaseDao bd=new BaseDao(); List<IpAddress> list=bd.query(ipObj); for(IpAddress ip:list) { System.out.println(ip); } System.out.println(list.size()); } ``` 4、结果 ``` //在只设置了一个条件的情况下,拼接出两个查询条件。 select * from ipaddress where ipAddress like ? and isReachable=? [%192.168.1%, false] ``` 5、问题: 请问如何处理这种由于对象基本类型默认值,导致的拼接错误的问题?
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私有的数
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
此博客仅为我业余记录文章所用,发布到此,仅供网友阅读参考,如有侵权,请通知我,我会删掉。 补充 有不少读者留言说本文章没有用,因为天气预报直接打开手机就可以收到了,为何要多此一举发送到邮箱呢!!!那我在这里只能说:因为你没用,所以你没用!!! 这里主要介绍的是思路,不是天气预报!不是天气预报!!不是天气预报!!!天气预报只是用于举例。请各位不要再刚了!!! 下面是我会用到的两个场景: 每日下
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
死磕YOLO系列,YOLOv1 的大脑、躯干和手脚
YOLO 是我非常喜欢的目标检测算法,堪称工业级的目标检测,能够达到实时的要求,它帮我解决了许多实际问题。 这就是 YOLO 的目标检测效果。它定位了图像中物体的位置,当然,也能预测物体的类别。 之前我有写博文介绍过它,但是每次重新读它的论文,我都有新的收获,为此我准备写一个系列的文章来详尽分析它。这是第一篇,从它的起始 YOLOv1 讲起。 YOLOv1 的论文地址:https://www.c
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的 回答 - Bravo Yeung,获得该问题下回答中得最高赞(236赞和1枚专业勋章),对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalk
记一次腾讯面试:进程之间究竟有哪些通信方式?如何通信? ---- 告别死记硬背
有一次面试的时候,被问到进程之间有哪些通信方式,不过由于之前没深入思考且整理过,说的并不好。想必大家也都知道进程有哪些通信方式,可是我猜很多人都是靠着”背“来记忆的,所以今天的这篇文章,讲给大家详细着讲解他们是如何通信的,让大家尽量能够理解他们之间的区别、优缺点等,这样的话,以后面试官让你举例子,你也能够顺手拈来。 1、管道 我们来看一条 Linux 的语句 netstat -tulnp | gr...
20行Python代码爬取王者荣耀全英雄皮肤
引言 王者荣耀大家都玩过吧,没玩过的也应该听说过,作为时下最火的手机MOBA游戏,咳咳,好像跑题了。我们今天的重点是爬取王者荣耀所有英雄的所有皮肤,而且仅仅使用20行Python代码即可完成。 准备工作 爬取皮肤本身并不难,难点在于分析,我们首先得得到皮肤图片的url地址,话不多说,我们马上来到王者荣耀的官网: 我们点击英雄资料,然后随意地选择一位英雄,接着F12打开调试台,找到英雄原皮肤的图片
网络(8)-HTTP、Socket、TCP、UDP的区别和联系
TCP/IP协议是传输层协议,主要解决数据如何在网络中传输,而HTTP是应用层协议,主要解决如何包装数据。 一、TCP与UDP的不同 1. 是否需要建立连接。 UDP在传送数据之前不需要先建立连接;TCP则提供面向连接的服务; 2. 是否需要给出确认 对方的传输层在收到UDP报文后,不需要给出任何确认,而 TCP需要给出确认报文,要提供可靠的、面向连接的传输服务。 3.虽然UDP不提供可靠交...
简明易理解的@SpringBootApplication注解源码解析(包含面试提问)
欢迎关注文章系列 ,关注我 《提升能力,涨薪可待》 《面试知识,工作可待》 《实战演练,拒绝996》 欢迎关注我博客,原创技术文章第一时间推出 也欢迎关注公 众 号【Ccww笔记】,同时推出 如果此文对你有帮助、喜欢的话,那就点个赞呗,点个关注呗! 《提升能力,涨薪可待篇》- @SpringBootApplication注解源码解析 一、@SpringBootApplication 的作用是什
防劝退!数据结构和算法难理解?可视化动画带你轻松透彻理解!
大家好,我是 Rocky0429,一个连数据结构和算法都不会的蒟蒻… 学过数据结构和算法的都知道这玩意儿不好学,没学过的经常听到这样的说法还没学就觉得难,其实难吗?真难! 难在哪呢?当年我还是个小蒟蒻,初学数据结构和算法的时候,在忍着枯燥看完定义原理,之后想实现的时候,觉得它们的过程真的是七拐八绕,及其难受。 在简单的链表、栈和队列这些我还能靠着在草稿上写写画画理解过程,但是到了数论、图...
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
开挂的人生!那些当选院士,又是ACM/IEEE 双料Fellow的华人学者们
昨日,2019年两院院士正式官宣,一时间抢占了各大媒体头条。 朋友圈也是一片沸腾,奔走相告,赶脚比自己中了大奖还嗨皮! 谁叫咱家导师就是这么厉害呢!!! 而就在最近,新一年度的IEEE/ACM Fellow也将正式公布。 作为学术届的顶级荣誉,不自然地就会将院士与Fellow作比较,到底哪个含金量更高呢? 学术君认为,同样是专业机构对学者的认可,考量标准不一,自然不能一概而论。 但...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
Python语言高频重点汇总
Python语言高频重点汇总 GitHub面试宝典仓库——点这里跳转 文章目录Python语言高频重点汇总**GitHub面试宝典仓库——点这里跳转**1. 函数-传参2. 元类3. @staticmethod和@classmethod两个装饰器4. 类属性和实例属性5. Python的自省6. 列表、集合、字典推导式7. Python中单下划线和双下划线8. 格式化字符串中的%和format9.
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观
代码详解:如何用Python快速制作美观、炫酷且有深度的图表
全文共12231字,预计学习时长35分钟生活阶梯(幸福指数)与人均GDP(金钱)正相关的正则图本文将探讨三种用Python可视化数据的不同方法。以可视化《2019年世界幸福报告》的数据为例,本文用Gapminder和Wikipedia的信息丰富了《世界幸福报告》数据,以探索新的数据关系和可视化方法。《世界幸福报告》试图回答世界范围内影响幸福的因素。报告根据对“坎特里尔阶梯问题”的回答来确定幸...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外
(经验分享)作为一名普通本科计算机专业学生,我大学四年到底走了多少弯路
今年正式步入了大四,离毕业也只剩半年多的时间,回想一下大学四年,感觉自己走了不少弯路,今天就来分享一下自己大学的学习经历,也希望其他人能不要走我走错的路。 (一)初进校园 刚进入大学的时候自己完全就相信了高中老师的话:“进入大学你们就轻松了”。因此在大一的时候自己学习的激情早就被抛地一干二净,每天不是在寝室里玩游戏就是出门游玩,不过好在自己大学时买的第一台笔记本性能并不是很好,也没让我彻底沉...
如何写一篇技术博客,谈谈我的看法
前言 只有光头才能变强。 文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y 我一直推崇学技术可以写技术博客去沉淀自己的知识,因为知识点实在是太多太多了,通过自己的博客可以帮助自己快速回顾自己学过的东西。 我最开始的时候也是只记笔记,认为自己能看得懂就好。但如果想验证自己是不是懂了,可以写成技术博客。在写技术博客的...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
互联网公司的裁员,能玩出多少种花样?
裁员,也是一门学问,可谓博大精深!以下,是互联网公司的裁员的多种方法:-正文开始-135岁+不予续签的理由:千禧一代网感更强。95后不予通过试用期的理由:已婚已育员工更有责任心。2通知接下来要过苦日子,让一部分不肯同甘共苦的员工自己走人,以“兄弟”和“非兄弟”来区别员工。3强制996。员工如果平衡不了工作和家庭,可在离婚或离职里二选一。4不布置任何工作,但下班前必须提交千字工作日报。5不给活干+...
【设计模式】单例模式的八种写法分析
网上泛滥流传单例模式的写法种类,有说7种的,也有说6种的,当然也不排除说5种的,他们说的有错吗?其实没有对与错,刨根问底,写法终究是写法,其本质精髓大体一致!因此完全没必要去追究写法的多少,有这个时间还不如跟着宜春去网吧偷耳机、去田里抓青蛙得了,一天天的....
《面试宝典》:检验是否为合格的初中级程序员的面试知识点,你都知道了吗?查漏补缺
欢迎关注文章系列,一起学习 《提升能力,涨薪可待篇》 《面试知识,工作可待篇》 《实战演练,拒绝996篇》 也欢迎关注公 众 号【Ccww笔记】,原创技术文章第一时间推出 如果此文对你有帮助、喜欢的话,那就点个赞呗,点个关注呗! 《面试知识,工作可待篇》-Java笔试面试基础知识大全 前言 是不是感觉找工作面试是那么难呢? 在找工作面试应在学习的基础进行总结面试知识点,工作也指日可待,欢...
关于研发效能提升的思考
研发效能提升是最近比较热门的一个话题,本人根据这几年的工作心得,做了一些思考总结,由于个人深度有限,暂且抛转引入。 三要素 任何生产力的提升都离不开这三个因素:人、流程和工具,少了其中任何一个因素都无法实现。 人,即思想,也就是古人说的“道”,道不同不相为谋,是制高点,也是高层建筑的基石。 流程,即方法,也是古人说的“法”。研发效能的提升,也就是要提高投入产出比,既要增加产出,也要减...
微博推荐算法简述
在介绍微博推荐算法之前,我们先聊一聊推荐系统和推荐算法。有这样一些问题:推荐系统适用哪些场景?用来解决什么问题、具有怎样的价值?效果如何衡量? 推荐系统诞生很早,但真正被大家所重视,缘起于以”facebook”为代表的社会化网络的兴起和以“淘宝“为代表的电商的繁荣,”选择“的时代已经来临,信息和物品的极大丰富,让用户如浩瀚宇宙中的小点,无所适从。推荐系统迎来爆发的机会,变得离用户更近: 快...
相关热词 c#开发的dll注册 c#的反射 c# grid绑定数据源 c#多线程怎么循环 c# 鼠标左键 c# char占位符 c# 日期比较 c#16进制转换为int c#用递归求顺序表中最大 c#小型erp源代码
立即提问