JAVA主要要點!!!!!!!!!!

l    JBS
1.列舉出 10個JAVA語言的優勢
a:免費,開源,跨平臺(平臺獨立性),簡單易用,功能完善,面向對象,健壯性,多線程,結構中立,企業應用的成熟平臺, 無線應用
2.列舉出JAVA中10個面向對象編程的術語
a:包,類,接口,對象,屬性,方法,構造器,繼承,封裝,多態,抽象,範型
3.列舉出JAVA中6個比較常用的包
Java.lang;java.util;java.io;java.sql;java.awt;java.net;java.applet;javax.swing
4.JAVA中的標識符有什麼作用和特點
作用:標識符用作給變量、類和方法命名
特點:可以以字母、下劃線“_”和”$”符開頭
首字符外,可以跟上字母、下劃線“_”和”$”符或數字
Java是大小寫敏感的,標識符也不例外
5.JAVA中的關鍵字有什麼特點,列舉出至少20個關鍵字
Java中一些賦以特定的含義、並用做專門用途的單詞稱爲關鍵字(keyword)
所有Java關鍵字都是小寫的,TURE、FALSE、NULL等都不是Java關鍵字 ;
goto和const 雖然從未被使用,但也作爲Java關鍵字保留;
•          中一共有51個關鍵字Java
abstract assert boolean break byte continue
case catch char class const double
default do extends else final float
for goto long if implements import
native new null instanceof int interface
package private protected public return short
static strictfp super switch synchronized this
while void throw throws transient try
volatile         

        6.JAVA中數據類型如何分類?

可分爲簡單數據類型和引用數據類型:
簡單數據類型:數值型(byte,short,int,long,float double),字符型(char),布爾型(boolean);
引用數據類型:類,接口,數組.
7.JAVA中運算符的分類及舉例
•          分割符:,,;,[],()
•          算術運算符: +,―,*,/,%,++,――
•          關係運算符: >, <,>=, <=,==,!=
•          布爾邏輯運算符: !,& , | , ^ , &&,||
•          位運算符: &,|,^,~ , >>, < <,>>>
•          賦值運算符: = 擴展賦值運算符:+=,―=,*=,/=
•          字符串連接運算符: +
•          造型操作符:()

8.super,this關鍵字的作用及用法
•          在Java類中使用super來引用父類的成分
–        可用於訪問父類中定義的屬性super
–        可用於調用父類中定義的成員方法super
–        可用於在子類構造器中調用父類的構造器super
–        的追溯不僅於直接父類super
•          中爲解決變量的命名衝突和不確定性問題,引入關鍵字“this”代表其所在方法的當前對象。Java
–        構造器中指該構造器所創建的新對象
–        方法中指調用該方法的對象
•          關鍵字的用法this
–        在類本身的方法或構造器中引用該類的實例變量和方法
–        將當前對象作爲參數傳遞給其它方法或構造器
–        用來調用其他的重載的構造器

9.什麼是JAVA中的表達式?有什麼作用?
•          表達式是運算符和操作數的結合,它是任何一門編程語言的關鍵組成部分
•          表達式允許程序員進行數學計算、值的比較、邏輯操作以及在Java中進行對象的操作。
•          一些表達式的例子:
–        X
–        X+10
–        Y=x+10
–        Arr[10]
–        student.geName()

10.做表列出JAVA中所有修飾符和他們的適用範圍(能不能修飾構造器,屬性,自由塊等)
  class 屬性 方法 構建器 自由塊 內部類
public Y Y Y Y  Y
protected    Y Y Y  Y
(Default) Y Y Y Y Y Y
private  Y Y Y  Y
final Y Y Y    Y
abstract Y  Y    Y
static    Y  Y Y


