121、內部類可以引用他包含類的成員嗎?有沒有什麼限制?
一個內部類對象可以訪問創建它的外部類對象的內容
122、WEB SERVICE名詞解釋。JSWDL開發包的介紹。JAXP、JAXM的解釋。SOAP、UDDI,WSDL解釋。
Web ServiceWeb Service是基於網絡的、分佈式的模塊化組件,它執行特定的任務,遵守具體的技術規範,這些規範使得Web Service能與其他兼容的組件進行互操作。
JAXP(Java API for XML Parsing) 定義了在Java中使用DOM, SAX, XSLT的通用的接口。這樣在你的程序中你只要使用這些通用的接口,當你需要改變具體的實現時候也不需要修改代碼。
JAXM(Java API for XML Messaging) 是爲SOAP通信提供訪問方法和傳輸機制的API。
WSDL是一種 XML 格式,用於將網絡服務描述爲一組端點,這些端點對包含面向文檔信息或面向過程信息的消息進行操作。這種格式首先對操作和消息進行抽象描述,然後將其綁定到具體的網絡協議和消息格式上以定義端點。相關的具體端點即組合成爲抽象端點(服務)。
SOAP即簡單對象訪問協議(Simple Object Access Protocol),它是用於交換XML編碼信息的輕量級協議。
UDDI 的目的是爲電子商務建立標準;UDDI是一套基於Web的、分佈式的、爲Web Service提供的、信息註冊中心的實現標準規範,同時也包含一組使企業能將自身提供的Web Service註冊,以使別的企業能夠發現的訪問協議的實現標準。
JAVA代碼查錯
1.
abstract class Name {
private String name;
public abstract boolean isStupidName(String name) {}
}
大俠們,這有何錯誤?
答案: 錯。abstract method必須以分號結尾,且不帶花括號。
2.
public class Something {
void doSomething () {
private String s = '';
int l = s.length();
}
}
有錯嗎?
答案: 錯。局部變量前不能放置任何訪問修飾符 (private,public,和protected)。final可以用來修飾局部變量
(final如同abstract和strictfp,都是非訪問修飾符,strictfp只能修飾class和method而非variable)。
3.
abstract class Something {
private abstract String doSomething ();
}
這好像沒什麼錯吧?
答案: 錯。abstract的methods不能以private修飾。abstract的methods就是讓子類implement(實現)具體細節的,怎麼可以用private把abstract
method封鎖起來呢? (同理,abstract method前不能加final)。
4.
public class Something {
public int addOne(final int x) {
return ++x;
}
}
這個比較明顯。
答案: 錯。int x被修飾成final,意味着x不能在addOne method中被修改。
5.
public class Something {
public static void main(String[] args) {
Other o = new Other();
new Something().addOne(o);
}
public void addOne(final Other o) {
o.i++;
}
}
class Other {
public int i;
}
和上面的很相似,都是關於final的問題,這有錯嗎?
答案: 正確。在addOne method中,參數o被修飾成final。如果在addOne method裏我們修改了o的reference
(比如: o = new Other();),那麼如同上例這題也是錯的。但這裏修改的是o的member vairable
(成員變量),而o的reference並沒有改變。
6.
class Something {
int i;
public void doSomething() {
System.out.println('i = ' + i);
}
}
有什麼錯呢? 看不出來啊。
答案: 正確。輸出的是'i = 0'。int i屬於instant variable (實例變量,或叫成員變量)。instant variable有default value。int的default value是0。
7.
class Something {
final int i;
public void doSomething() {
System.out.println('i = ' + i);
}
}
和上面一題只有一個地方不同,就是多了一個final。這難道就錯了嗎?
答案: 錯。final int i是個final的instant variable (實例變量,或叫成員變量)。final的instant variable沒有default value,必須在constructor (構造器)結束之前被賦予一個明確的值。可以修改爲'final int i = 0;'。
8.
public class Something {
public static void main(String[] args) {
Something s = new Something();
System.out.println('s.doSomething() returns ' + doSomething());
}
public String doSomething() {
return 'Do something ...';
}
}
看上去很完美。
答案: 錯。看上去在main裏call doSomething沒有什麼問題,畢竟兩個methods都在同一個class裏。但仔細看,main是static的。static method不能直接call non-static methods。可改成'System.out.println('s.doSomething() returns ' + s.doSomething());'。同理,static method不能訪問non-static instant variable。
9.
此處,Something類的文件名叫OtherThing.java
class Something {
private static void main(String[] something_to_do) {
System.out.println('Do something ...');
}
}
這個好像很明顯。
答案: 正確。從來沒有人說過Java的Class名字必須和其文件名相同。但public class的名字必須和文件名相同。
10.
interface A{
int x = 0;
}
class B{
int x =1;
}
class C extends B implements A {
public void pX(){
System.out.println(x);
}
public static void main(String[] args) {
new C().pX();
}
}
答案:錯誤。在編譯時會發生錯誤(錯誤描述不同的JVM有不同的信息,意思就是未明確的x調用,兩個x都匹配(就象在同時import java.util和java.sql兩個包時直接聲明Date一樣)。對於父類的變量,可以用super.x來明確,而接口的屬性默認隱含爲 public static final.所以可以通過A.x來明確。
11.
interface Playable {
void play();
}
interface Bounceable {
void play();
}
interface Rollable extends Playable, Bounceable {
Ball ball = new Ball('PingPang');
}
class Ball implements Rollable {
private String name;
public String getName() {
return name;
}
public Ball(String name) {
this.name = name;
}
public void play() {
ball = new Ball('Football');
System.out.println(ball.getName());
}
}
這個錯誤不容易發現。
答案: 錯。'interface Rollable extends Playable, Bounceable'沒有問題。interface可繼承多個interfaces,所以這裏沒錯。問題出在interface Rollable裏的'Ball ball = new Ball('PingPang');'。任何在interface裏聲明的interface variable (接口變量,也可稱成員變量),默認爲public static final。也就是說'Ball ball = new Ball('PingPang');'實際上是'public static final Ball ball = new Ball('PingPang');'。在Ball類的Play()方法中,'ball = new Ball('Football');'改變了ball的reference,而這裏的ball來自Rollable interface,Rollable interface裏的ball是public static final的,final的object是不能被改變reference的。因此編譯器將在'ball = new Ball('Football');'這裏顯示有錯。
JAVA編程題
1.現在輸入n個數字,以逗號,分開;然後可選擇升或者降序排序;按提交鍵就在另一頁面顯示按什麼排序,結果爲,提供reset
import java.util.*;
public class bycomma{
public static String[] splitStringByComma(String source){
if(source==null||source.trim().equals(''))
return null;
StringTokenizer commaToker = new StringTokenizer(source,',');
String[] result = new String[commaToker.countTokens()];
int i=0;
while(commaToker.hasMoreTokens()){
result[i] = commaToker.nextToken();
i++;
}
return result;
}
public static void main(String args[]){
String[] s = splitStringByComma('5,8,7,4,3,9,1');
int[] ii = new int[s.length];
for(int i = 0;i<s.length;i++){
ii[i] =Integer.parseInt(s[i]);
}
Arrays.sort(ii);
//asc
for(int i=0;i<s.length;i++){
System.out.println(ii[i]);
}
//desc
for(int i=(s.length-1);i>=0;i--){
System.out.println(ii[i]);
}
}
}
2.金額轉換,阿拉伯數字的金額轉換成中國傳統的形式如:(¥1011)->(一千零一拾一元整)輸出。
package test.format;
import java.text.NumberFormat;
import java.util.HashMap;
public class SimpleMoneyFormat {
public static final String EMPTY = '';
public static final String ZERO = '零';
public static final String ONE = '壹';
public static final String TWO = '貳';
public static final String THREE = '叄';
public static final String FOUR = '肆';
public static final String FIVE = '伍';
public static final String SIX = '陸';
public static final String SEVEN = '柒';
public static final String EIGHT = '捌';
public static final String NINE = '玖';
public static final String TEN = '拾';
public static final String HUNDRED = '佰';
public static final String THOUSAND = '仟';
public static final String TEN_THOUSAND = '萬';
public static final String HUNDRED_MILLION = '億';
public static final String YUAN = '元';
public static final String JIAO = '角';
public static final String FEN = '分';
public static final String DOT = '.';
private static SimpleMoneyFormat formatter = null;
private HashMap chineseNumberMap = new HashMap();
private HashMap chineseMoneyPattern = new HashMap();
private NumberFormat numberFormat = NumberFormat.getInstance();
private SimpleMoneyFormat() {
numberFormat.setMaximumFractionDigits(4);
numberFormat.setMinimumFractionDigits(2);
numberFormat.setGroupingUsed(false);
chineseNumberMap.put('0', ZERO);
chineseNumberMap.put('1', ONE);
chineseNumberMap.put('2', TWO);
chineseNumberMap.put('3', THREE);
chineseNumberMap.put('4', FOUR);
chineseNumberMap.put('5', FIVE);
chineseNumberMap.put('6', SIX);
chineseNumberMap.put('7', SEVEN);
chineseNumberMap.put('8', EIGHT);
chineseNumberMap.put('9', NINE);
chineseNumberMap.put(DOT, DOT);
chineseMoneyPattern.put('1', TEN);
chineseMoneyPattern.put('2', HUNDRED);
chineseMoneyPattern.put('3', THOUSAND);
chineseMoneyPattern.put('4', TEN_THOUSAND);
chineseMoneyPattern.put('5', TEN);
chineseMoneyPattern.put('6', HUNDRED);
chineseMoneyPattern.put('7', THOUSAND);
chineseMoneyPattern.put('8', HUNDRED_MILLION);
}
public static SimpleMoneyFormat getInstance() {
if (formatter == null)
formatter = new SimpleMoneyFormat();
return formatter;
}
public String format(String moneyStr) {
checkPrecision(moneyStr);
String result;
result = convertToChineseNumber(moneyStr);
result = addUnitsToChineseMoneyString(result);
return result;
}
public String format(double moneyDouble) {
return format(numberFormat.format(moneyDouble));
}
public String format(int moneyInt) {
return format(numberFormat.format(moneyInt));
}
public String format(long moneyLong) {
return format(numberFormat.format(moneyLong));
}
public String format(Number moneyNum) {
return format(numberFormat.format(moneyNum));
}
private String convertToChineseNumber(String moneyStr) {
String result;
StringBuffer cMoneyStringBuffer = new StringBuffer();
for (int i = 0; i < moneyStr.length(); i++) {
cMoneyStringBuffer.append(chineseNumberMap.get(moneyStr.substring(i, i + 1)));
}
//拾佰仟萬億等都是漢字裏面纔有的單位,加上它們
int indexOfDot = cMoneyStringBuffer.indexOf(DOT);
int moneyPatternCursor = 1;
for (int i = indexOfDot - 1; i > 0; i--) {
cMoneyStringBuffer.insert(i, chineseMoneyPattern.get(EMPTY + moneyPatternCursor));
moneyPatternCursor = moneyPatternCursor == 8 ? 1 : moneyPatternCursor + 1;
}
String fractionPart = cMoneyStringBuffer.substring(cMoneyStringBuffer.indexOf('.'));
cMoneyStringBuffer.delete(cMoneyStringBuffer.indexOf('.'), cMoneyStringBuffer.length());
while (cMoneyStringBuffer.indexOf('零拾') != -1) {
cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf('零拾'), cMoneyStringBuffer.indexOf('零拾') + 2, ZERO);
}
while (cMoneyStringBuffer.indexOf('零佰') != -1) {
cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf('零佰'), cMoneyStringBuffer.indexOf('零佰') + 2, ZERO);
}
while (cMoneyStringBuffer.indexOf('零仟') != -1) {
cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf('零仟'), cMoneyStringBuffer.indexOf('零仟') + 2, ZERO);
}
while (cMoneyStringBuffer.indexOf('零萬') != -1) {
cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf('零萬'), cMoneyStringBuffer.indexOf('零萬') + 2, TEN_THOUSAND);
}
while (cMoneyStringBuffer.indexOf('零億') != -1) {
cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf('零億'), cMoneyStringBuffer.indexOf('零億') + 2, HUNDRED_MILLION);
}
while (cMoneyStringBuffer.indexOf('零零') != -1) {
cMoneyStringBuffer.replace(cMoneyStringBuffer.indexOf('零零'), cMoneyStringBuffer.indexOf('零零') + 2, ZERO);
}
if (cMoneyStringBuffer.lastIndexOf(ZERO) == cMoneyStringBuffer.length() - 1)
cMoneyStringBuffer.delete(cMoneyStringBuffer.length() - 1, cMoneyStringBuffer.length());
cMoneyStringBuffer.append(fractionPart);
result = cMoneyStringBuffer.toString();
return result;
}
private String addUnitsToChineseMoneyString(String moneyStr) {
String result;
StringBuffer cMoneyStringBuffer = new StringBuffer(moneyStr);
int indexOfDot = cMoneyStringBuffer.indexOf(DOT);
cMoneyStringBuffer.replace(indexOfDot, indexOfDot + 1, YUAN);