详解Android中解析XML的方法

XML在各种开发中都广泛应用,Android也不例外。作为承载数据的一个重要角色,如何读写XML成为Android开发中一项重要的技能。今天就由我向大家介绍一下在Android平台下几种常见的XML解析和创建的方法。

在Android中,常见的XML解析器分别为SAX解析器、DOM解析器和PULL解析器,下面,我将一一向大家详细介绍。

SAX解析器:

SAX(Simple API for XML)解析器是一种基于事件的解析器,它的核心是事件处理模式,主要是围绕着事件源以及事件处理器来工作的。当事件源产生事件后,调用事件处理器相应的处理方法,一个事件就可以得到处理。在事件源调用事件处理器中特定方法的时候,还要传递给事件处理器相应事件的状态信息,这样事件处理器才能够根据提供的事件信息来决定自己的行为。
SAX解析器的优点是解析速度快,占用内存少。非常适合在Android移动设备中使用。

DOM解析器:

DOM是基于树形结构的的节点或信息片段的集合,允许开发人员使用DOM API遍历XML树、检索所需数据。分析该结构通常需要加载整个文档和构造树形结构,然后才可以检索和更新节点信息。
由于DOM在内存中以树形结构存放,因此检索和更新效率会更高。但是对于特别大的文档,解析和加载整个文档将会很耗资源。

PULL解析器:

PULL解析器的运行方式和SAX类似,都是基于事件的模式。不同的是,在PULL解析过程中,我们需要自己获取产生的事件然后做相应的操作,而不像SAX那样由处理器触发一种事件的方法,执行我们的代码。PULL解析器小巧轻便,解析速度快,简单易用,非常适合在Android移动设备中使用,Android系统内部在解析各种XML时也是用PULL解析器。

以上三种解析器,都是非常实用的解析器,我将会一一介绍。我们将会使用这三种解析技术完成一项共同的任务。

我们新建一个项目,项目结构如下:

我会在项目的assets目录中放置一个XML文档books.xml,内容如下:

<?xml version="1.0" encoding="utf-8"?>
<books>
  <book>
    <id>1001</id>
    <name>Thinking In Java</name>
    <price>80.00</price>
  </book>
  <book>
    <id>1002</id>
    <name>Core Java</name>
    <price>90.00</price>
  </book>
  <book>
    <id>1003</id>
    <name>Hello, Andriod</name>
    <price>100.00</price>
  </book>
</books> 

然后我们分别使用以上三种解析技术解析文档,得到一个List<Book>的对象,先来看一下Book.java的代码:

package com.scott.xml.model; 

public class Book {
  private int id;
  private String name;
  private float price; 

  public int getId() {
    return id;
  } 

  public void setId(int id) {
    this.id = id;
  } 

  public String getName() {
    return name;
  } 

  public void setName(String name) {
    this.name = name;
  } 

  public float getPrice() {
    return price;
  } 

  public void setPrice(float price) {
    this.price = price;
  } 

  @Override
  public String toString() {
    return "id:" + id + ", name:" + name + ", price:" + price;
  }
}

最后,我们还要把这个集合对象中的数据生成一个新的XML文档,如图:

生成的XML结构跟原始文档略有不同,是下面这种格式:

<?xml version="1.0" encoding="UTF-8"?>
<books>
  <book id="1001">
    <name>Thinking In Java</name>
    <price>80.0</price>
  </book>
  <book id="1002">
    <name>Core Java</name>
    <price>90.0</price>
  </book>
  <book id="1003">
    <name>Hello, Andriod</name>
    <price>100.0</price>
  </book>
</books>

接下来,就该介绍操作过程了,我们先为解析器定义一个BookParser接口,每种类型的解析器需要实现此接口。BookParser.java代码如下:

package com.scott.xml.parser; 

import java.io.InputStream;
import java.util.List; 

import com.scott.xml.model.Book; 

public interface BookParser {
  /**
   * 解析输入流 得到Book对象集合
   * @param is
   * @return
   * @throws Exception
   */
  public List<Book> parse(InputStream is) throws Exception; 