11.寫一個方法,用一個for循環打印九九乘法表
    /**
    *一個for循環打印九九乘法表
    */
    publicvoid nineNineMultiTable()
    {
      for (int i = 1,j = 1; j <= 9; i++) {
          System.out.print(i+"*"+j+"="+i*j+" ");
          if(i==j)
          {
              i=0;
              j++;
              System.out.println();
          }
      }
    }
12.給定一個java.util.Date對象,如何轉化爲”2007-3-22 20:23:22”格式的字符串
/**
    *將某個日期以固定格式轉化成字符串
    *@paramdate
    *@returnstr
    */
    public String dateToStr(java.util.Date date)
    {
      SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
      String str = sdf.format(date);
      return str;
    }
13.寫一個方法,能夠判斷任意一個整數是否素數
/**
    *判斷任意一個整數是否素數
    *@paramn
    *@returnboolean
    */
    publicboolean isPrimes(int n)
    {
      for (int i = 2; i <= Math.sqrt(n); i++) {
          if(n%i==0)
          {
              returnfalse;
          }
      }
      returntrue;
    }
14.寫一個方法,輸入任意一個整數,返回它的階乘
/**
    *獲得任意一個整數的階乘
    *@paramn
    *@returnn!
    */
    publicint factorial(int n)
    {
      //遞歸
      if(n==1)
      {
          return 1;
      }
      return n*factorial(n-1);
      //非遞歸
//    int multi = 1;
//    for (int i = 2; i <= n; i++) {
//        multi*=i;
//    }
//    return multi;
    }
15.寫一個方法,用二分查找法判斷任意整數在任意整數數組裏面是否存在,若存在就返回它在數組中的索引位置,不存在返回-1
/**
    *二分查找特定整數在整型數組中的位置(遞歸)
    *@paramdataset
    *@paramdata
    *@parambeginIndex
    *@paramendIndex
    *@returnindex
    */
    publicint binarySearch(int[] dataset,int data,int beginIndex,int endIndex)
    {
      int midIndex = (beginIndex+endIndex)/2;
      if(data <dataset[beginIndex]||data>dataset[endIndex]||beginIndex>endIndex)return -1;
      if(data <dataset[midIndex])
      {
          return binarySearch(dataset,data,beginIndex,midIndex-1);
      }elseif(data>dataset[midIndex])
      {
          return binarySearch(dataset,data,midIndex+1,endIndex);
      }else
      {
          return midIndex;
      }
    }
   
    /**
    *二分查找特定整數在整型數組中的位置(非遞歸)
    *@paramdataset
    *@paramdata
    *@returnindex
    */
    publicint binarySearch(int[] dataset ,int data)
    {
      int beginIndex = 0; 
      int endIndex = dataset.length - 1; 
      int midIndex = -1;
      if(data <dataset[beginIndex]||data>dataset[endIndex]||beginIndex>endIndex)return -1;
      while(beginIndex <= endIndex) {
          midIndex = (beginIndex+endIndex)/2;
          if(data <dataset[midIndex]) { 
          endIndex = midIndex-1; 
          } elseif(data>dataset[midIndex]) { 
          beginIndex = midIndex+1; 
          }else
          {
          return midIndex;
          }
      }
      return -1;
    }
16.做一個飼養員給動物餵食物的例子體現JAVA中的面向對象思想,接口(抽象類)的用處
package com.softeem.demo;

/**
*@authorleno
*動物的接口
*/
interface Animal
{
    publicvoid eat(Food food);
}
/**
*@authorleno
*一種動物類:貓
*/
class Cat implements Animal
{
    publicvoid eat(Food food)
    {
      System.out.println("小貓喫"+food.getName());
    }
}
/**
*@authorleno
*一種動物類:狗
*/
class Dog implements Animal
{
    publicvoid eat(Food food)
    {
      System.out.println("小狗啃"+food.getName());
    }
}

/**
*@authorleno
*食物抽象類
*/
abstractclass Food
{
    protected String name;
    public String getName() {
      returnname;
    }

    publicvoid setName(String name) {
      this.name = name;
    }
}

