`

java 基础点滴(一)

阅读更多
1. --jdom 读取XML数据

package test.xy.jdom;

import org.jdom.*;
import org.jdom.input.*;
import org.jdom.output.*;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.util.List;
public class MyJDom {
    public static void main(String[] args) throws Exception{
        SAXBuilder sb=new SAXBuilder();//建立构造器
        Document doc=sb.build(new FileInputStream("src/xml/test.xml"));//读入指定文件
        Element root=doc.getRootElement();//获得根节点
        List list=root.getChildren();//将根节点下的所有子节点放入List中
        for(int i=0;i<list.size();i++) {
            System.out.println("---------------------------");
            Element item=(Element)list.get(i);//取得节点实例
            String id=item.getAttribute("id").getValue();//取得属性值
            System.out.println("id-->"+id);

            Element sub=item.getChild("title");//取得当前节点的字节点
            String text=sub.getText();//取得当前节点的值
             System.out.println("Title-->"+text);
            if(item.getChild("content").getChildren().size()>0){
            Element sub2=item.getChild("content").getChild("name");
            Element age=item.getChild("content").getChild("age");
                String text2=sub2.getText();
                String ageText=age.getText();
                System.out.println("the age is:"+ageText);
                System.out.println("name-->"+text2);
            }
           

            Element sub3=item.getChild("email");
            String text3=sub3.getText();
            System.out.println("Email-->"+text3);
        }
      }
}

<?xml version="1.0" encoding="UTF-8"?>
<messages>
<message id="1">
   <title>biaoti_1</title>
   <content>
    <name>zhanghua</name>
    <age>30</age>
   </content>
   <email>zhanghua123@126.com</email>
</message>
<message id="2">
   <title>biaoti_2</title>
   <content>
    <name>lining</name>
    <age>28</age>
   </content>
   <email>lining123@126.com</email>
</message>
</messages>

------------------------------- 1 结束----------------------

2.  -- jdom对XML(增,删,改,查)

  import java.io.FileInputStream;
	import java.io.FileNotFoundException;
	import java.io.FileOutputStream;
	import java.io.IOException;
	import java.io.InputStream;
	import java.io.OutputStream;
	import java.util.List;

	import org.jdom.Document;
	import org.jdom.Element;
	import org.jdom.JDOMException;
	import org.jdom.input.SAXBuilder;
	import org.jdom.output.XMLOutputter;

	/**
	 * 
	 */
	public class JavaXML {

	 
	 //解析xml文件
	 
	 public static void XmlParse() throws JDOMException, IOException {
	  SAXBuilder builder = new SAXBuilder();
	  InputStream file = new FileInputStream("src/xml/po.xml");
	  Document document = builder.build(file);//获得文档对象
	  Element root = document.getRootElement();//获得根节点
	  List<Element> list = root.getChildren();
	  for(Element e:list) {
	   System.out.println("ID="+e.getAttributeValue("id"));
	   System.out.println("username="+e.getChildText("username"));
	   System.out.println("password="+e.getChildText("password"));
	  }
	 }
	 
	 //增
	 public static void addXml() throws JDOMException, FileNotFoundException, IOException {
	  SAXBuilder builder = new SAXBuilder();
	  Document doc = builder.build("src/xml/po.xml");//获得文档对象
	  Element root = doc.getRootElement();//获得根节点
	  
	  //添加新元素
	  Element element = new Element("person");
	  element.setAttribute("id", "3");
	  Element element1 = new Element("username");
	  element1.setText("HONGWEI");
	  Element element2 = new Element("password");
	  element2.setText("mima");
	  element.addContent(element1);
	  element.addContent(element2);
	  root.addContent(element);
	  doc.setRootElement(root);
	  
	  //文件处理
	  XMLOutputter out = new XMLOutputter();
	  out.output(doc, new FileOutputStream("src/xml/po.xml"));
	 }
	 
	 //根据ID值删除一个节点 
	 public static void deletePerson(int id) throws JDOMException, IOException {
	  SAXBuilder builder = new SAXBuilder();
	  InputStream file = new FileInputStream("src/xml/po.xml");
	  Document doc = builder.build(file);//获得文档对象
	  Element root = doc.getRootElement();//获得根节点
	  List<Element> list = root.getChildren();
	  for(Element e:list) {
	   //获取ID值
	   if(Integer.parseInt(e.getAttributeValue("id"))==id) {
	    root.removeContent(e);
	    break;//??
	   }
	  }
	  
	  //文件处理
	  XMLOutputter out = new XMLOutputter();
	  out.output(doc, new FileOutputStream("src/xml/po.xml"));
	 }
	 
	 //根据ID值修改一个节点 
	 public static void updatePerson(int id) throws JDOMException, IOException {
	  SAXBuilder builder = new SAXBuilder();
	  InputStream file = new FileInputStream("src/xml/po.xml");
	  Document doc = builder.build(file);//获得文档对象
	  Element root = doc.getRootElement();//获得根节点
	  List<Element> list = root.getChildren();
	  for(Element e:list) {
	   //获取ID值
	   if(Integer.parseInt(e.getAttributeValue("id"))==id) {
	    System.out.println("--------------------");
	    e.getChild("username").setText("111111111");
	    e.getChild("password").setText("password");
	    
	   }
	  }
	  
	  //文件处理
	  XMLOutputter out = new XMLOutputter();
	  out.output(doc, new FileOutputStream("src/xml/po.xml"));
	 }
	 
	 static public void main(String ars[]) throws JDOMException, IOException {
	  
	  //addXml();//增加XML
	 // deletePerson(3);//删除XML
	 // updatePerson(2);//修改XML
	  //XmlParse();//解析XML
	 }
	}

<?xml version="1.0" encoding="UTF-8"?>
<root>
 <person id="1">
  <username>张三</username>
  <password>123123</password>
 </person>
 <person id="2">
  <username>1111111112</username>
  <password>password2</password>
 </person>

<person id="3">
<username>liming</username>
<password>mima</password></person>

<person id="3">
<username>liushan</username>
<password>mima</password></person>
</root>




----------------------- 2 结束 -------------------------------

3.  -- java split 与tokenizer的区别
          String sample1="ben        ben" ;    //其中连个ben之间间隔8个空格

           String[] split1 = sample1.split(" "); //通过一个空格隔离

           StringTokenizer tokens = new StringTokenizer(sample1, " "); 
         List ls = new ArrayList();
while(tokens.hasMoreTokens()){
String str = (String)tokens.nextElement();
ls.add(str);
}

结果:split1.length 为 9  ls.size 为 2
解释:如果用split进行分离的话,他会将空格也作为一个字符串存入数组, 而tokenizer不会

--------------------------- 3 结束-------------------------------------

4. 把不连续的数字按部分连续的段分组(代码见附件TestGroup.rar)

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Iterator;
import java.util.List;


public class TestGroup {
	public static void main(String args[]){
	int[] systemArray = {10,11,12,13,55,606,56,57,58,59,61,70,79,80,86,87,88,89,600,800};
	
	TestGroup test = new TestGroup();
	Arrays.sort(systemArray);
	List listGroup = (ArrayList) test.getSystemGroup(systemArray);
	System.out.println(" ------------begin----------");
	for(int i = 0; i < listGroup.size(); i++){
		
		List pageList = (List)listGroup.get(i); //get page
		
		System.out.println("current page is:" + i);
		System.out.println("页范围:" + pageList.get(0) + "--" + pageList.get(1));
		
	}
	System.out.println(" ------------end----------");	
	}
	//systemList 是排序过的不连续的系统号码
	public List<Object> getSystemGroup(int[] systemArray){
		
		List<Object> groupList = new ArrayList<Object>();//保存每段的pageList
		List<Integer> pageList = new ArrayList<Integer>();
		
		Integer pageMinNum = 0;//当前连续页系统号最小值
		Integer pageMaxNum = 0;//当前连续页系统号最大值
		
		//如果是连续的取(systemMin取首个数据)和(systemMax取第二个数据)保存到pageList.add
		//
		int systemArrayLen = systemArray.length;
		
		//如果当前数据和上一个数据是连续的数据,设置systemMaxNum = 当前数据,继续下一个数据判断,
		//连续的数据从systemMin到systemMin为一页。
		//连续的判断是当前数据+1 是否等于上一个数据。
		for(int i = 0; i < systemArrayLen; i++){		
			
			if(i == 0){
				pageList = new ArrayList<Integer>();
				pageMinNum = systemArray[i];
				pageMaxNum = systemArray[i];
				pageList = new ArrayList<Integer>();
				pageList.add(pageMinNum);
				pageList.add(pageMaxNum);
				groupList.add(pageList);
				//如果当前数据不是最后一个数据,则下一页的最小值是当前下一个数据( systemList.get(i+1) );
				if((i + 1) < systemArrayLen){
					pageMinNum = systemArray[i+1];
				}
				
			
			}else{
				
				int preSystemNum = 0;
				int currentSystemNum = 0;
				
				preSystemNum = systemArray[i-1];
				currentSystemNum = systemArray[i];
				//连续的数据,继续判断下一个
				if(currentSystemNum == (preSystemNum + 1)){
					pageMaxNum = currentSystemNum;
					
					//如果当前是最后一个数据,不再判断
					if(i == (systemArrayLen - 1) ){
						pageList = new ArrayList<Integer>();
						pageList.add(pageMinNum);
						pageList.add(pageMaxNum);
						groupList.add(pageList);
					}
					
				}
				else{//不连续的数据,只有一个的情况
					pageList = new ArrayList<Integer>();
					pageList.add(pageMinNum);
					pageList.add(pageMaxNum);
					groupList.add(pageList);
					
					//如果当前数据不是最后一个数据,则下一页的最小值是当前数据( currentSystemNum);
					if((i + 1) < systemArrayLen){
						pageMinNum = currentSystemNum;
						pageMaxNum = pageMinNum;//如果是不连续数据,只一页,设置最大值等于最小值。
					}
					
					//如果当前是最后一个数据,不再判断
					if(i == systemArrayLen - 1){
						pageMinNum = currentSystemNum;
						pageMaxNum = pageMinNum;//如果是不连续数据,只一页,设置最大值等于最小值。
						pageList = new ArrayList<Integer>();
						pageList.add(pageMinNum);
						pageList.add(pageMaxNum);
						groupList.add(pageList);
					}
				}
				
			}
								
		}
		
		return groupList;
		
	}
	
	
}


------------------------------- 4结束----------------------


5同步的例子

public class TestCurrentThread {

	private static int[]arrayb = new int[100];
	private static int countNum; //计数器
	
	private synchronized int addQueryNeCount(){
		
		
		if(countNum <= 2000){
			countNum += 20;
		}
		
		System.out.println(Thread.currentThread().getName()+" 当前线程查询出 countNum:" + countNum);
		return countNum;
		
	}
	
	private synchronized int abstractQueryNeCount(){
		
		
		if(countNum >= 0){
			countNum -= 30;
		}
		
		System.out.println(Thread.currentThread().getName()+" 当前线程查询出 countNum:" + countNum);
		return countNum;
		
	}
	
	//同步部件方法导致阻塞
	public  synchronized void printArraya(){
		
		//查询网元个数,如果网元个数大于60,当前线程阻塞
		int neCount = addQueryNeCount();
		
		while(neCount > 100){
			System.out.println(Thread.currentThread().getName()+"111111111111111111111111");
			System.out.println(Thread.currentThread().getName()+":当前部件线程被阻塞--count:"+countNum);
			try {
				wait();
				System.out.println(Thread.currentThread().getName()+"ccccccccccccccccccccccccccc");
			
			} catch (InterruptedException e) {
				
				e.printStackTrace();
			}
		}
		System.out.println(Thread.currentThread().getName()+":部件线程同步完成 --count:"+countNum);
	}
	
	//同步部件方法解除阻塞
	public  synchronized void printArrayb(){
		
		//查询网元个数,如果网元个数大于60,当前线程阻塞
		int neCount = abstractQueryNeCount();
		
		if(neCount >100){
			System.out.println(Thread.currentThread().getName()+":正在解除被阻塞的线程塞--count:"+countNum);
			
		}else{
			System.out.println(Thread.currentThread().getName()+":已经解除阻塞--count:"+countNum);
			notifyAll();
		}
	}
	
    public void test(){
    	System.out.println("当前线程:"+ Thread.currentThread().getName());
    	InnerBlockClass innerThread1 = new InnerBlockClass();
    	InnerBlockClass innerThread2 = new InnerBlockClass();
    	InnerBlockClass innerThread3 = new InnerBlockClass();
    	InnerBlockClass innerThread4= new InnerBlockClass();
		InnerBlockClass innerThread5 = new InnerBlockClass();
		InnerBlockClass innerThread6 = new InnerBlockClass();
		InnerBlockClass innerThread7 = new InnerBlockClass();
		InnerBlockClass innerThread8 = new InnerBlockClass();
		InnerBlockClass innerThread9 = new InnerBlockClass();
		
		innerThread1.start();
		innerThread2.start();
		innerThread3.start();
		innerThread4.start();
		innerThread5.start();
		innerThread6.start();
		innerThread7.start();
		innerThread8.start();
		innerThread9.start();
		
		
		
		InnerUnBlockClass innerOpenThread1 = new InnerUnBlockClass();
		InnerUnBlockClass innerOpenThread2 = new InnerUnBlockClass();
		InnerUnBlockClass innerOpenThread3 = new InnerUnBlockClass();
		InnerUnBlockClass innerOpenThread4= new InnerUnBlockClass();
		InnerUnBlockClass innerOpenThread5 = new InnerUnBlockClass();
		InnerUnBlockClass innerOpenThread6 = new InnerUnBlockClass();
		InnerUnBlockClass innerOpenThread7 = new InnerUnBlockClass();
		InnerUnBlockClass innerOpenThread8 = new InnerUnBlockClass();
		
		innerOpenThread1.start();
		innerOpenThread2.start();
		innerOpenThread3.start();
		innerOpenThread4.start();
		innerOpenThread5.start();
		innerOpenThread6.start();
		innerOpenThread7.start();
		innerOpenThread8.start();
    }
	public static void main(String args[]){
		TestCurrentThread test = new TestCurrentThread();
		test.test();
		
	}
	//导致阻塞的线程
	private class InnerBlockClass extends Thread{
		public void run(){
			printArraya();
		}
	}
	
	//解除阻塞的线程
	private class InnerUnBlockClass extends Thread{
		public void run(){
			printArrayb();
		}
	}
}





分享到:
评论

相关推荐

    图像去雾基于基于Matlab界面的(多方法对比,PSNR,信息熵,GUI界面).rar

    MATLAB设计

    c语言打字母游戏源码.zip

    c语言打字母游戏源码

    c语言做的一个任务管理器.zip

    c语言做的一个任务管理器

    JetBra-2021.1.x-重置.mp4.zip

    JetBra-2021.1.x-重置.mp4.zip

    小学班主任与家长沟通现状及改进策略研究

    内容概要:本文围绕小学班主任与家长沟通的现状进行了详尽分析,揭示了沟通方式不当、频率低、内容片面及理念不一致等问题,并基于访谈、文献研究及案例分析,提出了多元化的沟通方式、丰富沟通内容、讲究沟通艺术、转变家长观念和完善制度等多项策略,旨在提高家校合作的效能。 适合人群:从事小学教育教学的班主任、教师以及对家校合作感兴趣的教育工作者。 使用场景及目标:①通过本文提出的多种策略,改善小学班主任与家长之间的沟通;②促进家校互动,助力学生健康成长和发展;③推动教育领域的研究与发展。 阅读建议:本文详细阐述了沟通现状及具体问题,适合系统阅读。读者可根据实际情况,挑选适用于自身的沟通策略实施,并结合实例进行反思与改进。

    WSL批量压缩MP4文件对应Shell脚本文件

    WSL批量压缩MP4文件对应Shell脚本文件

    Java源码ssm框架的社区疫情防控管理系统-毕业设计论文-期末大作业.rar

    本项目是一个基于Java SSM框架的社区疫情防控管理系统,旨在通过信息化手段提升社区疫情防控的效率和准确性。系统集成了居民信息管理、健康监测、疫情上报、隔离管理等多项功能,能够实时跟踪和记录社区居民的健康状况,及时发现潜在的风险人员,并对其进行有效的隔离和管理。系统采用了Spring、Spring MVC和MyBatis三大框架技术,确保了系统的稳定性和扩展性。通过前端页面与后端逻辑的紧密配合,系统实现了数据的动态展示和交互操作,极大地方便了社区工作人员的日常工作。此外,系统还具备强大的数据统计和分析功能,能够帮助管理人员全面掌握社区的疫情动态,制定科学合理的防控措施。项目为完整毕设源码,先看项目演示,希望对需要的同学有帮助。

    Motorcad 外转子式42极36槽 永磁同步电机,直流无刷电机设计案例, 该电机55kw,220rpm,功率密度较高

    Motorcad 外转子式42极36槽 永磁同步电机,直流无刷电机设计案例,。 该电机55kw,220rpm,功率密度较高

    labview控制 西门子S7-1200 1214 dcdcdcplc 程序 plc只需要设置连接机制与IP即可 通讯为TCP IP协议

    labview控制 西门子S7-1200 1214 dcdcdcplc 程序 plc只需要设置连接机制与IP即可 通讯为TCP IP协议

    城市驾驶舱解决方案.pdf

    城市驾驶舱解决方案.pdf

    Shell教程v1.0中文PDF完整版最新版本

    Shell是一种用C语言编写的程序,它作为用户与Unix/Linux系统之间的桥梁,使得用户可以通过Shell完成大部分工作。Shell既是一个命令语言,也是一个程序设计语言。 本书《Shell教程》以简洁明了的语言向读者介绍Shell编程,旨在帮助读者迅速掌握Shell编程技能,并能够编写出实用的程序和代码,特别适合初学者学习。 **目录** - **前言** - **第1章 Shell简介** - 介绍Shell及其命令的两种执行方式。 - **第2章 常见的Shell类型** - **第3章 Shell与编译型语言的对比** - **第4章 Shell的使用场景** - **第5章 编写第一个Shell脚本** - **第6章 Shell变量** - 包括Shell变量的定义、删除、只读变量以及变量类型。 - **第7章 Shell特殊变量** - 讨论Shell中的$0, $#, $*, $@, $?, $$等特殊变量及其与命令行参数的关系。 - **第8章 Shell替换** - **第9章 Shell运算符** - 包括算数运算符、关系运算符、布尔运算

    CNC编程员个人简历模板

    CNC编程员个人简历模板

    机械设计摇摆喂料机 sw21全套设计资料100%好用.zip

    机械设计摇摆喂料机 sw21全套设计资料100%好用.zip

    拍打经络操mmexport1735392775826.mp4

    中医养生,拍打经络操全身轻松百病除

    2-趣味数学2.3.7 完全免费的数学学习软件

    【软件介绍】:趣味数学是一款完全免费的数学学习软件,无需注册登录,界面简约纯净。它支持多种分类学习,如趣味数学、数学初练、应用计算、数字推理、图形推理、数字2048、题目练习和数学知识等。其中,趣味数学含154个题目和关卡,数学初练含75个题目,应用计算含310个题目,数字推理含260个题目,图形推理含116个题目,数字2048含79个关卡。题目练习功能可按初中、高中选择,并细分学期与题目类型。数学知识合集功能涵盖初中和高中的各种知识点,共100个高中学习章节,每个章节包含多个知识点。软件不仅提供丰富的数学知识学习,还支持多类型的数学刷题,所有题目均配有答案和解析。

    基于Java 实现的Android手机平台的背单词软件,利用手机解锁记忆单词 锁屏背单词力争帮大家合理地利用好碎片时间,把原本无用的时间变得有用,把没有意义的事情(解锁)变得有意义

    【作品名称】:基于Java 实现的Android手机平台的背单词软件,利用手机解锁记忆单词。锁屏背单词力争帮大家合理地利用好碎片时间,把原本无用的时间变得有用,把没有意义的事情(解锁)变得有意义 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【项目介绍】: 主要功能 (1)背单词解锁:锁屏界面滑动单词解锁。 (2)语音朗读:单词真人发音。 (3)复习单词:内置专业的复习功能,有效巩固单词。 (4)学习记录:记录每日解锁次数和学习量,鼓励督促学习。 (5)生词本:卡片堆叠式记录学习不熟练和答错的单词并复习。 (6)词句翻译:查询陌生词句,了解释义与读音。 (7)锁屏壁纸选择:可选默认壁纸,也可选取手机相册照片作为锁屏壁纸。 (8)名人名句:每日一句名人名句。 【资源声明】:本资源作为“参考资料”而不是“定制需求”,代码只能作为参考,不能完全复制照搬。需要有一定的基础看懂代码,自行调试代码并解决报错,能自行添加功能修改代码。

    微信小程序源码-智慧旅游平台开发微信小程序-微信端-毕业设计源码-期末大作业.zip

    本项目是围绕智慧旅游平台开发的微信小程序,旨在为游客提供更为便捷、全面的旅游信息服务。通过该小程序,用户可以轻松查询旅游景点信息、预订门票和酒店,同时还能获取实时天气、交通指南等实用数据,极大提升了旅游的便利性和趣味性。 在功能方面,小程序集成了地图导航、旅游攻略、在线支付等多项实用功能,用户可以根据自身需求灵活选择使用。框架方面,项目采用了微信小程序原生开发框架,确保了良好的用户体验和流畅的操作性能。 此外,该项目还融入了数据分析功能,帮助旅游管理部门更好地了解游客需求,优化旅游资源配置。项目的开发不仅锻炼了学生的实践能力,也为智慧旅游平台的建设提供了有力支持。项目为完整毕设源码,先看项目演示,希望对需要的同学有帮助。

    matlab-B样条轨迹规划-1 七次非均匀B样条轨迹规划, 基于NSGAII的时间-能量-冲击最优 上自己的关节值和时间就能用,简单好用,

    matlab-B样条轨迹规划-1 七次非均匀B样条轨迹规划, 基于NSGAII的时间-能量-冲击最优。 上自己的关节值和时间就能用,简单好用,

    基于springboot的餐品美食论坛源码(java毕业设计完整源码).zip

    项目均经过测试,可正常运行! 环境说明: 开发语言:java JDK版本:jdk1.8 框架:springboot 数据库:mysql 5.7/8 数据库工具:navicat 开发软件:eclipse/idea

    基于点分布模型集合的方法用于小鼠脑基因表达图像分割

    内容概要:本文提出了一种名为PDM-ENLOR的新方法,解决了统计形状模型(如Active Shape Models)在复杂形状表示中的局限性。PDM-ENLOR通过使用一系列局部回归模型来独立定位每个标志点,利用选定的显着标志点作为解释变量,并通过几何约束编码来提高模型灵活性。该方法在小鼠脑基因表达图像的多区域分割任务上表现优异,整体重叠率达到了88.1%,标准偏差为9.5%。 适合人群:医学图像分析研究人员、生物医学工程专业学生以及对图像分割和机器学习感兴趣的科研人员。 使用场景及目标:该方法适用于需要对复杂形状进行高精度分割的场景,特别是在缺乏明确边界特征的医学图像数据集中。其目标是在不牺牲模型灵活度的前提下,减少因噪声和图像复杂性导致的检测误差。 其他说明:本文提供了详细的实验验证和比较,包括不同模型设置下的性能评估,验证了PDM-ENLOR在多种相似性度量指标下的鲁棒性和有效性。此外,文章还讨论了方法的局限性和未来改进方向。

Global site tag (gtag.js) - Google Analytics