当前位置: 编程技术>移动开发
本页文章导读:
▪jar资料打包 jar文件打包
今天在学习打jar包。
主要目的是我想在windows下面测试通过了jar包后,再将其放在linux下运行。
我在windows下面通过cmd运行的时候出现了一个问题。我以普通的打jar的方式将jar包打.........
▪ xcode4 施用经验 xcode4 使用经验
1、编译器对内存管理的支持
在雪豹XCode4下,其对应编译器没有Objective-C Automatic Reference Counting
在狮子XCode4.2下,新建项目,编译器版本=APPLE LLVM compiler 3.0,Objective-C Automatic Refe.........
▪ 2、dom4j解析 二、dom4j解析
一:构建dom4j树(表示为Document 元素)常用方法:方式一:直接创建所有元素:dom4j为我们准备了工具类DocumentHelper ,该类的所有的方法都是静态方法,用来创建xml文档的各个.........
[1]jar资料打包
来源: 互联网 发布时间: 2014-02-18
jar文件打包
今天在学习打jar包。
主要目的是我想在windows下面测试通过了jar包后,再将其放在linux下运行。
我在windows下面通过cmd运行的时候出现了一个问题。我以普通的打jar的方式将jar包打出,但是当前目录引用了另外一个第三方的jar文件,所以导致我在运行的时候程序一直提示找不到那个第三方的jar包。于是我到网上找资料如何将jar包导入进来,主要是用到了下面的方式:
win32 java -Xbootclasspath/a: some.jar;some2.jar; -jar test.jar
unix java -Xbootclasspath/a: some.jar:some2.jar: -jar test.jar
上面的摘抄来自http://www.iteye.com/topic/332580。
但是程序还是报错。于是问了同事,他给我的解决方式是
InputStream inStream = Test.class.getResourceAsStream("/config/log4j.properties");
Properties props = new Properties();
props.load(inStream);
PropertyConfigurator.configure(props);
Properties props = new Properties();
props.load(inStream);
PropertyConfigurator.configure(props);
之前的语句是这样写的PropertyConfigurator.configure(Test.class.getResource("/config/log4j.properties").getFile());
改了之后将log的jar包放到运行的jar的目录下。然后再次运行程序,测试通过。
另外一个解决的方式是打包的时候选择打包成Runnable JAR file。这样就不会出现上面的问题了。
在此感谢我的两位同事。^-^~~
[2] xcode4 施用经验
来源: 互联网 发布时间: 2014-02-18
xcode4 使用经验
1、编译器对内存管理的支持
在雪豹XCode4下,其对应编译器没有Objective-C Automatic Reference Counting
在狮子XCode4.2下,新建项目,编译器版本=APPLE LLVM compiler 3.0,Objective-C Automatic Reference Counting默认内存管理
个人建议在开发手机版程序,内存管理仍有人工管理。Mac电脑平台下可以启用此标记
2、静态库的引用
在雪豹Xcode4下,必须手工引用系统和非系统库
在狮子XCode4.2下,系统库似乎自动引用找寻,不需要手工引用;非系统自带库,仍需要手工引用
3、一个问题的引发:Xcode4.2下编译“ASIHTTPRequest”开源项目的代码时,出现“Declaration of 'struct sockaddr_in' will not be visible outside of this function”
在XCode4下没有出现此问题
解决办法:#import <netinet/in.h>
此问题解决地址参考:https://github.com/pokeb/asi-http-request/pull/218
[3] 2、dom4j解析
来源: 互联网 发布时间: 2014-02-18
二、dom4j解析
一:构建dom4j树(表示为Document 元素)
常用方法:
方式一:直接创建所有元素:dom4j为我们准备了工具类DocumentHelper ,该类的所有的方法都是静态方法,用来创建xml文档的各个组成部分。
1.1.1创建Document 和Element对象:
Document doc=DocumentHelper.createDocument();
Element eltRoot=DocumentHelper.createElement(“student”);
doc.setEltRootElement(eltRoot);
1.1.2或者先准备好根元素,使用有参数的构造方法创建Document对象。
Element eltRoot=DocumentHelper.createElement(“student”);
Document doc=DocumentHelper.createDocument(eltRoot);
1.2:添加节点和设置节点内容:
方法:Branch 接口中定义的方法;
public Element addElemen(String name) //以指定的name 为当前节点创建一个子节点,并返回新节点的引用
public void setText(String text) //将content设置为节点的内容
示例如下:
Element eltName=eltRoot.addElement(“name”);
Element eltAge=eltRoot.addElement(“age”);
eltName.setText(“张三”);
eltAge.setText(“18”);
1.3:添加属性
方法:public Element addAttribute(String name,String value)
示例如下:
eltRoot.addAttribute(“sn”,”01”);
方式2:
2.1:org.dom4j.io提供了两个类:SAXReader和DOMReader,前者从一个现有的w3c DOM树构建dom4j树,而SAXReader则使用SAX解析器,从不同的输入源构建dom4j树。
2.1.1: 使用 SAXReader 构建dom4j文档对象:示例如下:
SAXReader saxReader=new SAXReader();
File file=new File(“student.xml”);
Document doc=saxReader.read(file);
2.2.1:使用DOMReader 构建dom4j 文档对象.
DocumentBuilderFactory dbf=new DocumentBuilderFactory.newInstance();
DocumentBuilder db=dbf.newDocumentBuilder();
File file=new File(“student.xml”);
org.w3c.dom.Document document=db.parse(file);
DOMReader domReader=new DOMReader();
org.dom4j.Document doc=domReader.read(document);
访问根节点:
Element root=doc.getRootElement();
访问节点:
访问所有节点:
java.util.List childrenList=elt.elements();
访问指定名称的所有节点
java.util.Liat childrenList=elt.elements(“student”);
访问指定名称第一个节点
Element eltChild=elt.element(“student”);
要迭代某个元素的所有子元素:
for(java.util.Iterator it=root.elementIterator();it.hasNext()){
Element element =it.hasNext();
……
}
Dom4j 中集成了对XPath的支持。在选择节点时,可以直接使用XPath 表达式,例如:
要选择例子文件 students.xml中的所有的<name>元素,代码如下:
java.util.List l=root.selectNodes(“//name”);
要选择属性sn的值等于01的<student>元素,代码如下:
java.util.List l=root.selectNodes(“//student[@sn=’01’]”);
注意:为了能够编译执行上述使用XPath表达式的代码,需要配置dom4j 安装包中自带的jaxen包,你也可以从http://sourceforge.net/products/jaxen/上下载jaxen。jaxen是一个用java开发的XPath引擎,用于配合各种基于XML的对象模型,如DOM,dom4j和JDOM。在dom4-1.6.1 目录下,有一个lib 子目录,其中有个jaxen-1.1-beta-6.jar文件,需要在classpath环境变量中配置该文件的全路径名。
访问属性:
要得到某个元素的所有属性,,如下:
java.util.List attrList=elt.attributes();
要得到指定的属性,如下:
Attribute attr=elt.attribute(“sn”);
要得到某个属性的值;如下:
String attrValue=elt.attributeValue(“sn”);
删除节点和节点的属性:
要删除某个元素::可以用Branch接口中定义的remove()方法,如下:
Element eltStu=root.element(“student”);
root.remove(eltStu);
要删除某个属性;如下:
elt.remove(elt.attribute(“sn”));
输出文档:
对象:XMLWriter 实例方法:write(Document doc)
常用的几种构造方法总结:
1:无参数:
2:字节流参数
3:字符流参数。
4:文档输出格式类参数。
示例代码1:
输出文档内容到控制台
XMLWriter xw=new XMLWriter();
xw.write(doc);
示例代码2:
输出文档内容到文件。构造XMLWriter 对象的时候,可以传递字节流参数。其底层代码设置了自动刷新机制。
XMLWriter xw=new XMLWriter(new java.io.FileOutputStream(“student.xml”));
xw.write(doc);
示例代码3:
构造XMLWriter 对象的时候,可以传递java.io.Writer对象。
XMLWriter xw=new XMLWriter(new java.io.FileWriter(“student.xml”));
xw.write(doc);
xw.close();
注意:使用java.io.Writer对象构建的XMLWriter对象,则没有设置自动刷新机制,所以在调用write()方法之后,还要调用xw.close()或者xw.flush()方法。并且XMLWriter 继承自org.xml.sax.helpers.XMLFilterImpl类。它所提供的close()和flush()方法只是其内部java.io.Writer 对象的flush()和close()方法的封装方法。
示例代码4:
构造XMLWriter 对象的时候,可以传递文档输出格式类org.dom4j.io.OutputFormat,利用这个类,可以设置输出文档的字符编码,设置行分割符以及控制使用的缩进字符串等。
下面的代码输出格式使用4个空格作为缩进字符串,元素之间添加新行。
OutputFormat outFmt=new OutputFormat(“ ”,true);
XMLWriter xw=new XMLWriter(outFmt);
xw.write(doc);
下面的代码采用美化的格式输出文档,设置字符串编码为GB2312,并且用4个空格作为缩进。
OutputFormat outFmt=OutputFormat.createPrettyPrint();
outFmt.setEncoding(“GB2312”);
outFmt.setIndent(“ ”);
XMLWriter xw=new XMLWriter(outFmt);
xw.write(doc);
dom4j的名称空间 信息api
常用的方法有8个。
dom4j在Element和Attribute 接口中定义了获取名称空间信息的方法,这些方法和JDOM中的方法相同。如下所示:
public java.lang.String getNamespacePrefix()
该方法返回元素(属性)的名称空间前缀
public java.lang.String getNamespaceURI()
该方法返回元素(属性)的名称空间URI
public java.lang.String getName()
该方法返回元素(属性)的本地名
public java.lang.String getQualifiedName()
该方法返回元素(属性)的限定名
public Namespace getNamespace()
该方法返回元素本身的名称空间
public java.util.List additionalNamespaces()
返回某元素上附加的名称空间声明列表,列表中的每一个对象都是Namespace类型。这个类的方法提供了两个方法分别获得名称空间前缀和本地名。如下:
public java.lang.String getPrefix()
该方法返回名称空间前缀。
public java.lang.String getURI()
该方法返回名称空间的URI。
---------------------------------------------------
DOM4J解析技术
一. Document对象相关
(1) 读取XML文件,获得document对象
eg ->
SAXReader reader = new SAXReader();
Document document = reader.read(new File(emp.xml"));
(2) 解析XML形式的文本,得到document对象
eg ->
String text = "元素";
Document document = DocumentHelper.parseText(text);
(3) 主动创建document对象
eg ->
Document document = DocumentHelper.createDocument();
Element root = document.addElement("members");// 创建根节点
二. 节点相关
(1) 获取文档的根节点.
eg ->
SAXReader reader = new SAXReader();
Document document = reader.read(new File(emp.xml"));
(2) 取得某节点的单个子节点
eg ->
Element memberElm=root.element("member");// "member"是节点名
(3) 取得节点的文字
eg ->
DString text=memberElm.getText();
或者:
eg ->
String text=root.elementText("name");//这个是取得根节点下的name字节点的文字
(4) 取得某节点下名为"member"的所有字节点并进行遍历
eg ->
List nodes = rootElm.elements("member");
for (Iterator it = nodes.iterator(); it.hasNext();) {
Element elm = (Element) it.next(); // do something
}
(5)对某节点下的所有子节点进行遍历
eg ->
for(Iterator it=root.elementIterator();it.hasNext();){
Element element = (Element) it.next(); // do something
}
(6) 在某节点下添加子节点
eg ->
Element ageElm = newMemberElm.addElement("age");
(7)设置节点文字.
eg ->
ageElm.setText("29");
(8) 删除某节点
eg ->
parentElm.remove(childElm);// childElm是待删除的节点,parentElm是其父节点
(9)添加一个CDATA节点
eg ->
Element contentElm = infoElm.addElement("content");
contentElm.addCDATA(diary.getContent());
contentElm.getText(); // 特别说明:获取节点的CDATA值与获取节点的值是一个方法
contentElm.clearContent(); //清除节点中的内容,CDATA亦可
三 . 属性相关
(1)取得某节点下的某属性
eg ->
Element root=document.getRootElement();
Attribute attribute=root.attribute("size");// 属性名name
(2)取得属性的文字
eg ->
String text=attribute.getText();
或者: eg ->
String text2=root.element("name").attributeValue("firstname"); //这个是取得根节点下name字节点的属性firstname的值.
(3)遍历某节点的所有属性
eg ->
Element root=document.getRootElement();
for(Iterator it=root.attributeIterator();it.hasNext();){
Attribute attribute = (Attribute) it.next();
String text=attribute.getText();
System.out.println(text);
}
(4)设置某节点的属性和文字
eg ->
newMemberElm.addAttribute("name", "sitinspring");
(5) 设置属性的文字
eg ->
Attribute attribute=root.attribute("name");
attribute.setText("sitinspring");
(6)删除某属性
eg ->
Attribute attribute=root.attribute("size");// 属性名name
root.remove(attribute);
四 . 将文档写入XML文件
(1)文档中全为英文,不设置编码,直接写入的形式
eg ->
XMLWriter writer = new XMLWriter(new FileWriter("output.xml"));
writer.write(document);
writer.close();
(2)文档中含有中文,设置编码格式写入的形式
eg ->
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("GBK"); // 指定XML编码
XMLWriter writer = new XMLWriter(new FileWriter("output.xml"),format);
writer.write(document);
writer.close();
五 . 字符串与XML的转换
(1)将字符串转化为XML
eg ->
String text = " sitinspring ";
Document document = DocumentHelper.parseText(text);
(2)将文档或节点的XML转化为字符串
eg ->
SAXReader reader = new SAXReader();
Document document = reader.read(new File("input.xml"));
Element root=document.getRootElement();
String docXmlText=document.asXML();
String rootXmlText=root.asXML();
Element memberElm=root.element("member");
String memberXmlText=memberElm.asXML();
一:构建dom4j树(表示为Document 元素)
常用方法:
方式一:直接创建所有元素:dom4j为我们准备了工具类DocumentHelper ,该类的所有的方法都是静态方法,用来创建xml文档的各个组成部分。
1.1.1创建Document 和Element对象:
Document doc=DocumentHelper.createDocument();
Element eltRoot=DocumentHelper.createElement(“student”);
doc.setEltRootElement(eltRoot);
1.1.2或者先准备好根元素,使用有参数的构造方法创建Document对象。
Element eltRoot=DocumentHelper.createElement(“student”);
Document doc=DocumentHelper.createDocument(eltRoot);
1.2:添加节点和设置节点内容:
方法:Branch 接口中定义的方法;
public Element addElemen(String name) //以指定的name 为当前节点创建一个子节点,并返回新节点的引用
public void setText(String text) //将content设置为节点的内容
示例如下:
Element eltName=eltRoot.addElement(“name”);
Element eltAge=eltRoot.addElement(“age”);
eltName.setText(“张三”);
eltAge.setText(“18”);
1.3:添加属性
方法:public Element addAttribute(String name,String value)
示例如下:
eltRoot.addAttribute(“sn”,”01”);
方式2:
2.1:org.dom4j.io提供了两个类:SAXReader和DOMReader,前者从一个现有的w3c DOM树构建dom4j树,而SAXReader则使用SAX解析器,从不同的输入源构建dom4j树。
2.1.1: 使用 SAXReader 构建dom4j文档对象:示例如下:
SAXReader saxReader=new SAXReader();
File file=new File(“student.xml”);
Document doc=saxReader.read(file);
2.2.1:使用DOMReader 构建dom4j 文档对象.
DocumentBuilderFactory dbf=new DocumentBuilderFactory.newInstance();
DocumentBuilder db=dbf.newDocumentBuilder();
File file=new File(“student.xml”);
org.w3c.dom.Document document=db.parse(file);
DOMReader domReader=new DOMReader();
org.dom4j.Document doc=domReader.read(document);
访问根节点:
Element root=doc.getRootElement();
访问节点:
访问所有节点:
java.util.List childrenList=elt.elements();
访问指定名称的所有节点
java.util.Liat childrenList=elt.elements(“student”);
访问指定名称第一个节点
Element eltChild=elt.element(“student”);
要迭代某个元素的所有子元素:
for(java.util.Iterator it=root.elementIterator();it.hasNext()){
Element element =it.hasNext();
……
}
Dom4j 中集成了对XPath的支持。在选择节点时,可以直接使用XPath 表达式,例如:
要选择例子文件 students.xml中的所有的<name>元素,代码如下:
java.util.List l=root.selectNodes(“//name”);
要选择属性sn的值等于01的<student>元素,代码如下:
java.util.List l=root.selectNodes(“//student[@sn=’01’]”);
注意:为了能够编译执行上述使用XPath表达式的代码,需要配置dom4j 安装包中自带的jaxen包,你也可以从http://sourceforge.net/products/jaxen/上下载jaxen。jaxen是一个用java开发的XPath引擎,用于配合各种基于XML的对象模型,如DOM,dom4j和JDOM。在dom4-1.6.1 目录下,有一个lib 子目录,其中有个jaxen-1.1-beta-6.jar文件,需要在classpath环境变量中配置该文件的全路径名。
访问属性:
要得到某个元素的所有属性,,如下:
java.util.List attrList=elt.attributes();
要得到指定的属性,如下:
Attribute attr=elt.attribute(“sn”);
要得到某个属性的值;如下:
String attrValue=elt.attributeValue(“sn”);
删除节点和节点的属性:
要删除某个元素::可以用Branch接口中定义的remove()方法,如下:
Element eltStu=root.element(“student”);
root.remove(eltStu);
要删除某个属性;如下:
elt.remove(elt.attribute(“sn”));
输出文档:
对象:XMLWriter 实例方法:write(Document doc)
常用的几种构造方法总结:
1:无参数:
2:字节流参数
3:字符流参数。
4:文档输出格式类参数。
示例代码1:
输出文档内容到控制台
XMLWriter xw=new XMLWriter();
xw.write(doc);
示例代码2:
输出文档内容到文件。构造XMLWriter 对象的时候,可以传递字节流参数。其底层代码设置了自动刷新机制。
XMLWriter xw=new XMLWriter(new java.io.FileOutputStream(“student.xml”));
xw.write(doc);
示例代码3:
构造XMLWriter 对象的时候,可以传递java.io.Writer对象。
XMLWriter xw=new XMLWriter(new java.io.FileWriter(“student.xml”));
xw.write(doc);
xw.close();
注意:使用java.io.Writer对象构建的XMLWriter对象,则没有设置自动刷新机制,所以在调用write()方法之后,还要调用xw.close()或者xw.flush()方法。并且XMLWriter 继承自org.xml.sax.helpers.XMLFilterImpl类。它所提供的close()和flush()方法只是其内部java.io.Writer 对象的flush()和close()方法的封装方法。
示例代码4:
构造XMLWriter 对象的时候,可以传递文档输出格式类org.dom4j.io.OutputFormat,利用这个类,可以设置输出文档的字符编码,设置行分割符以及控制使用的缩进字符串等。
下面的代码输出格式使用4个空格作为缩进字符串,元素之间添加新行。
OutputFormat outFmt=new OutputFormat(“ ”,true);
XMLWriter xw=new XMLWriter(outFmt);
xw.write(doc);
下面的代码采用美化的格式输出文档,设置字符串编码为GB2312,并且用4个空格作为缩进。
OutputFormat outFmt=OutputFormat.createPrettyPrint();
outFmt.setEncoding(“GB2312”);
outFmt.setIndent(“ ”);
XMLWriter xw=new XMLWriter(outFmt);
xw.write(doc);
dom4j的名称空间 信息api
常用的方法有8个。
dom4j在Element和Attribute 接口中定义了获取名称空间信息的方法,这些方法和JDOM中的方法相同。如下所示:
public java.lang.String getNamespacePrefix()
该方法返回元素(属性)的名称空间前缀
public java.lang.String getNamespaceURI()
该方法返回元素(属性)的名称空间URI
public java.lang.String getName()
该方法返回元素(属性)的本地名
public java.lang.String getQualifiedName()
该方法返回元素(属性)的限定名
public Namespace getNamespace()
该方法返回元素本身的名称空间
public java.util.List additionalNamespaces()
返回某元素上附加的名称空间声明列表,列表中的每一个对象都是Namespace类型。这个类的方法提供了两个方法分别获得名称空间前缀和本地名。如下:
public java.lang.String getPrefix()
该方法返回名称空间前缀。
public java.lang.String getURI()
该方法返回名称空间的URI。
---------------------------------------------------
DOM4J解析技术
一. Document对象相关
(1) 读取XML文件,获得document对象
eg ->
SAXReader reader = new SAXReader();
Document document = reader.read(new File(emp.xml"));
(2) 解析XML形式的文本,得到document对象
eg ->
String text = "元素";
Document document = DocumentHelper.parseText(text);
(3) 主动创建document对象
eg ->
Document document = DocumentHelper.createDocument();
Element root = document.addElement("members");// 创建根节点
二. 节点相关
(1) 获取文档的根节点.
eg ->
SAXReader reader = new SAXReader();
Document document = reader.read(new File(emp.xml"));
(2) 取得某节点的单个子节点
eg ->
Element memberElm=root.element("member");// "member"是节点名
(3) 取得节点的文字
eg ->
DString text=memberElm.getText();
或者:
eg ->
String text=root.elementText("name");//这个是取得根节点下的name字节点的文字
(4) 取得某节点下名为"member"的所有字节点并进行遍历
eg ->
List nodes = rootElm.elements("member");
for (Iterator it = nodes.iterator(); it.hasNext();) {
Element elm = (Element) it.next(); // do something
}
(5)对某节点下的所有子节点进行遍历
eg ->
for(Iterator it=root.elementIterator();it.hasNext();){
Element element = (Element) it.next(); // do something
}
(6) 在某节点下添加子节点
eg ->
Element ageElm = newMemberElm.addElement("age");
(7)设置节点文字.
eg ->
ageElm.setText("29");
(8) 删除某节点
eg ->
parentElm.remove(childElm);// childElm是待删除的节点,parentElm是其父节点
(9)添加一个CDATA节点
eg ->
Element contentElm = infoElm.addElement("content");
contentElm.addCDATA(diary.getContent());
contentElm.getText(); // 特别说明:获取节点的CDATA值与获取节点的值是一个方法
contentElm.clearContent(); //清除节点中的内容,CDATA亦可
三 . 属性相关
(1)取得某节点下的某属性
eg ->
Element root=document.getRootElement();
Attribute attribute=root.attribute("size");// 属性名name
(2)取得属性的文字
eg ->
String text=attribute.getText();
或者: eg ->
String text2=root.element("name").attributeValue("firstname"); //这个是取得根节点下name字节点的属性firstname的值.
(3)遍历某节点的所有属性
eg ->
Element root=document.getRootElement();
for(Iterator it=root.attributeIterator();it.hasNext();){
Attribute attribute = (Attribute) it.next();
String text=attribute.getText();
System.out.println(text);
}
(4)设置某节点的属性和文字
eg ->
newMemberElm.addAttribute("name", "sitinspring");
(5) 设置属性的文字
eg ->
Attribute attribute=root.attribute("name");
attribute.setText("sitinspring");
(6)删除某属性
eg ->
Attribute attribute=root.attribute("size");// 属性名name
root.remove(attribute);
四 . 将文档写入XML文件
(1)文档中全为英文,不设置编码,直接写入的形式
eg ->
XMLWriter writer = new XMLWriter(new FileWriter("output.xml"));
writer.write(document);
writer.close();
(2)文档中含有中文,设置编码格式写入的形式
eg ->
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("GBK"); // 指定XML编码
XMLWriter writer = new XMLWriter(new FileWriter("output.xml"),format);
writer.write(document);
writer.close();
五 . 字符串与XML的转换
(1)将字符串转化为XML
eg ->
String text = " sitinspring ";
Document document = DocumentHelper.parseText(text);
(2)将文档或节点的XML转化为字符串
eg ->
SAXReader reader = new SAXReader();
Document document = reader.read(new File("input.xml"));
Element root=document.getRootElement();
String docXmlText=document.asXML();
String rootXmlText=root.asXML();
Element memberElm=root.element("member");
String memberXmlText=memberElm.asXML();
最新技术文章: