SAX解析 XML的Demo_"system.setproperty(\"org.xml.sax.driver\", \"org.-程序员宅基地

技术标签: android file  

下面我们就用上面介绍的 Java SDK 中的SAX 方式来实现解析 XML 形式的地震数据的 Demo例子。

三. 实例开发

我们要解析的为美国地质调查局USGS 提供的地震数据, xml 数据地址为:

http://earthquake.usgs.gov/earthquakes/catalogs/1day-M2.5.xml

http://earthquake.usgs.gov/earthquakes/catalogs/7day-M2.5.xml

http://earthquake.usgs.gov/earthquakes/catalogs/7day-M5.xml

分别为1 天以内 2.5 级以上、 7 天内 2.5 级以上和 7 天内 5 级以上地震数据。

Xml数据的格式如下所示:

[xhtml]  view plain copy
  1. <?xml version="1.0"?>  
  2. <feed xmlns="http://www.w3.org/2005/Atom" xmlns:georss="http://www.georss.org/georss">  
  3.   <updated>2010-09-15T04:41:18Z</updated>  
  4.   <title>USGS M2.5+ Earthquakes</title>  
  5.   <subtitle>Real-time, worldwide earthquake list for the past day</subtitle>  
  6.   <link rel="self" href="http://earthquake.usgs.gov/earthquakes/catalogs/1day-M2.5.xml" mce_href="http://earthquake.usgs.gov/earthquakes/catalogs/1day-M2.5.xml"/>  
  7.   <link href="http://earthquake.usgs.gov/earthquakes/" mce_href="http://earthquake.usgs.gov/earthquakes/"/>  
  8.   <author><name>U.S. Geological Survey</name></author>  
  9.   <id>http://earthquake.usgs.gov/</id>  
  10.   <icon>/favicon.ico</icon>  
  11.   <entry>  
  12.       <id>urn:earthquake-usgs-gov:ak:10078833</id>  
  13.       <title>M 2.9, Southern Alaska</title>  
  14.       <updated>2010-09-15T04:14:03Z</updated>  
  15.       <link rel="alternate" type="text/html" href="http://earthquake.usgs.gov/earthquakes/recenteqsww/Quakes/ak10078833.php" mce_href="http://earthquake.usgs.gov/earthquakes/recenteqsww/Quakes/ak10078833.php"/>  
  16.       <summary type="html">  
  17.         <!--[CDATA[<img src="http://earthquake.usgs.gov/images/globes/60_-155.jpg" mce_src="http://earthquake.usgs.gov/images/globes/60_-155.jpg" alt="59.909&#176;N 153.124&#176;W" align="left" hspace="20" /><p>Wednesday, September 15, 2010 04:14:03 UTC<br>Tuesday, September 14, 2010 08:14:03 PM at epicenter</p><p><b>Depth</b>: 98.90 km (61.45 mi)</p>]]-->  
  18.       </summary>  
  19.       <georss:point>59.9094 -153.1241</georss:point>  
  20.       <georss:elev>-98900</georss:elev>  
  21.       <category label="Age" term="Past hour"/>  
  22.   </entry>  
  23.    <entry>  
  24.     <!-- 还有entry条目,省略-->  
  25.   </entry>  
  26. </feed>  

下面我们就来完成用Java SAX 的方式解析以上 XML 形式的 USGS 地震数据的 Android 例子。

我们要完成的效果图如下图1 所示:

1 ListView 列表显示的地震数据

解析完地震数据后用ListView 列表的方式显示每条地震的震级和地名信息。

新建一个Android 工程 AndroidXMLDemoSax 。

首先新建添加一个类EarthquakeEntry ,用来保存一条地震信息,类的内容为:

