List add() iterator同时遍历报错或者结果不对

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.ListIterator;
import java.util.concurrent.CopyOnWriteArrayList;

public class DiGuiTest {
public static void main(String[] args) {

    List<OrgDto> list = new ArrayList<OrgDto>();
    OrgDto dto1 = new OrgDto();
    dto1.setOrgId(10l);
    dto1.setSupOrgId(3l);
    dto1.setOrgName("10部门");
    list.add(dto1);

    OrgDto dto2 = new OrgDto();
    dto2.setOrgId(12l);
    dto2.setSupOrgId(10l);
    dto2.setOrgName("12部门");
    list.add(dto2);

    OrgDto dto3 = new OrgDto();
    dto3.setOrgId(13l);
    dto3.setSupOrgId(12l);
    dto3.setOrgName("13部门");
    list.add(dto3);

    Long a = 3l;
    List<Long> supList = new CopyOnWriteArrayList<Long>();
    supList.add(a);
    List<String> nameList = new ArrayList<String>();

    Iterator<Long> iterator = supList.iterator();

    while (iterator.hasNext()) {
        Long s = Long.parseLong(iterator.next().toString());
        for (OrgDto o : list) {
            if (o.getOrgId().equals(s)) {
                nameList.add(o.getOrgName().trim());
            } else if (o.getSupOrgId().equals(s)) {
                nameList.add(o.getOrgName().trim());
                supList.add(o.getOrgId());
            }
        }
    }

    for (String n : nameList) {
        System.out.println(n);
    }
}

}

想要实现的是 能够输出10部门及其所有子部门的部门名称,即10部门、12部门、13部门