  /**
   * 序列化Book对象集合 得到XML形式的字符串
   * @param books
   * @return
   * @throws Exception
   */
  public String serialize(List<Book> books) throws Exception;
}

好了,我们就该一个一个的实现该接口,完成我们的解析过程。

使用SAX解析器:
SaxBookParser.Java代码如下:

package com.scott.xml.parser; 

import java.io.InputStream;
import java.io.StringWriter;
import java.util.ArrayList;
import java.util.List; 

import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import javax.xml.transform.OutputKeys;
import javax.xml.transform.Result;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.sax.SAXTransformerFactory;
import javax.xml.transform.sax.TransformerHandler;
import javax.xml.transform.stream.StreamResult; 

import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.AttributesImpl;
import org.xml.sax.helpers.DefaultHandler; 

import com.scott.xml.model.Book; 

public class SaxBookParser implements BookParser { 

  @Override
  public List<Book> parse(InputStream is) throws Exception {
    SAXParserFactory factory = SAXParserFactory.newInstance(); //取得SAXParserFactory实例
    SAXParser parser = factory.newSAXParser();         //从factory获取SAXParser实例
    MyHandler handler = new MyHandler();            //实例化自定义Handler
    parser.parse(is, handler);                 //根据自定义Handler规则解析输入流
    return handler.getBooks();
  } 

  @Override
  public String serialize(List<Book> books) throws Exception {
    SAXTransformerFactory factory = (SAXTransformerFactory) TransformerFactory.newInstance();//取得SAXTransformerFactory实例
    TransformerHandler handler = factory.newTransformerHandler();      //从factory获取TransformerHandler实例
    Transformer transformer = handler.getTransformer();           //从handler获取Transformer实例
    transformer.setOutputProperty(OutputKeys.ENCODING, "UTF-8");      // 设置输出采用的编码方式
    transformer.setOutputProperty(OutputKeys.INDENT, "yes");        // 是否自动添加额外的空白
    transformer.setOutputProperty(OutputKeys.OMIT_XML_DECLARATION, "no");  // 是否忽略XML声明 

    StringWriter writer = new StringWriter();
    Result result = new StreamResult(writer);
    handler.setResult(result); 

    String uri = "";  //代表命名空间的URI 当URI无值时 须置为空字符串
    String localName = ""; //命名空间的本地名称(不包含前缀) 当没有进行命名空间处理时 须置为空字符串 

    handler.startDocument();
    handler.startElement(uri, localName, "books", null); 

    AttributesImpl attrs = new AttributesImpl();  //负责存放元素的属性信息
    char[] ch = null;
    for (Book book : books) {
      attrs.clear(); //清空属性列表
      attrs.addAttribute(uri, localName, "id", "string", String.valueOf(book.getId()));//添加一个名为id的属性(type影响不大,这里设为string)
      handler.startElement(uri, localName, "book", attrs);  //开始一个book元素 关联上面设定的id属性 

      handler.startElement(uri, localName, "name", null); //开始一个name元素 没有属性
      ch = String.valueOf(book.getName()).toCharArray();
      handler.characters(ch, 0, ch.length);  //设置name元素的文本节点
      handler.endElement(uri, localName, "name"); 

      handler.startElement(uri, localName, "price", null);//开始一个price元素 没有属性
      ch = String.valueOf(book.getPrice()).toCharArray();
      handler.characters(ch, 0, ch.length);  //设置price元素的文本节点
      handler.endElement(uri, localName, "price"); 

      handler.endElement(uri, localName, "book");
    }
    handler.endElement(uri, localName, "books");
    handler.endDocument(); 

    return writer.toString();
  } 

  //需要重写DefaultHandler的方法
  private class MyHandler extends DefaultHandler { 

    private List<Book> books;
    private Book book;
    private StringBuilder builder; 

    //返回解析后得到的Book对象集合
    public List<Book> getBooks() {
      return books;
    } 

    @Override
    public void startDocument() throws SAXException {
      super.startDocument();
      books = new ArrayList<Book>();
      builder = new StringBuilder();
    } 