[java]  view plain copy
  1. public class EarthquakeEntry {  
  2.     //定义变量  
  3.     private Date date;  
  4.     private Location location;  
  5.     private String place;  
  6.     private String link;  
  7.     private double magnitude;  
  8.     private double elev;  
  9.     //构造函数  
  10.     public EarthquakeEntry()  
  11.     {  
  12.           
  13.     }  
  14.     public EarthquakeEntry(Date _date, String _place, String _link, Location _location, double _magnitude, double _elev)  
  15.     {  
  16.         this.date = _date;  
  17.         this.location = _location;  
  18.         this.place = _place;  
  19.         this.link = _link;  
  20.         this.magnitude = _magnitude;  
  21.         this.elev = _elev;  
  22.     }     
  23.     //set方法  
  24.     public void setDate(Date _date)  
  25.     {  
  26.         this.date = _date;  
  27.     }  
  28.     public void setLocation(Location _location)  
  29.     {  
  30.         this.location = _location;  
  31.     }  
  32.     public void setPlace(String _place)  
  33.     {  
  34.         this.place = _place;  
  35.     }  
  36.     public void setLink(String _link)  
  37.     {  
  38.         this.link = _link;  
  39.     }  
  40.     public void setMagnitude(double _magnitude)  
  41.     {  
  42.         this.magnitude = _magnitude;  
  43.     }  
  44.     public void setElev(double _elev)  
  45.     {  
  46.         this.elev = _elev;  
  47.     }  
  48.     //get方法  
  49.     public Date getDate()  
  50.     {  
  51.         return this.date;  
  52.     }  
  53.     public Location getLocation()  
  54.     {  
  55.         return this.location;  
  56.     }  
  57.     public String getPlace()  
  58.     {  
  59.         return this.place;  
  60.     }  
  61.     public String getLink()  
  62.     {  
  63.         return this.link;  
  64.     }  
  65.     public double getMagnitude()  
  66.     {  
  67.         return this.magnitude;  
  68.     }  
  69.     public double getElev()  
  70.     {  
  71.         return this.elev;  
  72.     }  
  73.       
  74.     @Override  
  75.     public String toString() {  
  76.         String earthquakeString = " M" + magnitude + " " + place;  
  77.         return earthquakeString;  
  78.     }  
  79.     }  

比较简单,定义和一条地震内容对应的变量,并设置set 和 get 函数,并且重写 toString()函数在 ListView 输出时用。

 

接着新建添加一个类SaxEarthquakeHandler ,继承 DefaultHandler ,完成解析地震数据的具体逻辑实现,内容如下:

