隨筆-9  評論-15  文章-1  trackbacks-0
            2005年8月22日
          、xml有哪些解析技術?區別是什么?

          答:有DOM,SAX,STAX等

          DOM:處理大型文件時其性能下降的非常厲害。這個問題是由DOM的樹結構所造成的,這種結構占用的內存較多,而且DOM必須在解析文件之前把整個文檔裝入內存,適合對XML的隨機訪問SAX:不現于DOM,SAX是事件驅動型的XML解析方式。它順序讀取XML文件,不需要一次全部裝載整個文件。當遇到像文件開頭,文檔結束,或者標簽開頭與標簽結束時,它會觸發一個事件,用戶通過在其回調事件中寫入處理代碼來處理XML文件,適合對XML的順序訪問

          STAX:Streaming API for XML (StAX)

          2、你在項目中用到了xml技術的哪些方面?如何實現的?

          答:用到了數據存貯,信息配置兩方面。在做數據交換平臺時,將不能數據源的數據組裝成XML文件,然后將XML文件壓縮打包加密后通過網絡傳送給接收者,接收解密與解壓縮后再同XML文件中還原相關信息進行處理。在做軟件配置時,利用XML可以很方便的進行,軟件的各種配置參數都存貯在XML文件中。

          3、用jdom解析xml文件時如何解決中文問題?如何解析?

          答:看如下代碼,用編碼方式加以解決

          package test;

          import java.io.*;

          public class DOMTest

          {

          private String inFile = "c:\people.xml";

          private String outFile = "c:\people.xml";

          public static void main(String args[])

          {

          new DOMTest();

          }

          public DOMTest()

          {

          try

          {

          javax.xml.parsers.DocumentBuilder builder =

          javax.xml.parsers.DocumentBuilderFactory.newInstance().newDocumentBuilder();

          org.w3c.dom.Document doc = builder.newDocument();

          org.w3c.dom.Element root = doc.createElement("老師");

          org.w3c.dom.Element wang = doc.createElement("王");

          org.w3c.dom.Element liu = doc.createElement("劉");

          wang.appendChild(doc.createTextNode("我是王老師"));

          root.appendChild(wang);

          doc.appendChild(root);

          javax.xml.transform.Transformer transformer =

          javax.xml.transform.TransformerFactory.newInstance().newTransformer();

          transformer.setOutputProperty(javax.xml.transform.OutputKeys.ENCODING, "gb2312");

          transformer.setOutputProperty(javax.xml.transform.OutputKeys.INDENT, "yes");





          transformer.transform(new javax.xml.transform.dom.DOMSource(doc),

          new



          javax.xml.transform.stream.StreamResult(outFile));

          }

          catch (Exception e)

          {

          System.out.println (e.getMessage());

          }

          }

          }
          posted @ 2005-08-22 15:08 jam 閱讀(1343) | 評論 (0)編輯 收藏
            String subString(String str, int i) {
              String strReturn 
          = "";
              
          if (str.equals(""|| str == null || i == 0{
                
          return "";
              }

              
          for (int j = 1; j <= str.length(); j++{
                String temp 
          = "";
                temp 
          = str.substring(0, j);
                
          if (temp.getBytes().length >= i) {
                  
          if (temp.substring(j - 1, j).getBytes().length == 1{
                    strReturn 
          = temp;
                  }

                  
          else {
                    strReturn 
          = str.substring(0, j - 1);
                  }


                  
          break;
                }


              }


              
          return strReturn;
            }


          以上是java面試題:
          “編程:編寫一個截取字符串的函數,輸入為一個字符串和字節數,輸出為按字節數
          但是要保證漢字不被截半個,如“我ABC”4,應該截為“我AB”,輸入“我ABC漢DEF”,6,應該輸出為“我ABC”而不是“我ABC+漢的半個”。 ”
          posted @ 2005-08-22 14:25 jam 閱讀(6815) | 評論 (8)編輯 收藏
           1package test;
           2
           3public class BigInt {
           4  public static void main(String arg[]) {
           5    new BigInt();
           6  }

           7
           8  public BigInt() {
           9    String bigInt1 =
          10        "12312311111111111111111111111111111111113132135135465464646546455545";
          11    String bigInt2 =
          12        "12312311111111111111111111111111111111113132135135465464646546455545";
          13    int[] iArr1 = arr(bigInt1);
          14    int[] iArr2 = arr(bigInt2);
          15    int[] iArr3 = new int[iArr2.length];
          16    int iTemp = 0;
          17    String flag = "";
          18    for (int i = 0; i < iArr1.length; i++{
          19      if (flag.equals("add")) {
          20        iTemp = iArr1[i] + iArr2[i] + 1; ;
          21      }

          22      else {
          23        iTemp = iArr1[i] + iArr2[i];
          24      }

          25      flag = "";
          26      if (iTemp > 9999{
          27        iTemp = iTemp - 10000;
          28        flag = "add";
          29      }

          30
          31      iArr3[i] = iTemp;
          32    }

          33    String temp = "";
          34    for (int i = 0; i < iArr3.length; i++{
          35
          36      if (iArr3[i] < 10{
          37        temp =  "000" + String.valueOf(iArr3[i])+temp;
          38
          39      }

          40      else if (iArr3[i] < 100{
          41        temp = "00" + String.valueOf(iArr3[i])+temp;
          42      }

          43      else if (iArr3[i] < 1000{
          44        temp = "0" + String.valueOf(iArr3[i])+temp;
          45      }

          46      else {
          47        temp =  String.valueOf(iArr3[i])+temp;
          48      }

          49
          50    }

          51    System.out.println(temp);
          52  }

          53
          54  int[] arr(String s) {
          55    int j = s.length() / 4;
          56
          57    int[] ArrOne = new int[j + 1];
          58    int iLength;
          59    iLength = s.length();
          60
          61    for (int i = 0; i < j; i++)
          62
          63    {
          64
          65      ArrOne[i] = Integer.parseInt(s.substring(iLength - 4 * (i + 1),
          66                                               iLength - 4 * i));
          67
          68    }

          69
          70    return ArrOne;
          71
          72  }

          73}

          74
          posted @ 2005-08-22 12:31 jam 閱讀(573) | 評論 (0)編輯 收藏
          主站蜘蛛池模板: 新绛县| 唐海县| 新津县| 河东区| 高雄县| 怀化市| 桓台县| 西城区| 奉化市| 安福县| 达孜县| 清苑县| 保康县| 双流县| 翼城县| 静乐县| 康乐县| 嵩明县| 菏泽市| 怀宁县| 盘山县| 石城县| 克什克腾旗| 湄潭县| 海原县| 理塘县| 博兴县| 盘锦市| 东乡族自治县| 赫章县| 淮滨县| 怀来县| 会理县| 宿松县| 五家渠市| 曲麻莱县| 潜山县| 灵宝市| 兰州市| 澳门| 神池县|