    @Override
    public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
      super.startElement(uri, localName, qName, attributes);
      if (localName.equals("book")) {
        book = new Book();
      }
      builder.setLength(0);  //将字符长度设置为0 以便重新开始读取元素内的字符节点
    } 

    @Override
    public void characters(char[] ch, int start, int length) throws SAXException {
      super.characters(ch, start, length);
      builder.append(ch, start, length); //将读取的字符数组追加到builder中
    } 

    @Override
    public void endElement(String uri, String localName, String qName) throws SAXException {
      super.endElement(uri, localName, qName);
      if (localName.equals("id")) {
        book.setId(Integer.parseInt(builder.toString()));
      } else if (localName.equals("name")) {
        book.setName(builder.toString());
      } else if (localName.equals("price")) {
        book.setPrice(Float.parseFloat(builder.toString()));
      } else if (localName.equals("book")) {
        books.add(book);
      }
    }
  }
}

代码中,我们定义了自己的事件处理逻辑,重写了DefaultHandler的几个重要的事件方法。下面我为大家着重介绍一下DefaultHandler的相关知识。DefaultHandler是一个事件处理器,可以接收解析器报告的所有事件,处理所发现的数据。它实现了EntityResolver接口、DTDHandler接口、ErrorHandler接口和ContentHandler接口。这几个接口代表不同类型的事件处理器。我们着重介绍一下ContentHandler接口。结构如图:

这几个比较重要的方法已被我用红线标注,DefaultHandler实现了这些方法,但在方法体内没有做任何事情,因此我们在使用时必须覆写相关的方法。最重要的是startElement方法、characters方法和endElement方法。当执行文档时遇到起始节点,startElement方法将会被调用,我们可以获取起始节点相关信息;然后characters方法被调用,我们可以获取节点内的文本信息;最后endElement方法被调用,我们可以做收尾的相关操作。

最后,我们需要调用SAX解析程序,这个步骤在MainActivity中完成:

package com.scott.xml;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.util.List; 

import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button; 

import com.scott.xml.model.Book;
import com.scott.xml.parser.BookParser;
import com.scott.xml.parser.SaxBookParser; 

public class MainActivity extends Activity { 

  private static final String TAG = "XML"; 

  private BookParser parser;
  private List<Book> books; 

  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main); 

    Button readBtn = (Button) findViewById(R.id.readBtn);
    Button writeBtn = (Button) findViewById(R.id.writeBtn); 

    readBtn.setOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View v) {
        try {
          InputStream is = getAssets().open("books.xml");
          parser = new SaxBookParser(); //创建SaxBookParser实例
          books = parser.parse(is); //解析输入流
          for (Book book : books) {
            Log.i(TAG, book.toString());
          }
        } catch (Exception e) {
          Log.e(TAG, e.getMessage());
        }
      }
    });
    writeBtn.setOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View v) {
        try {
          String xml = parser.serialize(books); //序列化
          FileOutputStream fos = openFileOutput("books.xml", Context.MODE_PRIVATE);
          fos.write(xml.getBytes("UTF-8"));
        } catch (Exception e) {
          Log.e(TAG, e.getMessage());
        }
      }
    });
  }
}

界面就两个按钮,顺便给大家贴上:

点击“readXML”按钮,将会调用SAX解析器解析文档,并在日志台打印相关信息:
然后再点击“writeXML”按钮,将会在该应用包下的files目录生成一个books.xml文件:

使用DOM解析器:
DomBookParser.java代码如下:

package com.scott.xml.parser; 

import java.io.InputStream;
import java.io.StringWriter;
import java.util.ArrayList;
import java.util.List; 

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.transform.OutputKeys;
import javax.xml.transform.Result;
import javax.xml.transform.Source;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult; 

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList; 

import com.scott.xml.model.Book; 

public class DomBookParser implements BookParser { 