[java]  view plain copy
  1. public class SaxEarthquakeHandler extends DefaultHandler{  
  2.     //xml解析用到的Tag  
  3.     private String kEntryElementName = "entry";  
  4.     private String kLinkElementName = "link";  
  5.     private String kTitleElementName = "title";  
  6.     private String kUpdatedElementName = "updated";  
  7.     private String kGeoRSSPointElementName = "point";  
  8.     private String kGeoRSSElevElementName = "elev";  
  9.     //用于保存xml解析获取的结果  
  10.     private ArrayList<EarthquakeEntry> earthquakeEntryList;  
  11.     private EarthquakeEntry earthquakeEntry;  
  12.     private StringBuilder currentDataBuilder;  
  13.     private Boolean startEntryElementFlag = false;  
  14.       
  15.     //获取解析的地震列表  
  16.     public ArrayList<EarthquakeEntry> getEarthquakeEntryList()  
  17.     {  
  18.         return this.earthquakeEntryList;  
  19.     }  
  20.     //具体的xml解析回调函数  
  21.     @Override  
  22.     public void startDocument() throws SAXException {  
  23.         super.startDocument();  
  24.         //在开始解析时先创建实例  
  25.         earthquakeEntryList = new ArrayList<EarthquakeEntry>();  
  26.         currentDataBuilder = new StringBuilder();  
  27.     }  
  28.     @Override  
  29.     public void endDocument() throws SAXException {  
  30.         // TODO Auto-generated method stub  
  31.         Log.v("Sax""End");          
  32.     }  
  33.     //解析每一个标签Tag  
  34.     @Override  
  35.     public void startElement(String uri, String localName, String qName,  
  36.             Attributes attributes) throws SAXException {  
  37.         super.startElement(uri, localName, qName, attributes);  
  38. //      Log.v("Sax_StartElement", localName);  
  39.         if(localName.equalsIgnoreCase(kEntryElementName))  
  40.         {  
  41.             earthquakeEntry = new EarthquakeEntry();  
  42.             startEntryElementFlag = true;   
  43.         }  
  44.         else if ((localName.equalsIgnoreCase(kLinkElementName))&&(startEntryElementFlag == true)) {  
  45.             String relAttribute = attributes.getValue("rel");  
  46.             if(relAttribute.equalsIgnoreCase("alternate"))  
  47.             {  
  48.                 String webLink = attributes.getValue("href");  
  49.                 earthquakeEntry.setLink(webLink);  
  50.             }  
  51.         }  
  52.     }  
  53.     @Override  
  54.     public void characters(char[] ch, int start, int length)  
  55.             throws SAXException {  
  56.         super.characters(ch, start, length);  
  57.         currentDataBuilder.append(ch, start, length);  
  58.     }  
  59.     @Override  
  60.     public void endElement(String uri, String localName, String qName)  
  61.             throws SAXException {  
  62.         super.endElement(uri, localName, qName);  
  63.         if(startEntryElementFlag == true)  
  64.         {     
  65.             String currentData = currentDataBuilder.toString();  
  66.             if (localName.equalsIgnoreCase(kTitleElementName)) {  
  67.                 //提取强度信息  
  68.                 String magnitudeString = currentData.split(" ")[1];  
  69.                 int end =  magnitudeString.length()-1;  
  70.                 magnitudeString = magnitudeString.substring(0, end);  
  71.                 double magnitude = Double.parseDouble(magnitudeString);  
  72.                 earthquakeEntry.setMagnitude(magnitude);  
  73.                 //提取位置信息  
  74.                 String place = currentData.split(",")[1].trim();  
  75.                 earthquakeEntry.setPlace(place);  
  76.             }  
  77.             else if (localName.equalsIgnoreCase(kUpdatedElementName)) {  
  78.                 //构造更新时间  
  79.                 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss'Z'");  
  80.                 Date qdate = new GregorianCalendar(0,0,0).getTime();  
  81.                 try {  
  82.                   qdate = sdf.parse(currentData);  
  83.                 } catch (ParseException e) {  
  84.                   e.printStackTrace();  
  85.                 }  
  86.                 earthquakeEntry.setDate(qdate);  
  87.             }  
  88.             else if (localName.equalsIgnoreCase(kGeoRSSPointElementName)) {  
  89.                 //提取经纬度信息  
  90.                 String[] latLongitude = currentData.split(" ");  
  91.                 Location location = new Location("dummyGPS");  
  92.                 location.setLatitude(Double.parseDouble(latLongitude[0]));  
  93.                 location.setLongitude(Double.parseDouble(latLongitude[1]));  
  94.                 earthquakeEntry.setLocation(location);  
  95.             }  
  96.             else if (localName.equalsIgnoreCase(kGeoRSSElevElementName)) {  
  97.                 //提取海拔高度信息  
  98.                 double evel;  
  99.                 //因为USGS数据有可能会输错,比如为"--10000",多了一个"-"号  
  100.                 try {  
  101.                     evel = Double.parseDouble(currentData);  
  102.                 } catch (Exception e) {  
  103.                     // TODO: handle exception  
  104.                     e.printStackTrace();  
  105.                     evel = 0;  
  106.                 }  
  107.                 Log.v("Sax_Elev", String.valueOf(evel));  
  108.                 earthquakeEntry.setElev(evel);  
  109.             }  
  110.             else if(localName.equalsIgnoreCase(kEntryElementName))  
  111.             {  
  112.                 earthquakeEntryList.add(earthquakeEntry);  
  113.                 startEntryElementFlag = false;  
  114.             }  
  115.             currentDataBuilder.setLength(0);  
  116.         }  
  117.     }     
  118.     }  

首先定义了 xml解析和保存解析结果等相关的一些变量,接着定义一个 get 函数

//获取解析的地震列表