/**
*@authorleno
*一種食物類:魚
*/
class Fish extends Food
{
    public Fish(String name) {
      this.name = name;
    }
}
/**
*@authorleno
*一種食物類:骨頭
*/
class Bone extends Food

    public Bone(String name) {
      this.name = name;
    }
}

/**
*@authorleno
*飼養員類
*
*/
class Feeder
{
    /**
    *飼養員給某種動物喂某種食物
    *@paramanimal
    *@paramfood
    */
    publicvoid feed(Animal animal,Food food)
    {
      animal.eat(food);
    }
}

/**
*@authorleno
*測試飼養員給動物餵食物
*/
publicclass TestFeeder {

    publicstaticvoid main(String[] args) {
      Feeder feeder=new Feeder();
      Animal animal=new Dog();
      Food food=new Bone("肉骨頭");
      feeder.feed(animal,food); //給狗喂肉骨頭
      animal=new Cat();
      food=new Fish("魚");
      feeder.feed(animal,food); //給貓餵魚


    }
}
17.描述JAVA中異常處理的機制
•          程序的執行過程中如出現異常,會自動生成一個異常類對象,該異常對象將被提交給Java運行時系統,這個過程稱爲拋出(throw)異常。Java
•          當Java運行時系統接收到異常對象時,會尋找能處理這一異常的代碼並把當前異常對象交給其處理,這一過程稱爲捕獲(catch)異常。
•          如果Java運行時系統找不到可以捕獲異常的方法,則運行時系統將終止,相應的Java程序也將退出。
•          程序員通常只能處理違例(Exception),而對錯誤(Error)無能爲力。

18.做一個單子模式的類,只加載一次屬性文件
package com.softeem.demo;

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.util.Properties;

/**
*@authorleno
*單子模式,保證在整個應用期間只加載一次配置屬性文件
*/
publicclass Singleton {

    privatestatic Singleton instance;
    privatestaticfinal String CONFIG_FILE_PATH = "E://config.properties";
    private Properties config;
    private Singleton()
    {
      config = new Properties();
      InputStream is;
      try {
          is = new FileInputStream(CONFIG_FILE_PATH);
          config.load(is);
          is.close();
      } catch (FileNotFoundException e) {
          // TODO Auto-generated catch block
          e.printStackTrace();
      } catch (IOException e) {
          // TODO Auto-generated catch block
          e.printStackTrace();
      }
    }
    publicstatic Singleton getInstance()
    {
      if(instance==null)
      {
          instance = new Singleton();
      }
      returninstance;
    }
    public Properties getConfig() {
      returnconfig;
    }
    publicvoid setConfig(Properties config) {
      this.config = config;
    }
   
   

}
l    J2SE
19.拷貝一個目錄(文件)到指定路徑
/**
    *拷貝一個目錄或者文件到指定路徑下
    *@paramsource
    *@paramtarget
    */
    publicvoid copy(File source,File target)
    {
      File tarpath = new File(target,source.getName());
      if(source.isDirectory())
      {
          tarpath.mkdir();
          File[] dir = source.listFiles();
          for (int i = 0; i < dir.length; i++) {
              copy(dir[i],tarpath);
          }
      }else
      {
          try {
              InputStream is = new FileInputStream(source);
              OutputStream os = new FileOutputStream(tarpath);
              byte[] buf = newbyte[1024];
              int len = 0;
              while((len = is.read(buf))!=-1)
              {
                  os.write(buf,0,len);
              }
              is.close();
              os.close();
          } catch (FileNotFoundException e) {
              // TODO Auto-generated catch block
              e.printStackTrace();
          } catch (IOException e) {
              // TODO Auto-generated catch block
              e.printStackTrace();
          }
      }
    }
20.用JAVA中的多線程示例銀行取款問題
packagecom.softeem.demo;