  @Override
  public List<Book> parse(InputStream is) throws Exception {
    List<Book> books = new ArrayList<Book>();
    DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); //取得DocumentBuilderFactory实例
    DocumentBuilder builder = factory.newDocumentBuilder(); //从factory获取DocumentBuilder实例
    Document doc = builder.parse(is);  //解析输入流 得到Document实例
    Element rootElement = doc.getDocumentElement();
    NodeList items = rootElement.getElementsByTagName("book");
    for (int i = 0; i < items.getLength(); i++) {
      Book book = new Book();
      Node item = items.item(i);
      NodeList properties = item.getChildNodes();
      for (int j = 0; j < properties.getLength(); j++) {
        Node property = properties.item(j);
        String nodeName = property.getNodeName();
        if (nodeName.equals("id")) {
          book.setId(Integer.parseInt(property.getFirstChild().getNodeValue()));
        } else if (nodeName.equals("name")) {
          book.setName(property.getFirstChild().getNodeValue());
        } else if (nodeName.equals("price")) {
          book.setPrice(Float.parseFloat(property.getFirstChild().getNodeValue()));
        }
      }
      books.add(book);
    }
    return books;
  } 

  @Override
  public String serialize(List<Book> books) throws Exception {
    DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
    DocumentBuilder builder = factory.newDocumentBuilder();
    Document doc = builder.newDocument();  //由builder创建新文档 

    Element rootElement = doc.createElement("books"); 

    for (Book book : books) {
      Element bookElement = doc.createElement("book");
      bookElement.setAttribute("id", book.getId() + ""); 

      Element nameElement = doc.createElement("name");
      nameElement.setTextContent(book.getName());
      bookElement.appendChild(nameElement); 

      Element priceElement = doc.createElement("price");
      priceElement.setTextContent(book.getPrice() + "");
      bookElement.appendChild(priceElement); 

      rootElement.appendChild(bookElement);
    } 

    doc.appendChild(rootElement); 

    TransformerFactory transFactory = TransformerFactory.newInstance();//取得TransformerFactory实例
    Transformer transformer = transFactory.newTransformer();  //从transFactory获取Transformer实例
    transformer.setOutputProperty(OutputKeys.ENCODING, "UTF-8");      // 设置输出采用的编码方式
    transformer.setOutputProperty(OutputKeys.INDENT, "yes");        // 是否自动添加额外的空白
    transformer.setOutputProperty(OutputKeys.OMIT_XML_DECLARATION, "no");  // 是否忽略XML声明 

    StringWriter writer = new StringWriter(); 

    Source source = new DOMSource(doc); //表明文档来源是doc
    Result result = new StreamResult(writer);//表明目标结果为writer
    transformer.transform(source, result); //开始转换 

    return writer.toString();
  } 

}

然后再MainActivity中只需改一个地方:

readBtn.setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View v) {
    try {
      InputStream is = getAssets().open("books.xml");
//     parser = new SaxBookParser();
      parser = new DomBookParser();
      books = parser.parse(is);
      for (Book book : books) {
        Log.i(TAG, book.toString());
      }
    } catch (Exception e) {
      Log.e(TAG, e.getMessage());
    }
  }
});

执行结果是一样的。

使用PULL解析器:
PullBookParser.java代码如下:

package com.scott.xml.parser; 

import java.io.InputStream;
import java.io.StringWriter;
import java.util.ArrayList;
import java.util.List; 

import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlSerializer; 

import android.util.Xml; 

import com.scott.xml.model.Book; 

public class PullBookParser implements BookParser { 

  @Override
  public List<Book> parse(InputStream is) throws Exception {
    List<Book> books = null;
    Book book = null; 

//   XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
//   XmlPullParser parser = factory.newPullParser(); 

    XmlPullParser parser = Xml.newPullParser(); //由android.util.Xml创建一个XmlPullParser实例
    parser.setInput(is, "UTF-8");        //设置输入流 并指明编码方式 

    int eventType = parser.getEventType();
    while (eventType != XmlPullParser.END_DOCUMENT) {
      switch (eventType) {
        case XmlPullParser.START_DOCUMENT:
          books = new ArrayList<Book>();
          break;
        case XmlPullParser.START_TAG:
          if (parser.getName().equals("book")) {
            book = new Book();
          } else if (parser.getName().equals("id")) {
            eventType = parser.next();
            book.setId(Integer.parseInt(parser.getText()));
          } else if (parser.getName().equals("name")) {
            eventType = parser.next();
            book.setName(parser.getText());
          } else if (parser.getName().equals("price")) {
            eventType = parser.next();
            book.setPrice(Float.parseFloat(parser.getText()));
          }
          break;
        case XmlPullParser.END_TAG:
          if (parser.getName().equals("book")) {
            books.add(book);
            book = null;
          }
          break;
      }
      eventType = parser.next();
    }
    return books;
  } 

