<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

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

    答:有DOM,SAX,STAX等

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

    STAX:Streaming API for XML (StAX)

    2、你在項目中用到了xml技術(shù)的哪些方面?如何實現(xiàn)的?

    答:用到了數(shù)據(jù)存貯,信息配置兩方面。在做數(shù)據(jù)交換平臺時,將不能數(shù)據(jù)源的數(shù)據(jù)組裝成XML文件,然后將XML文件壓縮打包加密后通過網(wǎng)絡(luò)傳送給接收者,接收解密與解壓縮后再同XML文件中還原相關(guān)信息進行處理。在做軟件配置時,利用XML可以很方便的進行,軟件的各種配置參數(shù)都存貯在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 閱讀(1334) | 評論 (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面試題:
    “編程:編寫一個截取字符串的函數(shù),輸入為一個字符串和字節(jié)數(shù),輸出為按字節(jié)數(shù)
    但是要保證漢字不被截半個,如“我ABC”4,應(yīng)該截為“我AB”,輸入“我ABC漢DEF”,6,應(yīng)該輸出為“我ABC”而不是“我ABC+漢的半個”。 ”
    posted @ 2005-08-22 14:25 jam 閱讀(6807) | 評論 (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 閱讀(567) | 評論 (0)編輯 收藏
    在工作中碰到ip地址檢查的問題,因此自己寫了一個checkIPAdress方法。
     1/**
     2   * check input is ip or not.
     3   * @return a strResult.1 is not ip adress,0 is ipadress
     4   */

     5
     6  private String checkIPAdress(String input) {
     7
     8    String strResult = "0";
     9    //identify the length of the string
    10    if (input.length() < 7 || input.length() > 15{
    11      return "1";
    12    }

    13
    14    int startIndex = 0;
    15    Vector v = new Vector();
    16    int index = 0;
    17    startIndex = input.indexOf(".");
    18    while (startIndex < input.length() && startIndex != -1{
    19      String temp = input.substring(index, startIndex);
    20      v.addElement(temp);
    21      index = startIndex + 1;
    22      startIndex = input.indexOf(".", startIndex + 1);
    23    }

    24    v.addElement(input.substring(index));
    25    if (v.size() != 4{
    26      return "1";
    27    }

    28    for (int i = 0; i < v.size(); i++{
    29      try {
    30        int iTemp = Integer.parseInt( (String) v.elementAt(i));
    31
    32        if (iTemp < 0 || iTemp > 254{
    33
    34          return "1";
    35        }

    36
    37      }

    38      catch (Exception e) {
    39        e.printStackTrace();
    40        return "1";
    41      }

    42
    43    }

    44
    45    return strResult;
    46
    47  }
         起始在判斷分割ip地址應(yīng)該使用split方法。但是因為我系統(tǒng)中用的是jdk1.2所以采用這個笨方法,如果覺得不爽可以改成split,更方便。
    posted @ 2005-08-11 12:50 jam 閱讀(484) | 評論 (0)編輯 收藏
    主站蜘蛛池模板: 亚洲一区二区三区深夜天堂| 一日本道a高清免费播放| 日本人的色道www免费一区| 永久免费无码网站在线观看个| 国产gv天堂亚洲国产gv刚刚碰 | 久久午夜夜伦鲁鲁片免费无码| 亚洲综合久久1区2区3区| 国产在线播放免费| 久久国产精品成人片免费| 女bbbbxxxx另类亚洲| 亚洲网址在线观看你懂的| 美女被免费视频网站a国产| 免费成人高清在线视频| 亚洲欧美日韩自偷自拍| 亚洲AV无码久久精品狠狠爱浪潮| 无码一区二区三区免费视频 | 国产无遮挡无码视频免费软件| 亚洲国产成人无码av在线播放| 久久国产成人亚洲精品影院| 成人免费毛片内射美女APP| 花蝴蝶免费视频在线观看高清版 | 亚洲av无码一区二区三区观看| 国产AV无码专区亚洲AWWW| 日韩高清在线高清免费| 午夜精品一区二区三区免费视频 | 亚洲Aⅴ在线无码播放毛片一线天 亚洲avav天堂av在线网毛片 | 国产亚洲情侣一区二区无码AV| 最近最好的中文字幕2019免费| 国产午夜无码精品免费看| 国产成人亚洲精品无码AV大片 | 一级特黄录像免费播放肥| 日韩亚洲翔田千里在线| 亚洲永久在线观看| 久久精品国产亚洲AV无码偷窥| 亚洲国产一级在线观看| 成人午夜免费福利| 天天影院成人免费观看| 免费视频精品一区二区三区 | 天堂亚洲国产中文在线| 精品亚洲麻豆1区2区3区| 亚洲综合另类小说色区|