/**
*@authorleno
*賬戶類
*默認有餘額,可以取款
*/
class Account {
    privatefloatbalance = 1000;

    publicfloat getBalance() {
      returnbalance;
    }

    publicvoid setBalance(float balance) {
      this.balance = balance;
    }
   
    /**
    *取款的方法需要同步
    *@parammoney
    */
    publicsynchronizedvoid withdrawals(float money)
    {
      if(balance>=money)
      {
          System.out.println("被取走"+money+"元!");
          try {
              Thread.sleep(1000);
          } catch (InterruptedException e) {
              // TODO Auto-generated catch block
              e.printStackTrace();
          }
          balance-=money;
      }
      else
      {
          System.out.println("對不起,餘額不足!");
      }
    }
   
}

/**
*@authorleno
*銀行卡
*/
class TestAccount1 extends Thread {

    private Account account;
   
   
    public TestAccount1(Account account) {
      this.account = account;
    }


    @Override
    publicvoid run() {
      account.withdrawals(800);
      System.out.println("餘額爲:"+account.getBalance()+"元!");
    } 
}
/**
*@authorleno
*存摺
*/
class TestAccount2 extends Thread {

    private Account account;
    public TestAccount2(Account account) {
          this.account = account;
      }
    @Override
    publicvoid run() {
      account.withdrawals(700);
      System.out.println("餘額爲:"+account.getBalance()+"元!");
    } 
}

publicclass Test
{
    publicstaticvoid main(String[] args) {
      Account account = new Account();
      TestAccount1 testAccount1 = new TestAccount1(account);
      testAccount1.start();
      TestAccount2 testAccount2 = new TestAccount2(account);
      testAccount2.start();
    }
}
21.用JAVA中的多線程示例火車站售票問題
package com.softeem.demo;

/**
*@authorleno
*售票類
*/
class SaleTicket implements Runnable {
    inttickets = 100;

    publicvoid run() {
      while (tickets > 0) {
          sale();
//或者下面這樣實現
//        synchronized (this) {
//            if (tickets > 0) {
//                System.out.println(Thread.currentThread().getName() + "賣第"
//                      + (100 - tickets + 1) + "張票");
//                tickets--;
//            }
//        }
      }
    }

    publicsynchronizedvoid sale() {
      if (tickets > 0) {
          System.out.println(Thread.currentThread().getName() + "賣第"
                  + (100 - tickets + 1) + "張票");
          tickets--;
      }
    }

}

publicclass TestSaleTicket {

    publicstaticvoid main(String[] args) {
      SaleTicket st = new SaleTicket();
      new Thread(st, "一號窗口").start();
      new Thread(st, "二號窗口").start();
      new Thread(st, "三號窗口").start();
      new Thread(st, "四號窗口").start();

    }
}

22.用JAVA中的多線程示例生產者和消費者問題
package com.softeem.demo;

class Producer implements Runnable
{
private SyncStack stack;

    public Producer(SyncStack stack) {
    this.stack = stack;
}

    publicvoid run() {
      for (int i = 0; i < stack.getProducts().length; i++) {
          String product = "產品"+i;
          stack.push(product);
          System.out.println("生產了: "+product);
          try
          {
            Thread.sleep(200);
          }
          catch(InterruptedException e)
          {
            e.printStackTrace();
          }


      }
    }
   
}

class Consumer implements Runnable
{
    private SyncStack stack;

    public Consumer(SyncStack stack) {
    this.stack = stack;
}
    publicvoid run() {
      for(int i=0;i <stack.getProducts().length;i++)
          {
          String product =stack.pop();
          System.out.println("消費了: "+product);
          try
          {
            Thread.sleep(1000);
          }
          catch(InterruptedException e)
          {
            e.printStackTrace();
          }

          }

     
    }
}