  @Override
  public String serialize(List<Book> books) throws Exception {
//   XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
//   XmlSerializer serializer = factory.newSerializer(); 

    XmlSerializer serializer = Xml.newSerializer(); //由android.util.Xml创建一个XmlSerializer实例
    StringWriter writer = new StringWriter();
    serializer.setOutput(writer);  //设置输出方向为writer
    serializer.startDocument("UTF-8", true);
    serializer.startTag("", "books");
    for (Book book : books) {
      serializer.startTag("", "book");
      serializer.attribute("", "id", book.getId() + ""); 

      serializer.startTag("", "name");
      serializer.text(book.getName());
      serializer.endTag("", "name"); 

      serializer.startTag("", "price");
      serializer.text(book.getPrice() + "");
      serializer.endTag("", "price"); 

      serializer.endTag("", "book");
    }
    serializer.endTag("", "books");
    serializer.endDocument(); 

    return writer.toString();
  }
}

然后再对MainActivity做以下更改:

readBtn.setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View v) {
    try {
      InputStream is = getAssets().open("books.xml");
//     parser = new SaxBookParser();
//     parser = new DomBookParser();
      parser = new PullBookParser();
      books = parser.parse(is);
      for (Book book : books) {
        Log.i(TAG, book.toString());
      }
    } catch (Exception e) {
      Log.e(TAG, e.getMessage());
    }
  }
});

和其他两个执行结果都一样。