2个回答

 while (iterator.hasNext()) {改成用for(int i=0;i<supList.size();i++){

java认为在迭代过程中,容器应当保持不变。因此,java容器中通常保留了一个域称为modCount,每次你对容器修改,这个值就会加1。当你调用iterator方法时,返回的迭代器会记住当前的modCount,随后迭代过程中会检查这个值,一旦发现这个值发生变化,就说明你对容器做了修改,就会抛异常。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
遍历泛型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; }

struts2迭代器遍历 action list值

action 代码: public class Test1 { private List<String> listString = new ArrayList<String>(); public List<String> getListString() { return listString; } public void setListString(List<String> listString) { this.listString = listString; } public String execute() throws IOException { // Configuration conf = new Configuration(); // FileSystem fSystem = FileSystem.get(URI.create("hdfs:/^de:9000"), conf); // Path path = new Path("/user/upload/"); // FileStatus[] list = fSystem.listStatus(path); // // for (FileStatus pFileStatus : list) { // listString.add(pFileStatus.getPath().getName()); // } listString.add("fsafsa"); listString.add("fsafsa"); System.out.println("fsafsa" + listString.size()); return "success"; } jsp页面代码 <s:iterator value="listString" var="info"> <tr><td><s:property value="info" /></td> </tr> </s:iterator> 在action中listString是有值得为什么到jsp页面中就不显示了 如果在JSP页面给iterator赋值的话 就可以显示 iterator 我尝试过网上说的很多方法了 基本上没用。。

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

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

c++的list能否在自定义类中使用

这是我的menusystem.h头文件,有的功能还没写完,我想在主菜单的b功能里面实现对这两个集合的遍历,我有另外两个头文件分别包含老师类和学生类。 list<Student>::iterator() its; list<Teacher>::iterator() itt; 这两句会提示错误: error C2146: syntax error : missing ';' before identifier 'its' error C2501: 'its' : missing storage-class or type specifiers error C2146: syntax error : missing ';' before identifier 'itt' error C2535: 'int __thiscall MenuSystem::iterator(void)' : member function already defined or declaredd:\vc6.0(绿色win8可用)\program ide\vc++6.0\myprojects\课程设计\menusystem.h(23) : see declaration of 'iterator' error C2501: 'itt' : missing storage-class or type specifiers /* 系统的核心类,通过该菜单系统实现所有功能,通过友元联系上老师类和学生类。 */ #pragma once #ifndef __MENUSYSTEM_H__ #define __MENUSYSTEM_H__ #include<list> #include<iostream> #include"student.h" #include"teacher.h" class Teacher; class Student; class SchoolPerson; using namespace std; class MenuSystem { public: typedef list<Student> LISTS; typedef list<Teacher> LISTT; LISTS lists; LISTT listt; void showmenu() { list<Student>::iterator() its; list<Teacher>::iterator() itt; cout<<"欢迎进入高校水电管理系统"<<endl; START: cout<<"请选择功能(输入数字):"<<endl; cout<<"a、录入用户信息"<<endl; cout<<"b、查询用户信息"<<endl; cout<<"c、查询未缴费名单"<<endl; cout<<"d、退出系统"<<endl; cin>>button; switch (button) { case 'a': cout<<"用户信息录入界面"; cout<<"请输入S或者T选择录入学生信息还是老师信息输入其他返回主界面:"; cin>>career; switch (career) { case 'S': { int swi=1; while (swi==1) { Student *stu; stu=new Student; (*stu).set(); lists.push_front(*stu); cout<<"输入1继续添加,输入其他退出添加。"; cin>>swi; } } break; case 'T': { int swi=1; while (swi==1) { Teacher *tea; tea=new Teacher; (*tea).set(); listt.push_front(*tea); cout<<"输入1继续添加,输入其他退出添加。"; cin>>swi; } } break; default: goto START; } break; case 'b': { char button2; cout<<"用户信息查询"<<endl; cout<<"a、查询所有学生信息"<<endl; cout<<"b、查询所以老师信息"<<endl; cout<<"c、查询学生个人信息"<<endl; cout<<"d、查询老师个人信息"<<endl; cout<<"按其他键返回主菜单"<<endl; cin>>button2; switch (button2) { case 'a': { for (its=lists.begin();its!=lists.end();its++) { (*its).print_information(); cout<<endl; } } break; case 'b': { for (itt=listt.begin();itt!=lists.end();itt++) { (*itt).print_information(); cout<<endl; } } break; case 'c': { int sign=0; long snumber; cout<<"请输入要查询的学生的学号:"; cin>>snumber; for (its=lists.begin();its!=lists.end();its++) { if ((*its).getnumber()==snumber) { cout<<"查询结果如下:"<<endl; (*its).print_information(); sign=1; } } if (sign==0) cout<<"没有此用户!"; } break; case 'd': { int sign=0; long tnumber; cout<<"请输入要查询的老师的工号:"; cin>>snumber; for (itt=lists.begin();itts!=listt.end();itt++) { if ((*itt).getnumber()==tnumber) { cout<<"查询结果如下:"<<endl; (*itt).print_information(); sign=1; } } if (sign==0) cout<<"没有此用户!"; } break; default: goto START; } } case 'c': //调用没交费学生信息 //调用没交费老师信息 break; case 'd': exit(0); default: cout<<"错误的指令,请重新输入:"<<endl; goto START; } } private: char button; char career; }; #endif

一个奇怪的问题,从泛型为Integer的Set中取到的遍历取到的值为String

``` public ResponseResult putAllAnswer(Map<Integer, String> map) { Set<Integer> testIds=map.keySet(); List<Integer> errorAnswer=new LinkedList<Integer>(); for(Integer testId:testIds){ Test test=testMapper.selectByPrimaryKey(testId); if(map.get(testId).equals(test.getRightAnswer())){ continue; }else{ errorAnswer.add(testId); } } } public ResponseResult putAllAnswer(HashMap<Integer, String> map) { Set<Integer> testIds=map.keySet(); List<Integer> errorAnswer=new LinkedList<Integer>(); Iterator<Integer> iter=testIds.iterator(); while(iter.hasNext()){ System.out.println(iter.next().getClass()); Integer testId=iter.next(); } } ``` 代码如上,在执行到for循环内时,testId无法接受testIds中的数据,显示类型转换错误,String无法转换为Integer类型,非常奇怪,即使是通过Iterator遍历也无法获取set集合中的值,始终显示String无法转换为Integer类型的报错,甚至在无法通过getClass方法来获取对象的类型信息,执行该语句也会报错

自制linklist容器,遍历元素时出问题,只能访问第一个元素

代码如下 容器类 ``` package datastructure; import java.util.Iterator; //链表 public class LinkList<T> implements Iterable{ Node<T> first,last; int length; Iterator<T> itr=null; public LinkList(){ first=last=null; length=0; } public Iterator<T> iterator() { return new itr(); } //存取第i个节点 Node<T> getNode(int i){ if(i<0||i>length-1){ return null; } if(i==0){ return first; } Node<T> p=first; int j=0; while(p!=null&&j<i){ p=p.next; j++; } return p; } //取得i号节点的值 public T get(int i){ Node<T> p=getNode(i); if(p==null){ return null; } else return p.data; } //修改第i号节点的值 public boolean set(int i,T x){ Node<T> p=getNode(i); if(p==null){ return false; } else{ p.data=x; return true; } } //在i位插入元素 public void add(int i,T x){ Node<T> p=null,s=null; int j=i-1; s=new Node<T>(x,null); if(first==null||length==0){ first=s; last=s; } if(j<0){ s.next=first; first=s; } if(j>=length-1){ s.next=last; last=s; }else{ p=getNode(j); s.next=p.next; p.next=s; } length++; } class itr implements Iterator<T>{ private int index=0; private Node<T> current=first; public boolean hasNext() { return (index!=length&&current!=null); } public T next() { T temp=current.data; current=current.next; index++; return temp; } } } //节点 class Node<T> implements Comparable<Node<T>>{ public T data; public Node<T> next; public Node(T key){ data=key; next=null; } public Node(T key,Node<T> next){ data=key; this.next=next; } public boolean equals(Object e){ Node<T> node=(Node<T>)e; return data.equals(node.data); } public int compareTo(Node<T> e) { Comparable<T> x; if(data instanceof Comparable){ x=(Comparable<T>)data; return (int)x.compareTo(e.data); }else throw new ClassCastException("类型无法比较!"); } public String toString(){ return data.toString(); } } ``` 测试类 ``` package datastructure; import java.util.*; public class test { public static void main(String[] args) { LinkList<Integer> list=new LinkList<Integer>(); list.add(1,1); list.add(2,2); list.add(3,3); Iterator<Integer> i=list.iterator(); while(i.hasNext()){ System.out.println(i.next()); } } } ```

java list 内递归构建树,效率很差,如果remove节点报ConcurrentModificationException

递归调用循环次数太多,求救,效率很慢 list大小3000+, 当想着循环时发现父节点挂接到父节点的时候,减小list大小来减少循环次数,却报错, 希望能得到帮助,如何优化,重写? 代码中只能得到根节点的ID ![代码原图](https://img-ask.csdn.net/upload/201905/23/1558579301_650521.png) ``` /** * @param aynpAll 所有数据 * @param checkId 根节点ID * @return */ private static AynpTree getAyTree(final List<TAynp> aynpAll, final String checkId) { List<AynpTree> dataList = aylistToAyTreeList(aynpAll); //转换树对象 //根节点 List<AynpTree> treeRootList = (List<AynpTree>) CollectionUtils.select(dataList, new Predicate() { @Override public boolean evaluate(Object object) { AynpTree ay = (AynpTree) object; if (StringUtils.isBlank(checkId)) { return StringUtils.isBlank(ay.getPid()); } else { return StringUtils.equals(ay.getId(), checkId); } } }); //开始递归 getTreeNode(dataList, treeRootList); return treeRootList.get(0); } /** * 递归调用 * @param dataList全部数据集合 * @param treeRootList */ private static void getTreeNode(List<AynpTree> dataList, List<AynpTree> treeRootList) { for (AynpTree treeRoot : treeRootList) { List<AynpTree> children = new ArrayList<AynpTree>(); // Iterator<AynpTree> iterator = dataList.iterator(); ListIterator<AynpTree> listIterator = dataList.listIterator(); while (listIterator.hasNext()) { AynpTree data = (AynpTree) listIterator.next(); a++; if (StringUtils.equals(treeRoot.getId(), data.getPid())) { children.add(data); listIterator.remove(); getTreeNode(dataList, children); } } treeRoot.setChildren(children); } } ```

数据库中遍历 问题。。。。。。。。。。

[code="java"] public List<Map<String, Object>> findMovieByRegion(String region){ List<Map<String, Object>> movieList = new ArrayList<Map<String, Object>>(); SQLiteDatabase db = dbHelper.getReadableDatabase(); Cursor cursor = db.rawQuery("select num from Online_movie where region=?", new String[]{region}); while(cursor.moveToNext()){ int aa = cursor.getInt(cursor.getColumnIndex("num")); HashMap<String, Object> map = new HashMap<String, Object>(); map.put("aaa", aa); System.out.println(map); movieList.add(map); } return movieList; } //______________________________________________ 下面是 遍历上面 数据库中的 集合 MovieService ms = new MovieService(this.getBaseContext()); List<Map<String,Object>> typenum = ms.findMovieByRegion("美国"); for (Iterator<Map<String, Object>> typeiterator = typenum.iterator(); typeiterator.hasNext();) { Object num = typeiterator.next(); //这里打印的 num 是{aaa=10},{aaa=9},{aaa=3}可是 我只想得到 10,9,3这几个数字 因为 有花括号的话 组成的路径就是错误的 Log.v("num===ggggggggggggggg>", ""+num); listmap = FileList.findFile(Environment.getExternalStorageDirectory()+"/Pictures/"+num+".jpg"); } [/code]

Struts2遍历对象没反应

jsp ``` <body> <jsp:include page="top.jsp"/> <s:action name="article!getAllArticle" /> <s:iterator value="articles" > <s:property value="article.title"/> </s:iterator> <jsp:include page="buttom.jsp"/> </body> ``` action ``` package com.sg.action; import java.util.Iterator; import java.util.List; import javax.annotation.Resource; import javax.print.event.PrintJobAdapter; import org.apache.struts2.convention.annotation.Action; import org.apache.struts2.convention.annotation.Result; import org.springframework.stereotype.Controller; import com.opensymphony.xwork2.ActionContext; import com.opensymphony.xwork2.ActionSupport; import com.sg.model.Article; import com.sg.service.ArticleService; import com.sun.xml.internal.ws.org.objectweb.asm.Type; @SuppressWarnings({ "serial", "unused" }) @Controller @Action(value="article" ,results={ @Result (name="success" ,location="/index.jsp") }) public class ArticleAction extends ActionSupport{ @Resource private ArticleService articleService; private Article article; private List<Article> articles; public Article getArticle() { return article; } public void setArticle(Article article) { this.article = article; } public String add(){ System.out.println("a"); return "success"; } public void getAllArticle(){ articles=articleService.getArticle(); article=articles.get(0); System.out.println(article.getEditer()); for(Iterator<Article> iterator = articles.iterator();iterator.hasNext();){ System.out.println(iterator.next().getTitle().toString()); } } public List<Article> getArticles() { return articles; } public void setArticles(List<Article> articles) { this.articles = articles; } } ``` 调用action方法的时候控制台有输出信息,问题就是怎么调用到jsp页面上,网上查的好像就是这么写啊 别说list 了,直接<s:porperty value="article.title"/>都没东西

jsp遍历action数据为空

Action代码: public class IndividualAccount extends ActionSupport { private DayFinanceInfo this_month = null; private DayFinanceInfo last_month = null; private List<DayFinanceInfo> this_list = null; private List<DayFinanceInfo> last_list = null; @Override public String execute() throws Exception { // TODO Auto-generated method stub String[] time = new String[2]; SimpleDateFormat format = new SimpleDateFormat("yyyyMM"); String month = format.format(new Date()); Integer a = Integer.valueOf(month); String last_month = String.valueOf(a-1); time[0] = month; time[1] = last_month; get(time); return SUCCESS; } public void get(String[] time){ this_list = new ArrayList<DayFinanceInfo>(); last_list = new ArrayList<DayFinanceInfo>(); //本月 query("this",time[0]); //上月 query("last", time[1]); } /** * 数据库执行查询操作 * @param time 月份 * */ private void query(String which,String time){ User user = null; Map<String, Object> session = null; String username = null; Connection connection = null; Statement statement = null; ResultSet resultSet = null; //获取用户信息 session = ActionContext.getContext().getSession(); user = (User) session.get("user"); username = user.getUsername(); String query = "select * from day_finance where username='" + username + "' and month_time='" + time + "';"; try { connection = CreateConnection.getConnection(); statement = CreateConnection.getStatement(connection); resultSet = statement.executeQuery(query); while (resultSet.next()) { if(which.equals("this")){ this_month = new DayFinanceInfo(); this_month.setTime(resultSet.getString("datetime")); this_month.setType(resultSet.getString("class")); this_month.setMoney(resultSet.getString("cost")); this_month.setContent(resultSet.getString("title")); this_month.setRemark(resultSet.getString("remark")); this_list.add(this_month); }else{ last_month = new DayFinanceInfo(); last_month.setTime(resultSet.getString("datetime")); last_month.setType(resultSet.getString("class")); last_month.setMoney(resultSet.getString("cost")); last_month.setContent(resultSet.getString("title")); last_month.setRemark(resultSet.getString("remark")); last_list.add(last_month); } } } catch (Exception e) { // TODO: handle exception e.printStackTrace(); } finally{ try { resultSet.close(); statement.close(); connection.close(); } catch (SQLException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } public DayFinanceInfo getThis_month() { return this_month; } public void setThis_month(DayFinanceInfo this_month) { this.this_month = this_month; } public List<DayFinanceInfo> getThis_list() { return this_list; } public void setThis_list(List<DayFinanceInfo> this_list) { this.this_list = this_list; } public List<DayFinanceInfo> getLast_list() { return last_list; } public void setLast_list(List<DayFinanceInfo> last_list) { this.last_list = last_list; } public DayFinanceInfo getLast_month() { return last_month; } public void setLast_month(DayFinanceInfo last_month) { this.last_month = last_month; } } struts.xml配置: <action name="month_account" class="action.IndividualAccount" > <result name="success">/Page/Finance/zhanghu.jsp</result> </action> jsp代码: 页面一加载便发送请求 <script> var current = <%=month%>; current--; function month(){ $.post('month_account.action',{ month:<%=month%>, lastmonth:current },function(info){ }) } month(); </script> jsp界面中遍历代码: <s:iterator value="#this_list" id="this_"> <tr> <td class="settime"> <s:property value="#this_.time"/></td> <td class="setclass"> <s:property value="#this_.type"/></td> <td class="setmoney"> <s:property value="#this_.money"/></td> <td class="setcontent"> <s:property value="#this_.content"/></td> <td class="settips"> <s:property value="#this_.remark"/></td> </tr> </s:iterator>

java 集合什么情况需要用到迭代器

我看书学习java集合时经常看到 iterator迭代器,可以通过它来遍历集合,删除元素,如果是有序集合List还可以添加元素。<br/> 以前学集合的时候只是简单的学了几个方法add set remove get等等。在做项目的时候也完全够用。这几个方法和迭代器的方法是不是重复了<br/> 那么,问题来了,什么时候需要用到迭代器?这个迭代器需要熟练掌握吗?

简单模拟struts中的Interceptor的调用过程遇到的问题

不明白struts中Interceptor的调用过程(Interceptors的遍历过程),自己写了个小程序测试。得不到想要的结果 求大神指点啊~~ 代码如下: public class Interceptor { Invocation test; String name; public Interceptor(String name){ this.name=name; } public String intercept(Invocation test) { this.test=test; System.out.println("--name--1--"+name); test.invoke(); System.out.println("--name--2--"+name); eturn super.toString(); } } import java.util.ArrayList; import java.util.Iterator; import java.util.List; public class Invocation { public static void main(String[] args) { Invocation t = new Invocation(); t.invoke(); } public void invoke(){ List<Interceptor> list = new ArrayList<Interceptor>(); list.add(new Interceptor("aaaaa")); list.add(new Interceptor("bbbbb")); list.add(new Interceptor("ccccc")); list.add(new Interceptor("ddddd")); list.add(new Interceptor("eeeee")); list.add(new Interceptor("fffff")); list.add(new Interceptor("ggggg")); list.add(new Interceptor("hhhhh")); Iterator<Interceptor> iss = list.iterator(); if(iss.hasNext()){ Interceptor ms = iss.next(); ms.intercept(this); } }

控制台录入将内容添加到集合中,但是在集合遍历的时候变成了死循环,代码在下面,求指点迷津

ArrayList<String> al = new ArrayList<String>(); Scanner sc = new Scanner(System.in); while(sc.hasNext()) { String st = sc.next(); if("quit".equals(st)){ break; } al.add(st); } Iterator<String> it = al.iterator(); System.out.println(al.size()); String c = null; while(it.hasNext()) { //用debug测试这里一直为true ,我猜想是add方法出了问题 牛人求指点 c = c+it.hasNext(); } System.out.println(c); // } }

struts2的<s:set>标签问题

List<Student> students=new ArrayList<Student>(); students.add(new Student("xiaoming",15)); students.add(new Student("xiaomingg",16)); students.add(new Student("xiaominggg",17)); 一:用setAttribute方法就可以遍历成功,如下: request.setAttribute("students", students); <s:iterator value="#request.students" status="statuss"> ${statuss.index }:${name }----${id } </s:iterator> 二:用<s:set>标签,就不能遍历成功。如下: <s:set name="students" value="students" scope="request"/> <s:iterator value="#request.students" status="statuss"> ${statuss.index }:${name }----${id } </s:iterator> <s:set>标签不就是把值放入域对象中吗,为什么不能遍历成功呢

java中的迭代器问题。

package testcc; import java.util.Iterator; import java.util.NoSuchElementException; public class MyArrrayList<AnyType> implements Iterable<AnyType> { private static final int DEFAULT_CAPACITY = 10; private int theSize; private AnyType[] theItems; public MyArrrayList() { clear(); } public void clear() { theSize = 0; ensureCapality(DEFAULT_CAPACITY); } public int size() { return theSize; } public boolean isEmpty() { return size() == 0; } public void trimSize() { ensureCapality(size()); } public AnyType get(int idx) { if (idx < 0 || idx >= size()) throw new ArrayIndexOutOfBoundsException(); return theItems[idx]; } public AnyType set(int idx, AnyType newVal) { if (idx < 0 || idx >= size()) throw new ArrayIndexOutOfBoundsException(); AnyType old = theItems[idx]; theItems[idx] = newVal; return old; } @SuppressWarnings("unchecked") public void ensureCapality(int newCapality) { if (newCapality < theSize) return; AnyType[] old = theItems; theItems = (AnyType[]) new Object[newCapality]; for (int i = 0; i < size(); i++) { theItems[i] = old[i]; } } public boolean add(AnyType x) { add(size(), x); return true; } public void add(int idx, AnyType x) { if (theItems.length == size()) ensureCapality(size() * 2 + 1); for (int i = theSize; i > idx; i--) theItems[i] = theItems[i - 1]; theItems[idx] = x; theSize++; } public AnyType remove(int idx) { if (idx < 0 || idx >= size()) throw new ArrayIndexOutOfBoundsException(); AnyType removeItem = theItems[idx]; for (int i = idx; i < theSize; i++) theItems[i] = theItems[i + 1]; theSize--; return removeItem; } @Override public Iterator<AnyType> iterator() { // TODO Auto-generated method stub return new ArrayListIterator(this); } private static class ArrayListIterator<AnyType> implements Iterator<AnyType> { private int current = 0; private MyArrrayList<AnyType> theList; public ArrayListIterator(MyArrrayList<AnyType> list){ theList=list; } public boolean hasNext() { return current < theList.size(); } public AnyType next() { return theList.theItems[current++]; } public void remove() { theList.remove(--current); } } public static void main(String[] args) { MyArrrayList<Integer> list=new MyArrrayList<Integer>(); for(int i=1;i<20;i++) list.add(i); Iterator<Integer> it=list.iterator(); while(it.hasNext()) { System.out.print(it.next()); System.out.print(" "); } Iterator<Integer> its=list.iterator(); while(it.hasNext()) { System.out.println(it.next()); } } } 为什么只有一次输出,1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 ; 二次迭代的输出无结果!求大神解答

超时则清除list中的element,刷新listview?

连续读取人员信息并将其以map形式添加到list当中,如果list中的一条人员信息在30s内未能再一次读到,则将list中的该条信息清除,请问各位前辈有什么实现办法?谢谢!我我采用下面代码并未得到正确结果 ``` //确保list里面放的是不同对象map的堆地址,指向的是不同对象 Map<String, Object> map = new HashMap<String, Object>(); map.put("itemName", name); //注意此处不可将Bitmap对象直接放入hashmap中,而应传入地址 map.put("itemPhoto", photoPath); map.put("addTime",System.currentTimeMillis()); Log.v("map", map.toString()); //根据姓名查看list当中是否存在所有项 boolean exist = false; for(Map<String, Object> tempMap : list){ if(name.equals(tempMap.get("itemName"))){ exist = true; //如果有则更新时间 tempMap.put("addTime", System.currentTimeMillis()); break; } } //如果不存在,则添加到list当中 if(!exist){ list.add(map); } Log.v("removeb2",list.toString()); //遍历list查看有无超时项,有则清空该项 Iterator<Map<String, Object>> it = list.iterator(); while(it.hasNext()){ if(System.currentTimeMillis()-Long.parseLong(it.next().get("addTime").toString())>30000){ it.remove(); } } }; } //将定时任务中获取的List装入ListView中 Message msg = new Message(); msg.what = 1; handler.sendMessage(msg); ``` ``` switch (msg.what) { case 1: /*tv1.setText(null); tv2.setText(null); tv3.setText(null); img.setImageBitmap(null);*/ SimpleAdapter adapter = new SimpleAdapter(MainActivity.this,list,R.layout.activity_item, new String[]{"itemName","itemPhoto"},//查询键值获取map中资源 new int[]{R.id.itemName,R.id.itemPhoto});//将获取的资源填入对应项 adapter.notifyDataSetChanged();//刷新adapter从而达到刷新列表的目的。 lv.setAdapter(adapter); ```

执行delete没有报错,就是删不掉数据,sql语句也有,求大神

package edu.jmi.xyh.view; import java.awt.BorderLayout; public class DeleteView extends JFrame { private JPanel contentPane; private JTextField txID; private JTextField txName; private JPasswordField txPw; /** * Launch the application. */ public static void main(String[] args) { EventQueue.invokeLater(new Runnable() { public void run() { try { DeleteView frame = new DeleteView(); frame.setVisible(true); } catch (Exception e) { e.printStackTrace(); } } }); } /** * Create the frame. */ public DeleteView() { setTitle("\u5220\u9664\u5B66\u751F\u4FE1\u606F"); setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); setBounds(100, 100, 450, 300); contentPane = new JPanel(); contentPane.setBorder(new EmptyBorder(5, 5, 5, 5)); setContentPane(contentPane); contentPane.setLayout(null); JLabel label = new JLabel("\u5220 \u9664 \u5B66 \u751F \u4FE1 \u606F"); label.setFont(new Font("宋体", Font.PLAIN, 16)); label.setBounds(140, 22, 147, 15); contentPane.add(label); JLabel lblId = new JLabel("\u7528 \u6237 ID\uFF1A"); lblId.setBounds(95, 55, 69, 15); contentPane.add(lblId); txID = new JTextField(); txID.setBounds(174, 52, 113, 21); contentPane.add(txID); txID.setColumns(10); JLabel label_2 = new JLabel("\u7528 \u6237 \u540D\uFF1A"); label_2.setBounds(95, 98, 66, 15); contentPane.add(label_2); JLabel label_3 = new JLabel("\u5BC6 \u7801\uFF1A"); label_3.setBounds(95, 143, 54, 15); contentPane.add(label_3); txName = new JTextField(); txName.setBounds(174, 95, 113, 21); contentPane.add(txName); txName.setColumns(10); JButton button = new JButton("\u5220\u9664"); button.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) { String id=txID.getText(); String pw=txPw.getText(); String name=txName.getText(); Student student=new Student(); student.setStuId(id); student.setStuName(name); student.setStuPwd(pw); StudentDao studentDao=new StudentDao(); int result=studentDao.delete(id); if(result==0){ JOptionPane.showMessageDialog(null, "删除成功!"); } else{ JOptionPane.showMessageDialog(null, "删除失败!"); } System.out.println("id="+id+"pw="+pw); } }); button.setBounds(75, 189, 93, 23); contentPane.add(button); JButton button_1 = new JButton("\u53D6\u6D88"); button_1.addActionListener(new ActionListener() { public void actionPerformed(ActionEvent e) { //生成一个对象 MainView mainView = new MainView(); //隐藏窗口 DeleteView.this.setVisible(false); mainView.setVisible(true); } }); button_1.setBounds(232, 189, 93, 23); contentPane.add(button_1); txPw = new JPasswordField(); txPw.setBounds(174, 140, 113, 21); contentPane.add(txPw); } public void setMainView(MainView mainView) { // TODO Auto-generated method stub } public void setID(Object id) { // TODO Auto-generated method stub } } 2.package edu.jmi.xyh.dao; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import java.util.ArrayList; import java.util.List; import edu.jmi.xyh.bean.Student; public class StudentDao { //测试用 //ORM object relation mapping hibernate,ibaits //每一条记录映射每一个对象,记录集合映射成对象集合List //Dao data access object //save将一个java对象存储到数据库表中,就是将对象转换为记录 public int save(Student student){ //建立一个DBOperation,通过这个对象完成数据库的连接操作 DBOperation dboperation= new DBOperation(); //获取数据库连接 Connection connection=null; try{ connection=dboperation.getConnection(); Statement st=connection.createStatement(); //字符串拼接 String sql="insert into student(stuId,stuName,stuPwd)values('" +student.getStuId()+"','"+student.getStuName()+"','"+student.getStuPwd()+"')"; //用来在程序中指挥sql命令执行 st.execute(sql); System.out.println(sql); return 0; }catch(Exception ex){ ex.printStackTrace(); //返回上层判断 return -1; }finally{ dboperation.closeConnect(connection); } } public int update(Student student){ //建立一个DBOperation,通过这个对象完成数据库的连接操作 DBOperation dboperation= new DBOperation(); //获取数据库 Connection connection=null; try{ connection=dboperation.getConnection(); Statement st=connection.createStatement(); //字符串拼接 String sql="update student set stuName='"+student.getStuName()+ "', stuPwd='"+student.getStuPwd()+"' where stuId='"+ student.getStuId()+"'"; st.execute(sql); System.out.println(sql); return 0; }catch(Exception ex){ ex.printStackTrace(); //返回上层判断 return -1; }finally{ dboperation.closeConnect(connection); } } public int delete(Student student){ //建立一个DBOperation,通过这个对象完成数据库的连接操作 DBOperation dboperation= new DBOperation(); //获取数据库连接 Connection connection=null; try{ connection=dboperation.getConnection(); String sql="delete from student where stuId='?'"; //准备执行sql语句 PreparedStatement pst=connection.prepareStatement(sql); //替换上面的问号 pst.setString(1, student.getStuId()); pst.execute(); /* Statement st=connction.createStatement(); //字符串拼接 String sql="delete from student where Stuid='"+student.getStuid()+"'"; st.execute(sql);*/ //把sql语句打出来 System.out.println(sql); //返回值 return 0; //异常处理 }catch(Exception ex){ ex.printStackTrace(); //返回上层判断 return -1; }finally{ //关闭与数据库连接 dboperation.closeConnect(connection); } } //查询结果放到集合中,集合中的每一个对象都是student <>是泛型 public List<Student> query(){ //建立一个DBOperation,通过这个对象完成数据库的连接操作 DBOperation dboperation= new DBOperation(); //获取数据库 Connection connection=null; List<Student> list = new ArrayList<Student>(); try{ connection=dboperation.getConnection(); Statement st=connection.createStatement(); //查询语句 String sql="select* from student"; //查询语句执行exuecuteQuery,不是execte,执行后放回结果集resultset,把resultsest变成list,通过遍历实现 ResultSet rs=st.executeQuery(sql); //rs.next向下移动一行,刚开始在第0行。如果该行存在,返回true,否则会返回false, //每一行对应一个student对象,全部记录对应list //getInt,getString,getDate,getBoolean,获取该字段的值 //getInt(1),getInt("stuId") //可能有多条用while,最多用一条用if if(rs.next()){ Student student=new Student(); String stuId=rs.getString("stuId"); String stuName=rs.getString("stuName"); String stuPwd=rs.getString("stuPwd"); student.setStuId(stuId); student.setStuName(stuName); student.setStuPwd(stuPwd); //最后将student对象存放到集合中 list.add(student); } System.out.println(sql); return list; }catch(Exception ex){ ex.printStackTrace(); //返回上层判断 return null; }finally{ dboperation.closeConnect(connection); } } //重载 public static Student query(String id) { // TODO Auto-generated method stub //建立一个DBOperation,通过这个对象完成数据库的连接操作 DBOperation dbOperation=new DBOperation(); //获取数据库连接 Connection connction=null; try{ connction=dbOperation.getConnection(); Statement st=connction.createStatement(); //查询语句 String sql="select * from student where stuid='"+id+"'"; //查询语句执行exuecuteQuery,不是execute,执行后放回结果集resultset,把resultset变成list,通过遍历实现 ResultSet rs=st.executeQuery(sql); //可能有多条用while,最多一条就用if可以了。码农 Student student=null; if(rs.next()){ //如果有记录,新建一个student对象,将查到的结果封装到student对象中。 student=new Student(); String stuId=rs.getString("stuId"); String stuName=rs.getString("stuName"); String stuPwd=rs.getString("stuPwd"); student.setStuId(stuId); student.setStuName(stuName); student.setStuPwd(stuPwd); } return student; }catch(Exception ex){ ex.printStackTrace(); //返回上层判断 return null; }finally{ dbOperation.closeConnect(connction); } } public static void main(String args[]){ StudentDao studentDao=new StudentDao(); List<Student> list=studentDao.query(); //for each语句 iterator for(Student student:list){ System.out.println(student.getStuName()); } /*Student student=new Student(); student.setStuId("152118130235"); student.setStuName("徐耀辉"); student.setStuPwd("979194874");*/ } public int delete(String id) { // TODO Auto-generated method stub return 0; } }

如何维护并按照一定机制更新一张list?

连续读取人员信息并将其以map形式添加到list当中,如果list中的一条人员信息在30s内未能再一次读到,则将list中的该条信息清除,请问各位前辈有什么实现办法?谢谢!我我采用下面代码并未得到正确结果 ``` //确保list里面放的是不同对象map的堆地址,指向的是不同对象 Map<String, Object> map = new HashMap<String, Object>(); map.put("itemName", name); //注意此处不可将Bitmap对象直接放入hashmap中,而应传入地址 map.put("itemPhoto", photoPath); map.put("addTime",System.currentTimeMillis()); Log.v("map", map.toString()); //根据姓名查看list当中是否存在所有项 boolean exist = false; for(Map<String, Object> tempMap : list){ if(name.equals(tempMap.get("itemName"))){ exist = true; //如果有则更新时间 tempMap.put("addTime", System.currentTimeMillis()); break; } } //如果不存在,则添加到list当中 if(!exist){ list.add(map); } Log.v("removeb2",list.toString()); //遍历list查看有无超时项,有则清空该项 Iterator<Map<String, Object>> it = list.iterator(); while(it.hasNext()){ if(System.currentTimeMillis()-Long.parseLong(it.next().get("addTime").toString())>30000){ it.remove(); } } }; } //将定时任务中获取的List装入ListView中 Message msg = new Message(); msg.what = 1; handler.sendMessage(msg); ``` ``` switch (msg.what) { case 1: /*tv1.setText(null); tv2.setText(null); tv3.setText(null); img.setImageBitmap(null);*/ SimpleAdapter adapter = new SimpleAdapter(MainActivity.this,list,R.layout.activity_item, new String[]{"itemName","itemPhoto"},//查询键值获取map中资源 new int[]{R.id.itemName,R.id.itemPhoto});//将获取的资源填入对应项 adapter.notifyDataSetChanged();//刷新adapter从而达到刷新列表的目的。 lv.setAdapter(adapter); ```

初级玩转Linux+Ubuntu(嵌入式开发基础课程)

课程主要面向嵌入式Linux初学者、工程师、学生 主要从一下几方面进行讲解: 1.linux学习路线、基本命令、高级命令 2.shell、vi及vim入门讲解 3.软件安装下载、NFS、Samba、FTP等服务器配置及使用

我以为我对Mysql事务很熟,直到我遇到了阿里面试官

太惨了,面试又被吊打

Python代码实现飞机大战

文章目录经典飞机大战一.游戏设定二.我方飞机三.敌方飞机四.发射子弹五.发放补给包六.主模块 经典飞机大战 源代码以及素材资料(图片,音频)可从下面的github中下载: 飞机大战源代码以及素材资料github项目地址链接 ————————————————————————————————————————————————————————— 不知道大家有没有打过飞机,喜不喜欢打飞机。当我第一次接触这个东西的时候,我的内心是被震撼到的。第一次接触打飞机的时候作者本人是身心愉悦的,因为周边的朋友都在打飞机, 每

Python数据分析与挖掘

92讲视频课+16大项目实战+源码+¥800元课程礼包+讲师社群1V1答疑+社群闭门分享会=99元 &nbsp; 为什么学习数据分析? &nbsp; &nbsp; &nbsp; 人工智能、大数据时代有什么技能是可以运用在各种行业的?数据分析就是。 &nbsp; &nbsp; &nbsp; 从海量数据中获得别人看不见的信息,创业者可以通过数据分析来优化产品,营销人员可以通过数据分析改进营销策略,产品经理可以通过数据分析洞察用户习惯,金融从业者可以通过数据分析规避投资风险,程序员可以通过数据分析进一步挖掘出数据价值,它和编程一样,本质上也是一个工具,通过数据来对现实事物进行分析和识别的能力。不管你从事什么行业,掌握了数据分析能力,往往在其岗位上更有竞争力。 &nbsp;&nbsp; 本课程共包含五大模块: 一、先导篇: 通过分析数据分析师的一天,让学员了解全面了解成为一个数据分析师的所有必修功法,对数据分析师不在迷惑。 &nbsp; 二、基础篇: 围绕Python基础语法介绍、数据预处理、数据可视化以及数据分析与挖掘......这些核心技能模块展开,帮助你快速而全面的掌握和了解成为一个数据分析师的所有必修功法。 &nbsp; 三、数据采集篇: 通过网络爬虫实战解决数据分析的必经之路:数据从何来的问题,讲解常见的爬虫套路并利用三大实战帮助学员扎实数据采集能力,避免没有数据可分析的尴尬。 &nbsp; 四、分析工具篇: 讲解数据分析避不开的科学计算库Numpy、数据分析工具Pandas及常见可视化工具Matplotlib。 &nbsp; 五、算法篇: 算法是数据分析的精华,课程精选10大算法,包括分类、聚类、预测3大类型,每个算法都从原理和案例两个角度学习,让你不仅能用起来,了解原理,还能知道为什么这么做。

如何在虚拟机VM上使用串口

在系统内核开发中,经常会用到串口调试,利用VMware的Virtual Machine更是为调试系统内核如虎添翼。那么怎么搭建串口调试环境呢?因为最近工作涉及到这方面,利用强大的google搜索和自己

程序员的兼职技能课

获取讲师答疑方式: 在付费视频第一节(触摸命令_ALL)片头有二维码及加群流程介绍 限时福利 原价99元,今日仅需39元!购课添加小助手(微信号:csdn590)按提示还可领取价值800元的编程大礼包! 讲师介绍: 苏奕嘉&nbsp;前阿里UC项目工程师 脚本开发平台官方认证满级(六级)开发者。 我将如何教会你通过【定制脚本】赚到你人生的第一桶金? 零基础程序定制脚本开发课程,是完全针对零脚本开发经验的小白而设计,课程内容共分为3大阶段: ①前期将带你掌握Q开发语言和界面交互开发能力; ②中期通过实战来制作有具体需求的定制脚本; ③后期将解锁脚本的更高阶玩法,打通任督二脉; ④应用定制脚本合法赚取额外收入的完整经验分享,带你通过程序定制脚本开发这项副业,赚取到你的第一桶金!

MFC一站式终极全套课程包

该套餐共包含从C小白到C++到MFC的全部课程,整套学下来绝对成为一名C++大牛!!!

C++语言基础视频教程

C++语言基础视频培训课程:本课与主讲者在大学开出的程序设计课程直接对接,准确把握知识点,注重教学视频与实践体系的结合,帮助初学者有效学习。本教程详细介绍C++语言中的封装、数据隐藏、继承、多态的实现等入门知识;主要包括类的声明、对象定义、构造函数和析构函数、运算符重载、继承和派生、多态性实现等。 课程需要有C语言程序设计的基础(可以利用本人开出的《C语言与程序设计》系列课学习)。学习者能够通过实践的方式,学会利用C++语言解决问题,具备进一步学习利用C++开发应用程序的基础。

北京师范大学信息科学与技术学院笔试10复试真题

北京师范大学信息科学与技术学院笔试,可以更好的让你了解北师大该学院的复试内容,获得更好的成绩。

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

网络工程师小白入门--【思科CCNA、华为HCNA等网络工程师认证】

本课程适合CCNA或HCNA网络小白同志,高手请绕道,可以直接学习进价课程。通过本预科课程的学习,为学习网络工程师、思科CCNA、华为HCNA这些认证打下坚实的基础! 重要!思科认证2020年2月24日起,已启用新版认证和考试,包括题库都会更新,由于疫情原因,请关注官网和本地考点信息。题库网络上很容易下载到。

Python界面版学生管理系统

前不久上传了一个控制台版本的学生管理系统,这个是Python界面版学生管理系统,这个是使用pycharm开发的一个有界面的学生管理系统,基本的增删改查,里面又演示视频和完整代码,有需要的伙伴可以自行下

软件测试2小时入门

本课程内容系统、全面、简洁、通俗易懂,通过2个多小时的介绍,让大家对软件测试有个系统的理解和认识,具备基本的软件测试理论基础。 主要内容分为5个部分: 1 软件测试概述,了解测试是什么、测试的对象、原则、流程、方法、模型;&nbsp; 2.常用的黑盒测试用例设计方法及示例演示;&nbsp; 3 常用白盒测试用例设计方法及示例演示;&nbsp; 4.自动化测试优缺点、使用范围及示例‘;&nbsp; 5.测试经验谈。

Tomcat服务器下载、安装、配置环境变量教程(超详细)

未经我的允许,请不要转载我的文章,在此郑重声明!!! 请先配置安装好Java的环境,若没有安装,请参照我博客上的步骤进行安装! 安装Java环境教程https://blog.csdn.net/qq_40881680/article/details/83585542 Tomcat部署Web项目(一)·内嵌https://blog.csdn.net/qq_40881680/article/d...

2019数学建模A题高压油管的压力控制 省一论文即代码

2019数学建模A题高压油管的压力控制省一完整论文即详细C++和Matlab代码,希望对同学们有所帮助

图书管理系统(Java + Mysql)我的第一个完全自己做的实训项目

图书管理系统 Java + MySQL 完整实训代码,MVC三层架构组织,包含所有用到的图片资源以及数据库文件,大三上学期实训,注释很详细,按照阿里巴巴Java编程规范编写

linux下利用/proc进行进程树的打印

在linux下利用c语言实现的进程树的打印,主要通过/proc下的目录中的进程文件,获取status中的进程信息内容,然后利用递归实现进程树的打印

微信小程序开发实战之番茄时钟开发

微信小程序番茄时钟视频教程,本课程将带着各位学员开发一个小程序初级实战类项目,针对只看过官方文档而又无从下手的开发者来说,可以作为一个较好的练手项目,对于有小程序开发经验的开发者而言,可以更好加深对小程序各类组件和API 的理解,为更深层次高难度的项目做铺垫。

[已解决]踩过的坑之mysql连接报“Communications link failure”错误

目录 前言 第一种方法: 第二种方法 第三种方法(适用于项目和数据库在同一台服务器) 第四种方法 第五种方法(项目和数据库不在同一台服务器) 总结 前言 先给大家简述一下我的坑吧,(我用的是mysql,至于oracle有没有这样的问题,有心的小伙伴们可以测试一下哈), 在自己做个javaweb测试项目的时候,因为买的是云服务器,所以数据库连接的是用ip地址,用IDE开发好...

人工智能-计算机视觉实战之路(必备算法+深度学习+项目实战)

系列课程主要分为3大阶段:(1)首先掌握计算机视觉必备算法原理,结合Opencv进行学习与练手,通过实际视项目进行案例应用展示。(2)进军当下最火的深度学习进行视觉任务实战,掌握深度学习中必备算法原理与网络模型架构。(3)结合经典深度学习框架与实战项目进行实战,基于真实数据集展开业务分析与建模实战。整体风格通俗易懂,项目驱动学习与就业面试。 建议同学们按照下列顺序来进行学习:1.Python入门视频课程 2.Opencv计算机视觉实战(Python版) 3.深度学习框架-PyTorch实战/人工智能框架实战精讲:Keras项目 4.Python-深度学习-物体检测实战 5.后续实战课程按照自己喜好选择就可以

2019 AI开发者大会

2019 AI开发者大会(AI ProCon 2019)是由中国IT社区CSDN主办的AI技术与产业年度盛会。多年经验淬炼,如今蓄势待发:2019年9月6-7日,大会将有近百位中美顶尖AI专家、知名企业代表以及千余名AI开发者齐聚北京,进行技术解读和产业论证。我们不空谈口号,只谈技术,诚挚邀请AI业内人士一起共铸人工智能新篇章!

机器学习初学者必会的案例精讲

通过六个实际的编码项目,带领同学入门人工智能。这些项目涉及机器学习(回归,分类,聚类),深度学习(神经网络),底层数学算法,Weka数据挖掘,利用Git开源项目实战等。

Python数据分析师-实战系列

系列课程主要包括Python数据分析必备工具包,数据分析案例实战,核心算法实战与企业级数据分析与建模解决方案实战,建议大家按照系列课程阶段顺序进行学习。所有数据集均为企业收集的真实数据集,整体风格以实战为导向,通俗讲解Python数据分析核心技巧与实战解决方案。

YOLOv3目标检测实战系列课程

《YOLOv3目标检测实战系列课程》旨在帮助大家掌握YOLOv3目标检测的训练、原理、源码与网络模型改进方法。 本课程的YOLOv3使用原作darknet(c语言编写),在Ubuntu系统上做项目演示。 本系列课程包括三门课: (1)《YOLOv3目标检测实战:训练自己的数据集》 包括:安装darknet、给自己的数据集打标签、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。 (2)《YOLOv3目标检测:原理与源码解析》讲解YOLOv1、YOLOv2、YOLOv3的原理、程序流程并解析各层的源码。 (3)《YOLOv3目标检测:网络模型改进方法》讲解YOLOv3的改进方法,包括改进1:不显示指定类别目标的方法 (增加功能) ;改进2:合并BN层到卷积层 (加快推理速度) ; 改进3:使用GIoU指标和损失函数 (提高检测精度) ;改进4:tiny YOLOv3 (简化网络模型)并介绍 AlexeyAB/darknet项目。

2021考研数学张宇基础30讲.pdf

张宇:博士,全国著名考研数学辅导专家,教育部“国家精品课程建设骨干教师”,全国畅销书《张宇高等数学18讲》《张宇线性代数9讲》《张宇概率论与数理统计9讲》《张宇考研数学题源探析经典1000题》《张宇考

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

DirectX修复工具V4.0增强版

DirectX修复工具(DirectX Repair)是一款系统级工具软件,简便易用。本程序为绿色版,无需安装,可直接运行。 本程序的主要功能是检测当前系统的DirectX状态,如果发现异常则进行修复

期末考试评分标准的数学模型

大学期末考试与高中的考试存在很大的不同之处,大学的期末考试成绩是主要分为两个部分:平时成绩和期末考试成绩。平时成绩和期末考试成绩总分一般为一百分,然而平时成绩与期末考试成绩所占的比例不同会导致出现不同

Vue.js 2.0之全家桶系列视频课程

基于新的Vue.js 2.3版本, 目前新全的Vue.js教学视频,让你少走弯路,直达技术前沿! 1. 包含Vue.js全家桶(vue.js、vue-router、axios、vuex、vue-cli、webpack、ElementUI等) 2. 采用笔记+代码案例的形式讲解,通俗易懂

c语言项目开发实例

十个c语言案例 (1)贪吃蛇 (2)五子棋游戏 (3)电话薄管理系统 (4)计算器 (5)万年历 (6)电子表 (7)客户端和服务器通信 (8)潜艇大战游戏 (9)鼠标器程序 (10)手机通讯录系统

相关热词 c#对文件改写权限 c#中tostring c#支付宝回掉 c#转换成数字 c#判断除法是否有模 c# 横向chart c#控件选择多个 c#报表如何锁定表头 c#分级显示数据 c# 不区分大小写替换
立即提问