public  ArrayList<EarthquakeEntry> getEarthquakeEntryList()

{

return   this . earthquakeEntryList ;

}

返回解析的地震列表数据。

然后就是具体的xml 解析回调函数的重写实现,因为继承了类 DefaultHandler ,包含了SAX 处理相关的 4 个 Handler 的所有回调函数的空实现,因此我们只需覆盖我们需要的回调函数。这是我们只重写了和文档内容处理相关的 ContentHandler 中 startDocument endDocument  startElement  characters ,和 endElement 这几个回调函数,在实际应用中你可能还需添加错误处理或者其他的回调函数,只需重写覆盖即可。

回调函数中具体的处理逻辑和你的XML 数据的内容有关,以上实现了解析 USGS 的地震数据的处理逻辑,并添加了注释,如果有兴趣你可以对照着 USGS 的 XML 数据格式来看,这就不具体的讲了。

和地震相关的存储类和SAX 处理回调函数都完成了,接下来我们就来调用SaxEarthquakeHandler 开始解析并显示数据。

先修改res/layout 下的 main.xml 为:

[xhtml]  view plain copy
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:orientation="vertical"  
  4.     android:layout_width="fill_parent"  
  5.     android:layout_height="fill_parent"  
  6.     >  
  7.   <ListView  
  8.     android:id="@+id/list"  
  9.     android:layout_width="fill_parent"   
  10.     android:layout_height="fill_parent"  
  11.   />  
  12.     </LinearLayout>  

 

添加了一个用于显示的ListView 控件。

接着添加AndroidXMLDemoSax.java 文件的内容。

先添加获取xml 数据源的方法:

[java]  view plain copy
  1. private InputStream readEarthquakeDataFromInternet()  
  2.     {  
  3.         //从网络上获取实时地震数据  
  4.         URL infoUrl = null;  
  5.         InputStream inStream = null;  
  6.         try {  
  7.             infoUrl = new URL("http://earthquake.usgs.gov/earthquakes/catalogs/1day-M2.5.xml");  
  8.             URLConnection connection = infoUrl.openConnection();  
  9.             HttpURLConnection httpConnection = (HttpURLConnection)connection;  
  10.             int responseCode = httpConnection.getResponseCode();  
  11.             if(responseCode == HttpURLConnection.HTTP_OK)  
  12.             {  
  13.                 inStream = httpConnection.getInputStream();  
  14.             }  
  15.         } catch (MalformedURLException e) {  
  16.             // TODO Auto-generated catch block  
  17.             e.printStackTrace();  
  18.         } catch (IOException e) {  
  19.             // TODO Auto-generated catch block  
  20.             e.printStackTrace();  
  21.         }  
  22.         return inStream;  
  23.         }  

这是从 USGS的网站上读取 XML 数据并以 InputStream  的形式返回。因为需要用到联网功能,所以还得在 manifest.xml文件中添加联网权限:

< uses-permission   android:name = "android.permission.INTERNET"   />

这是联网获取XML 数据,也可以从本地读取 XML 数据,因为校园网会打不开 USGS 的网站,因此复制了一份 USGS 的地震数据以文件的形式保存在 assets 文件夹下,并使用如下函数读取:

[java]  view plain copy
  1. private InputStream readEarthquakeDataFromFile()  
  2.     {  
  3.         //从本地获取地震数据  
  4.         InputStream inStream = null;  
  5.         try {  
  6.             inStream = this.getAssets().open("USGS_Earthquake_1M2_5.xml");  
  7.         } catch (IOException e) {  
  8.             // TODO Auto-generated catch block  
  9.             e.printStackTrace();  
  10.         }  
  11.         return inStream;  
  12.         }  

有了XML 数据,就可以接下来进行解析了。