class SyncStack
{
    private String[] products = new String[10];
    privateintindex;
    publicsynchronizedvoid push(String product)
    {
      if(index==product.length())
      {
          try {
              wait();
          } catch (InterruptedException e) {
              // TODO Auto-generated catch block
              e.printStackTrace();
          }
      }
      notify();
      products[index]=product;
      index++;
    }
   
    publicsynchronized String pop()
    {
      if(index==0)
      {
          try {
              wait();
          } catch (InterruptedException e) {
              // TODO Auto-generated catch block
              e.printStackTrace();
          }
      }
      notify();
      index--;
      String product = products[index];
      return product;
    }

    public String[] getProducts() {
      returnproducts;
    }
   
   
}
publicclass TestProducerConsumer {
   
    publicstaticvoid main(String[] args) {
      SyncStack stack=new SyncStack();
      Producer p=new Producer(stack);
      Consumer c=new Consumer(stack);

      new Thread(p).start();
      new Thread(c).start();
      }
    }
23.編程實現序列化的Student(sno,sname)對象在網絡上的傳輸
package com.softeem.demo;

import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable;
import java.net.ServerSocket;
import java.net.Socket;

class Student implements Serializable {
      private int sno;
      private String sname;

      public Student(int sno, String sname) {
              this.sno = sno;
              this.sname = sname;
      }

      public int getSno() {
              return sno;
      }

      public void setSno(int sno) {
              this.sno = sno;
      }

      public String getSname() {
              return sname;
      }

      public void setSname(String sname) {
              this.sname = sname;
      }

      @Override
      public String toString() {
              return "學號:" + sno + ";姓名:" + sname;
      }

}

class MyClient extends Thread {
      @Override
      public void run() {
              try {
                    Socket s = new Socket("localhost", 9999);
                    ObjectInputStream ois = new ObjectInputStream(s.getInputStream());
                    Student stu = (Student) ois.readObject();
                    System.out.println("客戶端程序收到服務器端程序傳輸過來的學生對象>> " + stu);
                    ois.close();
                    s.close();
              } catch (IOException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
              } catch (ClassNotFoundException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
              }
      }
}

class MyServer extends Thread {

      @Override
      public void run() {
              try {
                    ServerSocket ss = new ServerSocket(9999);
                    Socket s = ss.accept();
                    ObjectOutputStream ops = new ObjectOutputStream(s.getOutputStream());
                    Student stu = new Student(1, "趙本山");
                    ops.writeObject(stu);
                    ops.close();
                    s.close();
                    ss.close();
              } catch (IOException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
              }
      }

}

public class TestTransfer {
      public static void main(String[] args) {
              new MyServer().start();
              new MyClient().start();
      }
}
l    JDBC
24.用dom4j組件解析如下XML格式的文件:
<?xml version="1.0" encoding="UTF-8"?>
<generator>
<table name="login" operation="1">
      <column name="username" handle="0">aaa </column>
      <column name="password" handle="0">123 </column>
</table>
<table name="login" operation="2">
      <column name="id" handle="1">1 </column>
      <column name="username" handle="0">bbb </column>
      <column name="password" handle="0">444 </column>
</table>
<table name="login" operation="3">
      <column name="id" handle="1">4 </column>