对于这三种解析器各有优点,我个人比较倾向于PULL解析器,因为SAX解析器操作起来太笨重,DOM不适合文档较大,内存较小的场景,唯有PULL轻巧灵活,速度快,占用内存小,使用非常顺手。读者也可以根据自己的喜好选择相应的解析技术。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • android开发基础教程—三种方式实现xml文件解析

    1.sax方式 复制代码 代码如下: /** * 使用sax解析 */ public class SaxParse{ /** * sax解析器 */ private SAXParser parser; public SaxParse(){ try { SAXParserFactory f = SAXParserFactory.newInstance(); parser = f.newSAXParser(); } catch (ParserConfigurationException e) { e

  • 基于Android XML解析与保存的实现

    解析XML文件:在Android平台上可以使用SAX.DOM和Android附带的pull解析器解析XML文件:pull解析器提供了各种事件,使用parser.next()方法进入下一个元素并触发相应事件,pull解析器产生的事件是一个数字,可以通过switch对感兴趣的事件进行处理:通过paser.nextText()方法可以获取下一个Text类型的节点的值:http://xmlpull.org/xmlpull-website/impls.shtml; 读取XMLXmlPullParser p

  • Android 使用XML做动画UI的深入解析

    效果: http://www.56.com/u82/v_OTM4MDk5MTk.html第一步: 创建anim文件夹放置动画xml文件在res文件夹下,创建一个anim的子文件夹. 第二步: 加载动画接着在Activity创建一个Animation类,然后使用AnimationUtils类加载动画xml 复制代码 代码如下: Animation animFadein; @Overrideprotected void onCreate(Bundle savedInstanceState) { su

  • android通用xml解析方法

    1.为什么需要写一个通用xml解析方法. 当需要解析不同的xml节点.你有可能是在xml解析的时候匹配不同节点并且节点名都是写死的,这样的话你解析不同的节点就需要不同的解析方法.当然这种方式是最简单也是最笨的方法.为了减少代码把代码写得更有质量那么你就需要考虑设计一个通用的xml解析方法. 2.解析思路. 一般情况下,xml的解析结果最好放在一个实体类对象中,那样的话你使用起来非常方便(当然也更OO了),你也可以选择其他的方法把解析结果保存下来,不过个人觉得这种方式是比较好的.在解析过程中你需要

  • Android开发之XML文件解析的使用

    前言  本文主要介绍在Android中怎样来解析XML文件.主要采用的是SAX机制,SAX全称为Simple API for XML,它既是一种接口,也是一个软件包.作为接口,SAX是事件驱动型XML解析的一个标准接口.XML文件解析一般有2种方法,DOM和SAX.其中DOM需要先将xml文档全部读入到电脑内存中,当文档内容太大时,该方法并不适用.SAX就比较好的解决了该问题,它是逐行解析的,可以随时中断.但是SAX的操作比较复杂.因此,这2种方法各有优缺点,看具体应用情况.在前面的文章Qt学习

  • android编程之XML文件解析方法详解(附源码)

    本文实例讲述了android编程之XML文件解析方法.分享给大家供大家参考,具体如下: 在android开发中,经常用到去解析xml文件,常见的解析xml的方式有一下三种:SAX.Pull.Dom解析方式.最近做了一个android版的CSDN阅读器,用到了其中的两种(sax,pull),今天对android解析xml的这三种方式进行一次总结. 今天解析的xml示例(channels.xml)如下: <?xml version="1.0" encoding="utf-8

  • Android提高之XML解析与生成实例详解

    本文实例讲述了使用SAX来解析XML.通常来说在Android里面可以使用SAX和DOM,DOM需要把整个XML文件读入内存再解析,比较消耗内存,而SAX是基于事件驱动的处理方式,可以在各节点触发回调函数,不过SAX适合节点结构简单的XML文档,复杂的XML文档在后期的节点深度处理会有点麻烦. 本文要解析的test.xml文件如下: <?xml version="1.0" encoding="utf-8"?> <test> <title

  • Android XML数据解析简单示例

    1.创建XML数据 在android工程目录中res/目录下创建raw文件夹,在raw文件夹内创建data.xml. 复制代码 代码如下: <?xml version="1.0" encoding="utf-8"?> <data>     <class>         <c studentNum="1">Android</c>         <c studentNum=&quo

  • Android解析服务器端发来的xml数据示例

    Android跟服务器交互数据,有时数据量大时,就需要以xml形式的交互数据.这里来实现服务器给Android客户端发送xml数据,Android客户端解析. 服务器端我使用dom4j第三方包来组织xml数据,大家可自行百度下载.而Android客户端则使用 XmlPullParser来解析xml数据. 服务器端代码: 复制代码 代码如下: package servlet; import java.io.IOException; import java.io.PrintWriter; impor

  • 详解Android中解析XML的方法

    XML在各种开发中都广泛应用,Android也不例外.作为承载数据的一个重要角色,如何读写XML成为Android开发中一项重要的技能.今天就由我向大家介绍一下在Android平台下几种常见的XML解析和创建的方法. 在Android中,常见的XML解析器分别为SAX解析器.DOM解析器和PULL解析器,下面,我将一一向大家详细介绍. SAX解析器: SAX(Simple API for XML)解析器是一种基于事件的解析器,它的核心是事件处理模式,主要是围绕着事件源以及事件处理器来工作的.当事

  • 详解Android中Intent的使用方法

    一.Intent的用途 Intent主要有以下几种重要用途: 1. 启动Activity:可以将Intent对象传递给startActivity()方法或startActivityForResult()方法以启动一个Activity,该Intent对象包含了要启动的Activity的信息及其他必要的数据. 2. 启动Service:可以将Intent对象传递给startService()方法或bindService()方法以启动一个Service,该Intent对象包含了要启动的Service的

  • 详解Android中Notification的使用方法

    在消息通知的时候,我们经常用到两个控件Notification和Toast.特别是重要的和需要长时间显示的信息,用Notification最合适不过了.他可以在顶部显示一个图标以标示有了新的通知,当我们拉下通知栏的时候,可以看到详细的通知内容.       最典型的应用就是未看短信和未接来电的显示,还有QQ微信,我们一看就知道有一个未接来电或者未看短信,收到QQ离线信息.同样,我们也可以自定义一个Notification来定义我们自己的程序想要传达的信息. Notification我把他分为两种

  • 详解Android中IntentService的使用方法

    为什么我们需要IntentService ? Android中的IntentService是继承自Service类的,在我们讨论IntentService之前,我们先想一下Service的特点: Service的回调方法(onCreate.onStartCommand.onBind.onDestroy)都是运行在主线程中的.当我们通过startService启动Service之后,我们就需要在Service的onStartCommand方法中写代码完成工作,但是onStartCommand是运行

  • 详解Android之解析XML文件三种方式(DOM,PULL,SAX)

    1.xml文件代码 <?xml version="1.0" encoding="UTF-8" ?> <%@ page language="java" contentType="text/xml; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib uri="http://java.sun.com/jsp/jstl/core

  • 详解Android中Handler的使用方法

    在Android开发中,我们经常会遇到这样一种情况:在UI界面上进行某项操作后要执行一段很耗时的代码,比如我们在界面上点击了一个"下载"按钮,那么我们需要执行网络请求,这是一个耗时操作,因为不知道什么时候才能完成.为了保证不影响UI线程,所以我们会创建一个新的线程去执行我们的耗时的代码.当我们的耗时操作完成时,我们需要更新UI界面以告知用户操作完成了.所以我们可能会写出如下的代码: package ispring.com.testhandler; import android.app.

  • 详解Android中AsyncTask的使用方法

    在Android中实现异步任务机制有两种方式,Handler和AsyncTask. Handler模式需要为每一个任务创建一个新的线程,任务完成后通过Handler实例向UI线程发送消息,完成界面的更新,这种方式对于整个过程的控制比较精细,但也是有缺点的,例如代码相对臃肿,在多个任务同时执行时,不易对线程进行精确的控制. 为了简化操作,Android1.5提供了工具类android.os.AsyncTask,它使创建异步任务变得更加简单,不再需要编写任务线程和Handler实例即可完成相同的任务

  • 实例详解Android中JNI的使用方法

    目录 前言 1.导入C语言的类 2.接着导入Android.mk文件 3.我们配置一下build.gradle文件 4.好了,此时可以编译一下项目了 5.此时我们可以找一下我们生成的so包了 6.将生成的so文件拷入src/main/jniLibs中 7.调用C语言方法的Activity如下 总结 前言 做Android开发的程序员应该都知道,Android的开发语言我们都是在使用JAVA(Kotlin和Flutter我们暂时不考虑).但是,有时候我们也需要使用到C语言进行一些功能的开发.这个时

  • 详解Android中weight的使用方法

    android中对weight的学习可以说是必须的,如果UI布局仅仅使用dp与sp等等,会让布局显得极度不灵活,毕竟各个手机屏幕大小不同,更别说是还有ipad之类的了,所以也是同做本人近期做的一个小UI来分享一下weight的使用. 左边是各个屏幕的显示效果,右边是1080*1920屏幕的具体显示效果.可以看到,不管屏幕如何变化,使用weight的布局中总是填充满屏幕的,至于美观效果就不说了,直接上代码. 小编使用的android studio,eclipse用户直接复制肯定会有问题,AS用户直

  • 详解Android中接口回调、方法回调

    在Android开发中我们很多地方都用到了方法的回调,回调就是把方法的定义和功能导入实现分开的一种机制,目的是为了解耦他的本质是基于观察者设计模式,即观察者设计模式的的简化版,例如:在下载时候的进度回调,在adapter与activity之间的回调,在javabean和fragment以及fragment之间的回调等等,回调的目的主要有两个:其一是传递数据,其二是保持数据的同步更新.常用的有两种形式,一是使用内部类的形式,得到接口的子类对象,另一种是直接实现定义的接口. 一.内部类的形式 1.在

随机推荐