[java]  view plain copy
  1.  //获取地震数据流  
  2.       InputStream earthquakeStream = readEarthquakeDataFromFile();  
  3.       //Sax方式进行xml解析  
  4.     SAXParserFactory factory = SAXParserFactory.newInstance();  
  5.     try {  
  6.     SAXParser parser = factory.newSAXParser();  
  7.     SaxEarthquakeHandler saxHandler = new SaxEarthquakeHandler();  
  8.     parser.parse(earthquakeStream, saxHandler);  
  9.     //获取解析后的列表数据  
  10.     earthquakeEntryList = saxHandler.getEarthquakeEntryList();  
  11. catch (Exception e) {  
  12.     // TODO Auto-generated catch block  
  13.     e.printStackTrace();  
  14.     }  

最后添加定义相关变量,用把解析的数据用ListView 显示:

[java]  view plain copy
  1. //定义显示的List相关变量  
  2. ListView list;  
  3. ArrayAdapter<EarthquakeEntry> adapter;  
  4.     ArrayList<EarthquakeEntry> earthquakeEntryList;  
  5.   
  6.     //用ListView进行显示  
  7.     list = (ListView)this.findViewById(R.id.list);  
  8.     adapter = new ArrayAdapter<EarthquakeEntry>(this, android.R.layout.simple_list_item_1, earthquakeEntryList);  
  9.         list.setAdapter(adapter);  

完成了,可以保存运行看下效果。

 

以上使用的是javax.xml.parsers 包中的 SAXParser 来实现, SAXParser 包装了底层的 XMLReader ,实现起来更加方便。但是我们也可以使用 XMLReader 来实现解析,下面就看下使用具体的 XMLReader 的方式,实现代码如下所示:

[java]  view plain copy
  1.         //使用org.xml.sax包中的XMLReader进行xml解析  
  2.         XMLReader xmlReader = null;  
  3.         //获取XMLReader的方式有两种  
  4.         //方式一:使用javax.xml.parsers.SAXParser的getXMLReader()方法  
  5. //        try {   
  6. //          xmlReader = SAXParserFactory.newInstance().newSAXParser().getXMLReader();  
  7. //      } catch (Exception e) {   
  8. //          // TODO Auto-generated catch block  
  9. //          e.printStackTrace();  
  10. //      }  
  11.         //方式二:使用org.xml.sax.helpers.XMLReaderFactory的createXMLReader()方法  
  12.         try {  
  13.             //设置系统的"org.xml.sax.driver",XMLReaderFactory创建createXMLReader()时要用到  
  14.             System.setProperty("org.xml.sax.driver","org.xmlpull.v1.sax2.Driver");  
  15.             xmlReader = XMLReaderFactory.createXMLReader();  
  16.         } catch (SAXException e) {  
  17.             // TODO Auto-generated catch block  
  18.             e.printStackTrace();  
  19.         }  
  20.         SaxEarthquakeHandler saxHandler = new SaxEarthquakeHandler();  
  21.         xmlReader.setContentHandler(saxHandler);  
  22.         //XMLReader的输入为InputSource  
  23.         InputSource inSource = new InputSource(earthquakeStream);  
  24.         try {  
  25.             xmlReader.parse(inSource);  
  26.         } catch (Exception e) {  
  27.             // TODO Auto-generated catch block  
  28.             e.printStackTrace();  
  29.         }  
  30.         //获取解析后的列表数据  
  31.             earthquakeEntryList = saxHandler.getEarthquakeEntryList();  

其中获取XMLReader 的方式有两种,一种是先获取 SAXParser ,然后通过getXMLReader() 方法来获取,

xmlReader = SAXParserFactory.newInstance().newSAXParser().getXMLReader();

另一种是直接使用XMLReader 的工厂类 XMLReaderFactory 调用 createXMLReader()方法创建,

xmlReader = XMLReaderFactory. createXMLReader ();

 不管是那种方式,只有获得了XMLReader 实例,接下来的操作都是一样的,先注册文档内容的事件处理器实例,

xmlReader.setContentHandler(saxHandler);

然后调用parse方法开始解析,

xmlReader.parse(inSource);

这样就用XMLReader进行了XML解析。

四. 总结

在这部分中我们首先学习了Android 上和 XML 解析相关的各个包的简单介绍,并且从有这么多个相关的包我们可以知道 Android 为 XML 的读写提供了相当大的支持。

然后具体学习了Android 上使用 SAX 方式解析 XML 的基本知识,使用 javax.xml.parsers 包中的 SAXParser 进行解析,及使用 org.xml.sax 包中的 XMLReader 进行解析两种方式分别的步骤,最后用解析 USGS 地震数据的 Demo 例子来实现介绍的内容。

这部分介绍的SAX 方式是属于原来 Java 就有的 XML 处理方式,同时, Android 平台为了使解析 XML 还能更加方便和更加健壮,提供了 android.sax 包来进行 SAX 进行 XML ,这部分内容我们以后我们继续接着学习。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/kaixinbingju/article/details/8677791

智能推荐

FTP命令字和返回码_ftp 登录返回230-程序员宅基地

文章浏览阅读3.5k次,点赞2次,收藏13次。为了从FTP服务器下载文件,需要要实现一个简单的FTP客户端。FTP(文件传输协议) 是 TCP/IP 协议组中的应用层协议。FTP协议使用字符串格式命令字,每条命令都是一行字符串,以“\r\n”结尾。客户端发送格式是:命令+空格+参数+"\r\n"的格式服务器返回格式是以:状态码+空格+提示字符串+"\r\n"的格式,代码只要解析状态码就可以了。读写文件需要登陆服务器,特殊用..._ftp 登录返回230

centos7安装rabbitmq3.6.5_centos7 安装rabbitmq3.6.5-程序员宅基地

文章浏览阅读648次。前提:systemctl stop firewalld 关闭防火墙关闭selinux查看getenforce临时关闭setenforce 0永久关闭sed-i'/SELINUX/s/enforcing/disabled/'/etc/selinux/configselinux的三种模式enforcing:强制模式,SELinux 运作中,且已经正确的开始限制..._centos7 安装rabbitmq3.6.5

idea导入android工程,idea怎样导入Android studio 项目?-程序员宅基地

文章浏览阅读5.8k次。满意答案s55f2avsx2017.09.05采纳率:46%等级:12已帮助:5646人新版Android Studio/IntelliJ IDEA可以直接导入eclipse项目,不再推荐使用eclipse导出gradle的方式2启动Android Studio/IntelliJ IDEA,选择 import project3选择eclipse 项目4选择 create project f..._android studio 项目导入idea 看不懂安卓项目

浅谈AI大模型技术:概念、发展和应用_ai大模型应用开发-程序员宅基地

文章浏览阅读860次,点赞2次,收藏6次。AI大模型技术已经在自然语言处理、计算机视觉、多模态交互等领域取得了显著的进展和成果,同时也引发了一系列新的挑战和问题,如数据质量、计算效率、知识可解释性、安全可靠性等。城市运维涉及到多个方面,如交通管理、环境监测、公共安全、社会治理等,它们需要处理和分析大量的多模态数据,如图像、视频、语音、文本等,并根据不同的场景和需求,提供合适的决策和响应。知识搜索有多种形式,如语义搜索、对话搜索、图像搜索、视频搜索等,它们可以根据用户的输入和意图,从海量的数据源中检索出最相关的信息,并以友好的方式呈现给用户。_ai大模型应用开发

非常详细的阻抗测试基础知识_阻抗实部和虚部-程序员宅基地

文章浏览阅读8.2k次,点赞12次,收藏121次。为什么要测量阻抗呢?阻抗能代表什么?阻抗测量的注意事项... ...很多人可能会带着一系列的问题来阅读本文。不管是数字电路工程师还是射频工程师,都在关注各类器件的阻抗,本文非常值得一读。全文13000多字,认真读完大概需要2小时。一、阻抗测试基本概念阻抗定义:阻抗是元器件或电路对周期的交流信号的总的反作用。AC 交流测试信号 (幅度和频率)。包括实部和虚部。​图1 阻抗的定义阻抗是评测电路、元件以及制作元件材料的重要参数。那么什么是阻抗呢?让我们先来看一下阻抗的定义。首先阻抗是一个矢量。通常,阻抗是_阻抗实部和虚部

小学生python游戏编程arcade----基本知识1_arcade语言 like-程序员宅基地

文章浏览阅读955次。前面章节分享试用了pyzero,pygame但随着想增加更丰富的游戏内容,好多还要进行自己编写类,从今天开始解绍一个新的python游戏库arcade模块。通过此次的《连连看》游戏实现,让我对swing的相关知识有了进一步的了解,对java这门语言也有了比以前更深刻的认识。java的一些基本语法,比如数据类型、运算符、程序流程控制和数组等,理解更加透彻。java最核心的核心就是面向对象思想,对于这一个概念,终于悟到了一些。_arcade语言 like

随便推点

【增强版短视频去水印源码】去水印微信小程序+去水印软件源码_去水印机要增强版-程序员宅基地

文章浏览阅读1.1k次。源码简介与安装说明:2021增强版短视频去水印源码 去水印微信小程序源码网站 去水印软件源码安装环境(需要材料):备案域名–服务器安装宝塔-安装 Nginx 或者 Apachephp5.6 以上-安装 sg11 插件小程序已自带解析接口,支持全网主流短视频平台,搭建好了就能用注:接口是公益的,那么多人用解析慢是肯定的,前段和后端源码已经打包,上传服务器之后在配置文件修改数据库密码。然后输入自己的域名,进入后台,创建小程序,输入自己的小程序配置即可安装说明:上传源码,修改data/_去水印机要增强版

verilog进阶语法-触发器原语_fdre #(.init(1'b0) // initial value of register (1-程序员宅基地

文章浏览阅读557次。1. 触发器是FPGA存储数据的基本单元2. 触发器作为时序逻辑的基本元件,官方提供了丰富的配置方式,以适应各种可能的应用场景。_fdre #(.init(1'b0) // initial value of register (1'b0 or 1'b1) ) fdce_osc (

嵌入式面试/笔试C相关总结_嵌入式面试笔试c语言知识点-程序员宅基地

文章浏览阅读560次。本该是不同编译器结果不同,但是尝试了g++ msvc都是先计算c,再计算b,最后得到a+b+c是经过赋值以后的b和c参与计算而不是6。由上表可知,将q复制到p数组可以表示为:*p++=*q++,*优先级高,先取到对应q数组的值,然后两个++都是在后面,该行运算完后执行++。在电脑端编译完后会分为text data bss三种,其中text为可执行程序,data为初始化过的ro+rw变量,bss为未初始化或初始化为0变量。_嵌入式面试笔试c语言知识点

57 Things I've Learned Founding 3 Tech Companies_mature-程序员宅基地

文章浏览阅读2.3k次。57 Things I've Learned Founding 3 Tech CompaniesJason Goldberg, Betashop | Oct. 29, 2010, 1:29 PMI’ve been founding andhelping run techn_mature

一个脚本搞定文件合并去重,大数据处理,可以合并几个G以上的文件_python 超大文本合并-程序员宅基地

文章浏览阅读1.9k次。问题:先讲下需求,有若干个文本文件(txt或者csv文件等),每行代表一条数据,现在希望能合并成 1 个文本文件,且需要去除重复行。分析:一向奉行简单原则,如无必要,绝不复杂。如果数据量不大,那么如下两条命令就可以搞定合并:cat a.txt >> new.txtcat b.txt >> new.txt……去重:cat new...._python 超大文本合并

支付宝小程序iOS端过渡页DFLoadingPageRootController分析_类似支付宝页面过度加载页-程序员宅基地

文章浏览阅读489次。这个过渡页是第一次打开小程序展示的,点击某个小程序前把手机的开发者->network link conditioner->enable & very bad network 就会在停在此页。比如《支付宝运动》这个小程序先看这个类的.h可以看到它继承于DTViewController点击左上角返回的方法- (void)back;#import "DTViewController.h"#import "APBaseLoadingV..._类似支付宝页面过度加载页

推荐文章

热门文章

相关标签