</table>
</generator>
規則: <table>operation 1表insert,2表update,3表delete.
<column>handle 1表作爲where條件,0表作爲操作字段。
要求:按照規則生成三條SQL語句!(即做一個方法解析xml文件生成一個含有三條SQL語句的字符串)
/**
    *解析XML文件生成一個含有可執行SQL語句的字符串
    *@paramxmlFileName
    *@returnSQL
    */
    public String parseXmltoSQL(String xmlFileName) {
      StringBuffer sbsql = new StringBuffer();
      SAXReader reader = new SAXReader();
      try {
          Document document = reader.read(new File(xmlFileName));
          Element element = document.getRootElement();
          Iterator it = element.elementIterator("table");
          while (it.hasNext()) {
              element = (Element) it.next();
              //獲得對錶的操作
              String oper = element.attributeValue("operation");
              //獲得表名
              String tableName = element.attributeValue("name");
              if ("1".equals(oper)) {
                  sbsql.append("insert into ").append(tableName);
                  Iterator it2 = element.elementIterator("column");
                  String columnName1 = null;
                  String columnValue1 = null;
                  String columnName2 = null;
                  String columnValue2 = null;
                  if (it2.hasNext()) {
                    element = (Element) it2.next();
                      columnName1 = element.attributeValue("name");
                      columnValue1 = element.getText();
                  }
                  if (it2.hasNext()) {
                    element = (Element) it2.next();
                      columnName2 = element.attributeValue("name");
                      columnValue2 = element.getText();
                  }
                  sbsql.append("("+columnName1+","+columnName2+")"+" values('"+columnValue1+"','"+columnValue2+"')/n");
                 
              } elseif ("2".equals(oper)) {
                  sbsql.append("update ").append(tableName);
                  Iterator it2 = element.elementIterator("column");
                  String columnName1 = null;
                  String columnValue1 = null;
                  String columnName2 = null;
                  String columnValue2 = null;
                  String columnName3 = null;
                  String columnValue3 = null;
                  if (it2.hasNext()) {
                        element = (Element) it2.next();
                          columnName1 = element.attributeValue("name");
                          columnValue1 = element.getText();
                    }
                  if (it2.hasNext()) {
                    element = (Element) it2.next();
                      columnName2 = element.attributeValue("name");
                      columnValue2 = element.getText();
                  }
                  if (it2.hasNext()) {
                    element = (Element) it2.next();
                      columnName3 = element.attributeValue("name");
                      columnValue3 = element.getText();
                  }
                  sbsql.append(" set "+columnName2+"='"+columnValue2+"',"+columnName3+"='"+columnValue3+"' where "+columnName1+"="+columnValue1+"/n");
                 
              }elseif ("3".equals(oper)) {
                  sbsql.append("delete from ").append(tableName);
                  Iterator it2 = element.elementIterator("column");
                  String columnName1 = null;
                  String columnValue1 = null;
                  if (it2.hasNext()) {
                        element = (Element) it2.next();
                          columnName1 = element.attributeValue("name");
                          columnValue1 = element.getText();
                    }
                  sbsql.append(" where "+columnName1+"="+columnValue1);
                 
              }
          }
      } catch (DocumentException e) {
          // TODO Auto-generated catch block
          e.printStackTrace();
      }
      return sbsql.toString();
    }
l    JSP/SERVLET
25.寫出JSP的內置對象並說明他們的作用
request:request表示HttpServletRequest對象。它包含了有關瀏覽器請求的信息,並且提供了幾個用於獲取cookie, header數據的有用的方法。 response:response表示HttpServletResponse對象,並提供了幾個用於設置送回 瀏覽器的響應的方法(如cookies,頭信息等) out:out對象是javax.jsp.JspWriter的一個實例,並提供了幾個方法使你能用於向瀏覽器回送輸出結果。 pageContext:pageContext表示一個javax.servlet.jsp.PageContext對象。它是用於方便存取各種範圍的名字空間、servlet相關的對象的API,並且包裝了通用的servlet相關功能的方法。 session:session表示一個請求的javax.servlet.http.HttpSession對象。Session可以存貯用戶的狀態信息 application:applicaton 表示一個javax.servle.ServletContext對象。這有助於查找有關servlet引擎和servlet環境的信息 config:config表示一個javax.servlet.ServletConfig對象。該對象用於存取servlet實例的初始化參數。 page:page表示從該頁面產生的一個servlet實例。
exception: exception對象是一個例外對象,當一個頁面在運行過程中發生了例外,就產生這個對象。如果一個JSP頁面要應用此對象,就必須把isErrorPage設爲true,否則無法編譯。他實際上是java.lang.Throwable的對象
 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章