MP源代碼:
<object align=middle classid=CLSID:22d6f312-b0f6-11d0-94ab-0080c74c7e95 class=OBJECT id=MediaPlayer width=160 height=168 >
<PARAM NAME=AUTOSTART VALUE=0 >
<param name=ShowStatusBar value=-1>
<param name=Filename value=http://xiaoping.cqie.cn/wmv/jler.wmv>
<embed
type=application/x-oleobject
codebase=http://activex.microsoft.com/activex/controls/mplayer/en/nsmp2inf.cab#Version=5,1,52,701
flename=mp src="</embed>
</object>
53.樹狀顯示js代碼
(要求:某行文本前面有一個加號的標(biāo)簽,一點擊加號變成減號,同時該行展開它之下所屬信息,以縮進(jìn)形式呈現(xiàn),再點擊減號又變回加號、下面展開的文本收回,這應(yīng)該怎么做?除了js方式有什么其他方式實現(xiàn)么?謝謝!)
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>無標(biāo)題文檔</title>
<script language="javascript">
function showLay(divId){
??????? var objDiv = eval(divId);
??????? if (objDiv.style.display=="none"){
??????????????? eval("sp"+divId+".innerHTML='-'");
??????????????? objDiv.style.display="";
??????? }else{
??????????????? eval("sp"+divId+".innerHTML='+'");
??????????????? objDiv.style.display="none";
??????? }}
</script>
</head>
<body>
<a href="#" onclick="showLay('Layer1')"><span id="spLayer1">+</span>a</a><br>
<div id="Layer1" style="display:none;">
|-<a href="insert_unit_info.html" target="body">a1</a><br>
|-<a href="select_unit_info.jsp" target="body">a2</a><br>
</div>
<a href="#" onclick="showLay('Layer2')"><span id="spLayer2">+</span>b</a><BR>
<div id="Layer2" style="display:none;">
|-<a href="insert_item_info.html" target="body">b1</a><br>
|-<a href="select_item_info.jsp" target="body">b2</a><br>
</div>
<a href="#" onclick="showLay('Layer3')"><span id="spLayer3">+</span>c</a><BR>
<div id="Layer3" style="display:none;">
|-<a href="insert_expert_info.html" target="body">c1</a><br>
|-<a href="select_expert_info.jsp" target="body">c2</a><br>
</div>
<a href="#" onclick="showLay('Layer4')"><span id="spLayer4">+</span>d</a><BR>
<div id="Layer4" style="display:none;">
|-d1<br>
|-d2<br>
</div>
</body>
</html>
54.下拉菜單(新建個.html文件,把代碼考進(jìn)去就行)
<html>
<head>
<title>打造下拉菜單</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<script language="javascript">
function MM_reloadPage(init) {? //reloads the window if Nav4 resized
? if (init==true) with (navigator) {if ((appName=="Netscape")&&(parseInt(appVersion)==4)) {
??? document.MM_pgW=innerWidth; document.MM_pgH=innerHeight; onresize=MM_reloadPage; }}
? else if (innerWidth!=document.MM_pgW || innerHeight!=document.MM_pgH) location.reload();
}
MM_reloadPage(true);
function MM_findObj(n, d) { //v4.0
? var p,i,x;? if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) {
??? d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);}
? if(!(x=d[n])&&d.all) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n];
? for(i=0;!x&&d.layers&&i<d.layers.length;i++) x=MM_findObj(n,d.layers[i].document);
? if(!x && document.getElementById) x=document.getElementById(n); return x;
}
function MM_showHideLayers() { //v3.0
? var i,p,v,obj,args=MM_showHideLayers.arguments;
? for (i=0; i<(args.length-2); i+=3) if ((obj=MM_findObj(args[i]))!=null) { v=args[i+2];
??? if (obj.style) { obj=obj.style; v=(v=='show')?'visible':(v='hide')?'hidden':v; }
??? obj.visibility=v; }
}
</script>
</head>
<body bgcolor="#CCCCCC" text="#000000" leftmargin="0" topmargin="0" marginwidth="0" marginheight="0" scroll=auto>
<div id="title" style="position:absolute; left:8px; top:15px; width:240px; height:15px; z-index:1; background-color: #006699;
layer-background-color: #006699; border: 1px none #000000">
? <table width="480" cellspacing="0" cellpadding="2">
??? <tr>
?????
<td width="120" onMouseOver="MM_showHideLayers('menu1','','show')"
onMouseOut="MM_showHideLayers
('menu1','','hide')"><b><font color="#FFFFFF"><a href="#">■
??????? 經(jīng)典論壇</a></font></b> </td>
??? </tr>
? </table>
</div>
<div id="menu1" style="position:absolute; left:8px; top:34px; width:120px; height:80px; z-index:2; background-color: #999966;
layer-background-color: #999966; border: 1px none #000000; visibility: hidden" onMouseOver="MM_showHideLayers
('menu1','','show')" onMouseOut="MM_showHideLayers('menu1','','hide')">
? <table width="100%" cellspacing="0" cellpadding="2" height="80">
??? <tr>
????? <td> <a href="#">Dreamweaver 專欄</a></td>
??? </tr>
??? <tr>
????? <td> <a href="#">Fireworks 專欄</a></td>
??? </tr>
??? <tr>
????? <td> <a href="#">Flash 基本操作</a></td>
??? </tr>
??? <tr>
????? <td> <a href="#">Flash 5 Action</a></td>
??? </tr>
? </table>
</div>
</body>
</html>
55.防止下載網(wǎng)頁信息(例如顯示受控文件)的簡單方法:
a。屏蔽鼠標(biāo)左右鍵,<body oncontextmenu=self.event.returnValue=false onselectstart="return false">
b。加密網(wǎng)頁源文件,推薦Batch Html Encryptor加密軟件。
c.用Adobe Acrobat 6.0 Standard軟件加密。
?
55。此方法顯示下拉框默認(rèn)值
<select name="max">
?<option value="1">第一名</option>
?<option value="2">第二名</option>
?<option value="3">第三名</option>
</select>
<script>document.all("max").value="3"</script>
56.用javascript設(shè)置輸入框焦點
<html>
<head>
<script language="javascript">
function t() {
document.getElementById('aa').focus();?
}??????????????????????????
<!--設(shè)置id為aa的元素得到焦點-->
</script>
</head>
<body onload="javascript:t()">
<input type="text" id="aa"> <!--設(shè)置文本輸入框的id為aa-->
</body>
</html>
57.select標(biāo)簽下的OPTION標(biāo)簽沒有value屬性時,把內(nèi)容當(dāng)屬性傳過去,比如<OPTION>所有用戶</OPTION>傳的值就是所有用戶,建議用以下方法。
<select name="account.accountId" >
????<OPTION value="">所有日志</OPTION>
????<OPTION value="renyang">任楊</OPTION>
</select>
58.不保留緩存方法:
<%
response.setHeader("Pragma", "No-cache");
response.setHeader("Cache-Control", "no-cache");
response.setHeader("Cache-Control", "must-revalidate");
response.setDateHeader("Expires",0);
%>
59.全選、全不選js方法 (直接放在.htm文件中即可)
<SCRIPT language="javascript">
function checkAll(e, itemName)
{
? var aa = document.getElementsByName(itemName);
? for (var i=0; i<aa.length; i++)
?? aa[i].checked = e.checked;
}
function check(e, allName)
{
? var all = document.getElementsByName(allName)[0];
? if(!e.checked) all.checked = false;
? else
? {
??? var aa = document.getElementsByName(e.name);
??? for (var i=0; i<aa.length; i++)
???? if(!aa[i].checked) return;
??? all.checked = true;
? }
}
</SCRIPT>
<input type=checkbox name=allPersons id=allPersons
onclick="checkAll(this, 'persons')"> <label
for="allPersons">全選</label><br>
<input type="checkbox" name="persons" id=persons
value="1"> <label
for="persons">第一名</label><br>
<input type="checkbox" name="persons" id=persons
value="2"> <label
for="persons">第二名</label><br>
<!-- 問題:第一名和第二名這兩個字ID不能一樣,否則點第二名這三個字時第一名前的框變化 -->
posted @
2006-08-16 16:42 阿成 閱讀(1119) |
評論 (0) |
編輯 收藏
//對于gb2312來講, 首字節(jié)碼位從0×81 至0×FE,尾字節(jié)碼位分別是0×40 至0×FE
//本例是驗證此串是否含有g(shù)b2312格式的字符,即是否含有漢字
public class Test{
? public boolean isGB2312( String str )
? {
??? char[] chars = str.toCharArray();
??? boolean isGB2312 = false;
??? for ( int i = 0; i < chars.length; i++ )
??? {
????? byte[] bytes = ( "" + chars[i] ).getBytes();
????? if ( bytes.length == 2 )
????? {
??????? int[] ints = new int[2];
??????? ints[0] = bytes[0] & 0xff;
??????? ints[1] = bytes[1] & 0xff;
??????? if ( ints[0] >= 0x81 && ints[0] <= 0xFE && ints[1] >= 0x40 && ints[1] <= 0xFE )
??????? {
????????? isGB2312 = true;
????????? break;
??????? }
????? }
??? }
??? return isGB2312;
? }
?
? public static void main(String[] args)
? {
??? String s = "ss您好ss";//結(jié)果為true
??? String s = "ssssss";//結(jié)果為false
??? Test test = new Test();
??? System.out.println(test.isGB2312(s));
? }
}
posted @
2006-08-16 16:38 阿成 閱讀(482) |
評論 (0) |
編輯 收藏
插入排序:
package org.rut.util.algorithm.support;
import org.rut.util.algorithm.SortUtil;
/**
?* @author treeroot
?* @since 2006-2-2
?* @version 1.0
?*/
public class InsertSort implements SortUtil.Sort{
??? /* (non-Javadoc)
???? * @see org.rut.util.algorithm.SortUtil.Sort#sort(int[])
???? */
??? public void sort(int[] data) {
??????? int temp;
??????? for(int i=1;i<data.length;i++){
??????????? for(int j=i;(j>0)&&(data[j]<data[j-1]);j--){
??????????????? SortUtil.swap(data,j,j-1);
??????????? }
??????? }???????
??? }
}
冒泡排序:
package org.rut.util.algorithm.support;
import org.rut.util.algorithm.SortUtil;
/**
?* @author treeroot
?* @since 2006-2-2
?* @version 1.0
?*/
public class BubbleSort implements SortUtil.Sort{
??? /* (non-Javadoc)
???? * @see org.rut.util.algorithm.SortUtil.Sort#sort(int[])
???? */
??? public void sort(int[] data) {
??????? int temp;
??????? for(int i=0;i<data.length;i++){
??????????? for(int j=data.length-1;j>i;j--){
??????????????? if(data[j]<data[j-1]){
??????????????????? SortUtil.swap(data,j,j-1);
??????????????? }
??????????? }
??????? }
??? }
}
選擇排序:
package org.rut.util.algorithm.support;
import org.rut.util.algorithm.SortUtil;
/**
?* @author treeroot
?* @since 2006-2-2
?* @version 1.0
?*/
public class SelectionSort implements SortUtil.Sort {
??? /*
???? * (non-Javadoc)
???? *
???? * @see org.rut.util.algorithm.SortUtil.Sort#sort(int[])
???? */
??? public void sort(int[] data) {
??????? int temp;
??????? for (int i = 0; i < data.length; i++) {
??????????? int lowIndex = i;
??????????? for (int j = data.length - 1; j > i; j--) {
??????????????? if (data[j] < data[lowIndex]) {
??????????????????? lowIndex = j;
??????????????? }
??????????? }
??????????? SortUtil.swap(data,i,lowIndex);
??????? }
??? }
}
Shell排序:
package org.rut.util.algorithm.support;
import org.rut.util.algorithm.SortUtil;
/**
?* @author treeroot
?* @since 2006-2-2
?* @version 1.0
?*/
public class ShellSort implements SortUtil.Sort{
??? /* (non-Javadoc)
???? * @see org.rut.util.algorithm.SortUtil.Sort#sort(int[])
???? */
??? public void sort(int[] data) {
??????? for(int i=data.length/2;i>2;i/=2){
??????????? for(int j=0;j<i;j++){
??????????????? insertSort(data,j,i);
??????????? }
??????? }
??????? insertSort(data,0,1);
??? }
??? /**
???? * @param data
???? * @param j
???? * @param i
???? */
??? private void insertSort(int[] data, int start, int inc) {
??????? int temp;
??????? for(int i=start+inc;i<data.length;i+=inc){
??????????? for(int j=i;(j>=inc)&&(data[j]<data[j-inc]);j-=inc){
??????????????? SortUtil.swap(data,j,j-inc);
??????????? }
??????? }
??? }
}
快速排序:
package org.rut.util.algorithm.support;
import org.rut.util.algorithm.SortUtil;
/**
?* @author treeroot
?* @since 2006-2-2
?* @version 1.0
?*/
public class QuickSort implements SortUtil.Sort{
??? /* (non-Javadoc)
???? * @see org.rut.util.algorithm.SortUtil.Sort#sort(int[])
???? */
??? public void sort(int[] data) {
??????? quickSort(data,0,data.length-1);???????
??? }
??? private void quickSort(int[] data,int i,int j){
??????? int pivotIndex=(i+j)/2;
??????? //swap
??????? SortUtil.swap(data,pivotIndex,j);
???????
??????? int k=partition(data,i-1,j,data[j]);
??????? SortUtil.swap(data,k,j);
??????? if((k-i)>1) quickSort(data,i,k-1);
??????? if((j-k)>1) quickSort(data,k+1,j);
???????
??? }
??? /**
???? * @param data
???? * @param i
???? * @param j
???? * @return
???? */
??? private int partition(int[] data, int l, int r,int pivot) {
??????? do{
?????????? while(data[++l]<pivot);
?????????? while((r!=0)&&data[--r]>pivot);
?????????? SortUtil.swap(data,l,r);
??????? }
??????? while(l<r);
??????? SortUtil.swap(data,l,r);???????
??????? return l;
??? }
}
改進(jìn)后的快速排序:
package org.rut.util.algorithm.support;
import org.rut.util.algorithm.SortUtil;
/**
?* @author treeroot
?* @since 2006-2-2
?* @version 1.0
?*/
public class ImprovedQuickSort implements SortUtil.Sort {
??? private static int MAX_STACK_SIZE=4096;
??? private static int THRESHOLD=10;
??? /* (non-Javadoc)
???? * @see org.rut.util.algorithm.SortUtil.Sort#sort(int[])
???? */
??? public void sort(int[] data) {
??????? int[] stack=new int[MAX_STACK_SIZE];
???????
??????? int top=-1;
??????? int pivot;
??????? int pivotIndex,l,r;
???????
??????? stack[++top]=0;
??????? stack[++top]=data.length-1;
???????
??????? while(top>0){
??????????? int j=stack[top--];
??????????? int i=stack[top--];
???????????
??????????? pivotIndex=(i+j)/2;
??????????? pivot=data[pivotIndex];
???????????
??????????? SortUtil.swap(data,pivotIndex,j);
???????????
??????????? //partition
??????????? l=i-1;
??????????? r=j;
??????????? do{
??????????????? while(data[++l]<pivot);
??????????????? while((r!=0)&&(data[--r]>pivot));
??????????????? SortUtil.swap(data,l,r);
??????????? }
??????????? while(l<r);
??????????? SortUtil.swap(data,l,r);
??????????? SortUtil.swap(data,l,j);
???????????
??????????? if((l-i)>THRESHOLD){
??????????????? stack[++top]=i;
??????????????? stack[++top]=l-1;
??????????? }
??????????? if((j-l)>THRESHOLD){
??????????????? stack[++top]=l+1;
??????????????? stack[++top]=j;
??????????? }
???????????
??????? }
??????? //new InsertSort().sort(data);
??????? insertSort(data);
??? }
??? /**
???? * @param data
???? */
??? private void insertSort(int[] data) {
??????? int temp;
??????? for(int i=1;i<data.length;i++){
??????????? for(int j=i;(j>0)&&(data[j]<data[j-1]);j--){
??????????????? SortUtil.swap(data,j,j-1);
??????????? }
??????? }??????
??? }
}
歸并排序:
package org.rut.util.algorithm.support;
import org.rut.util.algorithm.SortUtil;
/**
?* @author treeroot
?* @since 2006-2-2
?* @version 1.0
?*/
public class MergeSort implements SortUtil.Sort{
??? /* (non-Javadoc)
???? * @see org.rut.util.algorithm.SortUtil.Sort#sort(int[])
???? */
??? public void sort(int[] data) {
??????? int[] temp=new int[data.length];
??????? mergeSort(data,temp,0,data.length-1);
??? }
???
??? private void mergeSort(int[] data,int[] temp,int l,int r){
??????? int mid=(l+r)/2;
??????? if(l==r) return ;
??????? mergeSort(data,temp,l,mid);
??????? mergeSort(data,temp,mid+1,r);
??????? for(int i=l;i<=r;i++){
??????????? temp[i]=data[i];
??????? }
??????? int i1=l;
??????? int i2=mid+1;
??????? for(int cur=l;cur<=r;cur++){
??????????? if(i1==mid+1)
??????????????? data[cur]=temp[i2++];
??????????? else if(i2>r)
??????????????? data[cur]=temp[i1++];
??????????? else if(temp[i1]<temp[i2])
??????????????? data[cur]=temp[i1++];
??????????? else
??????????????? data[cur]=temp[i2++];???????????
??????? }
??? }
}
改進(jìn)后的歸并排序:
package org.rut.util.algorithm.support;
import org.rut.util.algorithm.SortUtil;
/**
?* @author treeroot
?* @since 2006-2-2
?* @version 1.0
?*/
public class ImprovedMergeSort implements SortUtil.Sort {
??? private static final int THRESHOLD = 10;
??? /*
???? * (non-Javadoc)
???? *
???? * @see org.rut.util.algorithm.SortUtil.Sort#sort(int[])
???? */
??? public void sort(int[] data) {
??????? int[] temp=new int[data.length];
??????? mergeSort(data,temp,0,data.length-1);
??? }
??? private void mergeSort(int[] data, int[] temp, int l, int r) {
??????? int i, j, k;
??????? int mid = (l + r) / 2;
??????? if (l == r)
??????????? return;
??????? if ((mid - l) >= THRESHOLD)
??????????? mergeSort(data, temp, l, mid);
??????? else
??????????? insertSort(data, l, mid - l + 1);
??????? if ((r - mid) > THRESHOLD)
??????????? mergeSort(data, temp, mid + 1, r);
??????? else
??????????? insertSort(data, mid + 1, r - mid);
??????? for (i = l; i <= mid; i++) {
??????????? temp[i] = data[i];
??????? }
??????? for (j = 1; j <= r - mid; j++) {
??????????? temp[r - j + 1] = data[j + mid];
??????? }
??????? int a = temp[l];
??????? int b = temp[r];
??????? for (i = l, j = r, k = l; k <= r; k++) {
??????????? if (a < b) {
??????????????? data[k] = temp[i++];
??????????????? a = temp[i];
??????????? } else {
??????????????? data[k] = temp[j--];
??????????????? b = temp[j];
??????????? }
??????? }
??? }
??? /**
???? * @param data
???? * @param l
???? * @param i
???? */
??? private void insertSort(int[] data, int start, int len) {
??????? for(int i=start+1;i<start+len;i++){
??????????? for(int j=i;(j>start) && data[j]<data[j-1];j--){
??????????????? SortUtil.swap(data,j,j-1);
??????????? }
??????? }
??? }
}
堆排序:
package org.rut.util.algorithm.support;
import org.rut.util.algorithm.SortUtil;
/**
?* @author treeroot
?* @since 2006-2-2
?* @version 1.0
?*/
public class HeapSort implements SortUtil.Sort{
??? /* (non-Javadoc)
???? * @see org.rut.util.algorithm.SortUtil.Sort#sort(int[])
???? */
??? public void sort(int[] data) {
??????? MaxHeap h=new MaxHeap();
??????? h.init(data);
??????? for(int i=0;i<data.length;i++)
??????????? h.remove();
??????? System.arraycopy(h.queue,1,data,0,data.length);
??? }
???? private static class MaxHeap{
????????
???????
??????? void init(int[] data){
??????????? this.queue=new int[data.length+1];
??????????? for(int i=0;i<data.length;i++){
??????????????? queue[++size]=data[i];
??????????????? fixUp(size);
??????????? }
??????? }
????????
??????? private int size=0;
??????? private int[] queue;
???????????????
??????? public int get() {
??????????? return queue[1];
??????? }
??????? public void remove() {
??????????? SortUtil.swap(queue,1,size--);
??????????? fixDown(1);
??????? }
??????? //fixdown
??????? private void fixDown(int k) {
??????????? int j;
??????????? while ((j = k << 1) <= size) {
??????????????? if (j < size && queue[j]<queue[j+1])
??????????????????? j++;
??????????????? if (queue[k]>queue[j]) //不用交換
??????????????????? break;
??????????????? SortUtil.swap(queue,j,k);
??????????????? k = j;
??????????? }
??????? }
??????? private void fixUp(int k) {
??????????? while (k > 1) {
??????????????? int j = k >> 1;
??????????????? if (queue[j]>queue[k])
??????????????????? break;
??????????????? SortUtil.swap(queue,j,k);
??????????????? k = j;
??????????? }
??????? }
??? }
}
?
SortUtil:
package org.rut.util.algorithm;
import org.rut.util.algorithm.support.BubbleSort;
import org.rut.util.algorithm.support.HeapSort;
import org.rut.util.algorithm.support.ImprovedMergeSort;
import org.rut.util.algorithm.support.ImprovedQuickSort;
import org.rut.util.algorithm.support.InsertSort;
import org.rut.util.algorithm.support.MergeSort;
import org.rut.util.algorithm.support.QuickSort;
import org.rut.util.algorithm.support.SelectionSort;
import org.rut.util.algorithm.support.ShellSort;
/**
?* @author treeroot
?* @since 2006-2-2
?* @version 1.0
?*/
public class SortUtil {
??? public final static int INSERT = 1;
??? public final static int BUBBLE = 2;
??? public final static int SELECTION = 3;
??? public final static int SHELL = 4;
??? public final static int QUICK = 5;
??? public final static int IMPROVED_QUICK = 6;
??? public final static int MERGE = 7;
??? public final static int IMPROVED_MERGE = 8;
??? public final static int HEAP = 9;
??? public static void sort(int[] data) {
??????? sort(data, IMPROVED_QUICK);
??? }
??? private static String[] name={
??????????? "insert","bubble","selection","shell","quick","improved_quick","merge","improved_merge","heap"
??? };
???
??? private static Sort[] impl=new Sort[]{
??????????? new InsertSort(),
??????????? new BubbleSort(),
??????????? new SelectionSort(),
??????????? new ShellSort(),
??????????? new QuickSort(),
??????????? new ImprovedQuickSort(),
??????????? new MergeSort(),
??????????? new ImprovedMergeSort(),
??????????? new HeapSort()
??? };
??? public static String toString(int algorithm){
??????? return name[algorithm-1];
??? }
???
??? public static void sort(int[] data, int algorithm) {
??????? impl[algorithm-1].sort(data);
??? }
??? public static interface Sort {
??????? public void sort(int[] data);
??? }
??? public static void swap(int[] data, int i, int j) {
??????? int temp = data[i];
??????? data[i] = data[j];
??????? data[j] = temp;
??? }
}
posted @
2006-08-16 16:06 阿成 閱讀(302) |
評論 (0) |
編輯 收藏
一、一對多映射
1、在映射一對多的雙相關(guān)聯(lián)關(guān)系時,應(yīng)該在one方把inverse屬性設(shè)為true,可以提高應(yīng)用的性能。
2、建立兩個對象的雙向關(guān)聯(lián)時,應(yīng)該同時修改關(guān)聯(lián)兩端的對象的應(yīng)用屬性,這樣使程序更加健壯,提高業(yè)務(wù)邏輯層的獨立性,使業(yè)務(wù)邏輯層的程序代碼不受hibernate實現(xiàn)的影響;同理,當(dāng)解除雙相關(guān)聯(lián)關(guān)系時,也應(yīng)該修改關(guān)聯(lián)兩端的對象的相應(yīng)屬性。
eg://添加
customer.getOrders().add(order);
order.setCustomer(customer);
//刪除
customer.getOrders().remove(order);
order.setCustomer(null);
3、在定義一對多映射中“一”的POJO類時,注意要private Set orders?= new HashSet();//通常把它初始化為集合實現(xiàn)類的一個實例,這樣避免訪問取值為null,引發(fā)NullPointerException異常,提高健壯性。
二、Session三種檢索方法:
1.load():根據(jù)給定OID從數(shù)據(jù)庫中加載一個持久化對象,如數(shù)據(jù)庫中沒有則拋出net.sf.hibernate.ObjectNotFoundException異常。
2.get():根據(jù)給定OID從數(shù)據(jù)庫中加載一個持久化對象,如數(shù)據(jù)庫中沒有則返回null。
3.find():按照參數(shù)指定的HQL語句加載一個或多個持久化對象,實際是HQL檢索方式的一種簡寫形式。
三、hql查詢:
在數(shù)組和Collection中的查詢:
String hql = "select??u from?User u where u in (:users)";
query.setParameterList("users", users);
//括號千萬別忘寫,否則出現(xiàn)如下錯誤:
2006-07-07 11:07:35 WARN [org.hibernate.util.JDBCExceptionReporter] - SQL Error: 907, SQLState: 42000
2006-07-07 11:07:35 ERROR [org.hibernate.util.JDBCExceptionReporter] - ORA-00907: 缺失右括號
posted @
2006-08-16 15:37 阿成 閱讀(420) |
評論 (0) |
編輯 收藏
Java FAQ
?
目錄:
Q1.1 什么是Java、Java2、JDK?JDK后面的1.3、1.4版本號又是怎么回事?
Q1.2 什么是JRE/J2RE?
Q1.3 學(xué)習(xí)Java用什么工具比較好?
Q1.4? 學(xué)習(xí)Java有哪些好的參考書?
Q1.5? Java和C++哪個更好?
Q1.6? 什么是J2SE/J2EE/J2ME?
Q2.1? 我寫了第一個Java程序,應(yīng)該如何編譯/運行?
Q2.2? 我照你說的做了,但是出現(xiàn)什么“'javac' 不是內(nèi)部或外部命令,也不是可運行的
程序或批處理文件。”。
Q2.3? 環(huán)境變量怎么設(shè)置?
Q2.4? 我在javac xxx.java的時候顯示什么“unreported exception java.io.IOExcepti
on;”。
Q2.5? javac xxx.java順利通過了,但是java xxx的時候顯示什么“NoClassDefFoundErr
or”。
Q2.6? 我在java xxx的時候顯示“Exception in thread "main" java.lang.NoSuchMetho
dError: main”。
Q2.7? 在java xxx的時候顯示“Exception in thread "main" java.lang.NullPointerEx
ception”。
Q2.8 package是什么意思?怎么用?
Q2.9 我沒有聲明任何package會怎么樣?
Q2.10 在一個類中怎么使用其他類?
Q2.11 我用了package的時候顯示"NoClassDefFoundError",但是我把所有package去掉的
時候能正常運行。
Q2.12 我想把java編譯成exe文件,該怎么做?
Q2.13 我在編譯的時候遇到什么"deprecated API",是什么意思?
Q3.1 我怎么給java程序加啟動參數(shù),就像dir /p/w那樣?
Q3.2 我怎么從鍵盤輸入一個int/double/字符串?
Q3.3 我怎么輸出一個int/double/字符串?
Q3.4 我發(fā)現(xiàn)有些書上直接用System.in輸入,比你要簡單得多。
Q3.5 我怎么從文件輸入一個int/double/字符串?
Q3.6 我想讀寫文件的指定位置,該怎么辦?
Q3.7 怎么判斷要讀的文件已經(jīng)到了盡頭?
Q4.1? java里面怎么定義宏?
Q4.2? java里面沒法用const。
Q4.3? java里面也不能用goto。
Q4.4? java里面能不能重載操作符?
Q4.5? 我new了一個對象,但是沒法delete掉它。
Q4.6? 我想知道為什么main方法必須被聲明為public static?為什么在main方法中不能調(diào)
用非static成員?
Q4.7? throw和throws有什么不同?
Q4.8? 什么是異常?
Q4.9? final和finally有什么不同?
Q5.1? extends和implements有什么不同?
Q5.2? java怎么實現(xiàn)多繼承?
Q5.3 abstract是什么?
Q5.4 public,protected,private有什么不同?
Q5.5 Override和Overload有什么不同?
Q5.6 我繼承了一個方法,但現(xiàn)在我想調(diào)用在父類中定義的方法。
Q5.7 我想在子類的構(gòu)造方法中調(diào)用父類的構(gòu)造方法,該怎么辦?
Q5.8 我在同一個類中定義了好幾個構(gòu)造方法并且想在一個構(gòu)造方法中調(diào)用另一個。
Q5.9 我沒有定義構(gòu)造方法會怎么樣?
Q5.10 我調(diào)用無參數(shù)的構(gòu)造方法失敗了。
Q5.11 我該怎么定義類似于C++中的析構(gòu)方法(destructor)?
Q5.12 我想將一個父類對象轉(zhuǎn)換成一個子類對象該怎么做?
Q5.13 其實我不確定a是不是B的實例,能不能分情況處理?
Q5.14 我在方法里修改了一個對象的值,但是退出方法后我發(fā)現(xiàn)這個對象的值沒變!
Q6.1 java能動態(tài)分配數(shù)組嗎?
Q6.2 我怎么知道數(shù)組的長度?
Q6.3 我還想讓數(shù)組的長度能自動改變,能夠增加/刪除元素。
Q???? 什么是鏈表?為什么要有ArrayList和LinkedList兩種List?
Q6.5 我想用隊列/棧。
Q6.6 我希望不要有重復(fù)的元素。
Q6.7 我想遍歷集合/Map。
Q6.8 我還要能夠排序。
Q6.9 但是我想給數(shù)組排序。
Q6.10 我想按不同方式排序。
Q6.11 Map有什么用?
Q6.12 set方法沒問題,但是get方法返回的是Object。
Q6.13 ArrayList和Vector有什么不同?HashMap和Hashtable有什么不同?
Q6.14 我要獲得一個隨機(jī)數(shù)。
Q6.15 我比較兩個String總是false,但是它們明明都是"abc" !
Q6.16 我想修改一個String但是在String類中沒找到編輯方法。
Q6.17 我想處理日期/時間。
一、準(zhǔn)備篇
Q1.1 什么是Java、Java2、JDK?JDK后面的1.3、1.4版本號又是怎么回事?
答:Java是一種通用的,并發(fā)的,強(qiáng)類型的,面向?qū)ο蟮木幊陶Z言(摘自Java規(guī)范第二版
)。
JDK是Sun公司分發(fā)的免費Java開發(fā)工具包,正式名稱為J2SDK(Java2 Software Develop K
it)。
包括基本的java工具包和標(biāo)準(zhǔn)類庫。
到目前(2003年7月)為止,Java有3個主要版本,即1.0,1.1,2.0;
JDK有1.0,1.1,1.2,1.3,1.4五個版本。
從JDK1.2起,Sun公司覺得Java改變足夠大而將java語言版本號提升為2.0。
不同的JDK主要在于提供的類庫不同。作為學(xué)習(xí)你可以下載最新的JDK1.4.2。
真正開發(fā)時則應(yīng)考慮向前兼容,比如1.3。下載請去http://java.sun.com。
JDK1.5預(yù)計將在2004年推出,屆時其中將包含若干嶄新的特性。
Q1.2 什么是JRE/J2RE?
答:J2RE是Java2 Runtime Environment,即Java運行環(huán)境,有時簡稱JRE。
如果你只需要運行Java程序或Applet,下載并安裝它即可。
如果你要自行開發(fā)Java軟件,請下載JDK。在JDK中附帶有JRE。
注意由于Microsoft對Java的支持不完全,請不要使用IE自帶的虛擬機(jī)來運行Applet,務(wù)必
安裝一個JRE或JDK。
Q1.3 學(xué)習(xí)Java用什么工具比較好?
答:作者建議首先使用JDK+文本編輯器,這有助你理解下列幾個基礎(chǔ)概念:path,classp
ath,package
并熟悉基本命令:javac和java。并且下載和你的JDK版本一致的API幫助。
如果你不確定類或函數(shù)的用法,請先查閱API而不是發(fā)貼求助。
當(dāng)你熟悉Java之后,你可以考慮開始使用一個IDE。
作者推薦eclipse,下載網(wǎng)址http://www.eclipse.org。因為eclispe是免費的,插件化的
。
eclispe的主要缺點是缺乏一個可視化的桌面程序開發(fā)工具,
幸運的是IBM在2003年11月已經(jīng)將部分代碼捐給eclipse組織,可以預(yù)計這個缺點很快就會
得到彌補。
無論如何,請不要使用Microsoft的VJ++!眾所周知Microsoft從來就沒有認(rèn)真支持過Java
。
最后但并非最不重要,要有一本好的參考書,并且英文要過關(guān)。
Q1.4? 學(xué)習(xí)Java有哪些好的參考書?
答:作者首先推薦Thinking in Java,中文名《Java編程思想》,有中文版。
目前的最新版本是第三版。
在http://64.78.49.204可以免費下載英文版。
該書第一章介紹了很多面向?qū)ο蟮木幊趟枷耄鳛樾率謶?yīng)當(dāng)認(rèn)真閱讀。
除此以外,O'relly出版社和Wrox出版社的書也不錯。作者本人不喜歡大陸作者的書。
也許你覺得英文太難,但是網(wǎng)上大多數(shù)資料都是英文的。另外,你需要經(jīng)常查閱API,而那
也是英文的。
Q1.5? Java和C++哪個更好?
答:這個問題是一個很不恰當(dāng)?shù)膯栴}。你應(yīng)該問:Java和C++哪個更適用于我的項目?
Java的優(yōu)點和缺點一樣明顯。
跨平臺是Java的主要優(yōu)點,但代價是運行速度的下降。
VC和Windows平臺有良好的集成和足夠快的速度,但是也只能局限在Windows平臺上。
和C++相比,Java學(xué)起來更快,開發(fā)人員不會碰到很多容易出錯的特性。
但是VB程序員甚至只需要拼裝模塊就可以了。
Q1.6? 什么是J2SE/J2EE/J2ME?
答:J2SE就是一般的Java。
J2ME是針對嵌入式設(shè)備的,比如支持Java的手機(jī),它有自己的JRE和SDK。
J2EE是一組用于企業(yè)級程序開發(fā)的規(guī)范和類庫,它使用J2SE的JRE。
二、命令篇
Q2.1? 我寫了第一個Java程序,應(yīng)該如何編譯/運行?
答:首先請將程序保存為xxx.java文件,注意你可能需要修改文件后綴名。
然后在dos窗口下使用javac xxx.java命令,你會發(fā)現(xiàn)該目錄下多了一個xxx.class文件,
再使用java xxx命令,你的java程序就開始運行了。
Q2.2? 我照你說的做了,但是出現(xiàn)什么“'javac' 不是內(nèi)部或外部命令,也不是可運行的
程序或批處理文件。”。
答:你遇到了path問題。操作系統(tǒng)在一定的范圍(path)內(nèi)搜索javac.exe,但是沒能找到。
請編輯你的操作系統(tǒng)環(huán)境變量,新增一個JAVA_HOME變量,設(shè)為你JDK的安裝目錄,
再編輯Path變量,加上一項 %JAVA_HOME%\bin。
然后保存并新開一個dos窗口,你就可以使用javac和java命令了。
Q2.3? 環(huán)境變量怎么設(shè)置?
答:請向身邊會設(shè)的人咨詢。
Q2.4? 我在javac xxx.java的時候顯示什么“unreported exception java.io.IOExcepti
on;”。
答:參見Q4.8以了解java中的異常機(jī)制。
Q2.5? javac xxx.java順利通過了,但是java xxx的時候顯示什么“NoClassDefFoundErr
or”。
答:1. 你遇到了classpath問題。java命令在一定的范圍(classpath)內(nèi)搜索你直接或間接
使用的class文件,但是未能找到。
首先請確認(rèn)你沒有錯敲成java xxx.class,
其次,檢查你的CLASSPATH環(huán)境變量,其實你并不需要設(shè)置該變量,
但如果你設(shè)置了該變量又沒有包含.(代表當(dāng)前目錄)的項,
你就會遇到這個問題。請在你的CLASSPATH環(huán)境變量中加入一項. 或干脆刪掉這個變量。
2. 如果你使用了并非JDK自帶的標(biāo)準(zhǔn)包,比如javax.servlet.*包,也會遇到這個問題,請
將相應(yīng)的jar文件加入classpath。
3. 如果你在java源文件中定義了package,請參見Q2.11。
Q2.6? 我在java xxx的時候顯示“Exception in thread "main" java.lang.NoSuchMetho
dError: main”。
答:首先,在你的程序中每個java文件有且只能有一個public類,
這個類的類名必須和文件名的大小寫完全一樣。
其次,在你要運行的類中有且只能有一個public static void main(String[] args)方法
,
這個方法就是你的主程序。
Q2.7? 在java xxx的時候顯示“Exception in thread "main" java.lang.NullPointerEx
ception”。
答:在程序中你試圖在值為null的對象變量上調(diào)用方法,請檢查你的程序確保你的對象被恰當(dāng)?shù)某跏蓟?br />參見Q4.8以了解java中的異常機(jī)制。
Q2.8 package是什么意思?怎么用?
答:為了唯一標(biāo)識每個類并分組,java使用了package的概念。
每個類都有一個全名,例如String的全名是java.lang.String,其中java.lang是包名,S
tring是短名。按照java命名慣例,包名是全部小寫的,而類名的第一個字母是大寫的。
這樣,如果你自行定義了同樣名字的類String,你可以把它放在mypackage中,
通過使用全名mypackage.String和java.lang.String來區(qū)分這兩個類。
同時,將邏輯上相關(guān)的類放在同一個包中,可以使程序結(jié)構(gòu)更為清楚。
為了定義包,你要做的就是在java文件開頭加一行“package mypackage;”。
注意包沒有嵌套或包含關(guān)系,mypackage包和mypackage.mysubpackage包對JRE來說是并列的兩個包(雖然開發(fā)者可
能暗示包含關(guān)系)。
Q2.9 我沒有聲明任何package會怎么樣?
答:你的類被認(rèn)為放在默認(rèn)包中。這時全名和短名是一致的。
Q2.10 在一個類中怎么使用其他類?
答:如果你使用java.lang包或者默認(rèn)包中的類,不用做任何事。
如果你的類位于mypackage包中,并且要調(diào)用同一包中的其他類,也不用做任何事。
如果你使用其他包中的類,在package聲明之后,類聲明之前使用import otherpackage1.Class
1; 或 import otherpackage2.*;?
這里.*表示引入這個包中的所有類。然后在程序中你可以使用其他類的短名。
如果短名間有重名沖突,必須使用全名來區(qū)分。
注意在使用其他包中的類時,你只能使用public的類和接口,參見Q5.4。
Q2.11 我用了package的時候顯示"NoClassDefFoundError",但是我把所有package去掉的
時候能正常運行。
答:將你的java文件按包名組織存放。
比如你的工作目錄是/work,你的類是package1.Class1,那么將它存放為/work/package1
/Class1.java。
如果沒有聲明包,那么直接放在/work下。
在/work下執(zhí)行javac package1/class1.java,再執(zhí)行java package1.class1,你會發(fā)現(xiàn)一
切正常。
另外,如果你的類的個數(shù)已經(jīng)多到了你需要使用包來組織的話,你可以考慮開始使用IDE。
Q2.12 我想把java編譯成exe文件,該怎么做?
答:JDK只能將java源文件編譯為class文件。
class文件是一種跨平臺的字節(jié)碼,必須依賴平臺相關(guān)的JRE來運行。Java以此來實現(xiàn)跨平
臺性。
有些開發(fā)工具可以將java文件編譯為exe文件。作者反對這種做法,因為這樣就取消了跨平
臺性。
如果你確信你的軟件只在Windows平臺上運行,你可以考慮使用C++/C#來編程。
Q2.13 我在編譯的時候遇到什么"deprecated API",是什么意思?
答:所謂deprecated是指已經(jīng)過時,但是為了向前兼容起見仍然保留的方法。
這些方法可能會在以后取消支持。你應(yīng)當(dāng)改用較新的方法。
在API里面會說明你應(yīng)當(dāng)用什么方法來代替之。
三、I/O篇
Q3.1 我怎么給java程序加啟動參數(shù),就像dir /p/w那樣?
答:還記得public static void main(String[] args)嗎?這里的args就是你的啟動參數(shù)
。
在運行時你輸入java package1.class1 arg1 arg2,args中就會有兩個String,第一個是
arg1,第二個是arg2。
Q3.2 我怎么從鍵盤輸入一個int/double/字符串?
答:java的I/O操作比C++要復(fù)雜一點。如果要從鍵盤輸入,樣例代碼如下:
BufferedReader cin = new BufferedReader( new InputStreamReader( System.in ) );
String s = cin.readLine();
這樣你就獲得了一個字符串,如果你需要數(shù)字的話再使用:
int n = Integer.parseInt( s ); 或者 double d = Double.parseDouble( s );
來將字符串"534"轉(zhuǎn)換成int或double。
Q3.3 我怎么輸出一個int/double/字符串?
答:使用System.out.println(n)或者System.out.println("Hello")等等。
Q3.4 我發(fā)現(xiàn)有些書上直接用System.in輸入,比你要簡單得多。
答:java使用unicode,是雙字節(jié)。而System.in是單字節(jié)的stream。
如果你要輸入雙字節(jié)文字比如中文,請使用作者的做法。
Q3.5 我怎么從文件輸入/輸出一個int/double/字符串?
答:類似于從鍵盤輸入,只不過換成
BufferedReader fin = new BufferedReader( new FileReader(" myFileName " ) );
PrintWriter fout = new PrintWriter( new FileWriter(" myFileName " ) );
另外如果你還沒下載API,請開始下載并閱讀java.io包中的內(nèi)容。
Q3.6 我想讀寫文件的指定位置,該怎么辦?
答:java.io.RandomAccessFile可以滿足你的需要。
Q3.7 怎么判斷要讀的文件已經(jīng)到了盡頭?
答:在Reader的read方法中明確說明返回-1表示流的結(jié)尾。
四、 關(guān)鍵字篇
Q4.1? java里面怎么定義宏?
答:java不支持宏,因為宏代換不能保證類型安全。
如果你需要定義常量,可以將它定義為某個類的static final成員。參見Q4.2和Q4.6。
Q4.2? java里面沒法用const。
答:你可以用final關(guān)鍵字。例如 final int m = 9。被聲明為final的變量不能被再次賦
值。唯一的例外是所謂blank final,如下例所示:
public class MyClass1 {
??? private final int a = 3;
??? private final int b; // blank final
??? public MyClass1() {
??????? a = 5; // 不合法,final變量不能被再次賦值。
??????? b = 4; // 合法,這是b第一次被賦值。
??????? b = 6; // 不合法,b不能被再次賦值。
??? }
}
final也可以用于聲明方法或類,被聲明為final的方法或類不能被繼承。
注意const是java的保留字以備擴(kuò)充。
Q4.3? java里面也不能用goto。
答:甚至在面向過程的語言中你也可以完全不用goto。請檢查你的程序流程是否合理。
如果你需要從多層循環(huán)中迅速跳出,java增強(qiáng)了(和C++相比)break和continue的功能,
支持label。
例如:
outer :
while( ... )
{
inner :
for( ... )
{
?????????? ...?? break inner; ...
?????????? ... continue outer; ...
}
}
和const一樣,goto也是java的保留字以備擴(kuò)充。
Q4.4? java里面能不能重載操作符?
答:不能。String的+號是唯一一個內(nèi)置的重載操作符。你可以通過定義接口和方法來實現(xiàn)
類似功能。
Q4.5? 我new了一個對象,但是沒法delete掉它。
答:java有自動內(nèi)存回收機(jī)制,即所謂Garbarge Collection。你不需要刪除對象。你再也
不用擔(dān)心指針錯誤,內(nèi)存溢出了。
Q4.6? 我想知道為什么main方法必須被聲明為public static?為什么在main方法中不能調(diào)
用非static成員?
答:聲明為public是為了這個方法可以被外部調(diào)用,詳情見Q5.4。
static是為了將某個成員變量/方法關(guān)聯(lián)到類(class)而非實例(instance)。
你不需要創(chuàng)建一個對象就可以直接使用這個類的static成員,因而在static成員中不能調(diào)
用非static成員,因為后者是關(guān)聯(lián)到對象實例(instance)的。
在A類中調(diào)用B類的static成員可以使用B.staticMember的寫法。
注意一個類的static成員變量是唯一的,被所有該類對象所共享的,在多線程程序設(shè)計中尤其要謹(jǐn)慎小心。
類的static成員是在類第一次被JRE裝載的時候初始化的。
你可以使用如下方法來使用非static成員:
public class A
{
??? private void someMethod() //非static成員
??? {}
??? public static void main(String args)
??? {
???????? A a = new A();? //創(chuàng)建一個對象實例
???????? a.someMethod();? //現(xiàn)在你可以使用非static方法了
??? }
}
Q4.7? throw和throws有什么不同?
答:throws用于方法聲明中,聲明一個方法會拋出哪些異常。而throw是在方法體中實際執(zhí)行拋出異常的
動作。
如果你在方法中throw一個異常,卻沒有在方法聲明中聲明之,編譯器會報錯。
注意Error和RuntimeException的子類是例外,無需特別聲明。
Q4.8? 什么是異常?
答:異常最早在Ada語言中引入,用于在程序中動態(tài)處理錯誤并恢復(fù)。
你可以在方法中攔截底層異常并處理之,也可以拋給更高層的模塊去處理。
你也可以拋出自己的異常指示發(fā)生了某些不正常情況。常見的攔截處理代碼如下:
try
{
......//以下是可能發(fā)生異常的代碼
??????? ...... //異常被你或低層API拋出,執(zhí)行流程中斷并轉(zhuǎn)向攔截代碼。
??????? ......
}
catch(Exception1 e) //如果Exception1是Exception2的子類并要做特別處理,應(yīng)排在前
面
{
? //發(fā)生Exception1時被該段攔截
}
catch(Exception2 e)
{
? //發(fā)生Exception2時被該段攔截
}
finally //這是可選的
{
?? //無論異常是否發(fā)生,均執(zhí)行此段代碼
?? //即使在catch段中又向外拋出了新的exception,finally段也會得到執(zhí)行。
}
Q4.9? final和finally有什么不同?
答:final請見Q4.2。finally用于異常機(jī)制,參見Q4.8。
五、 面向?qū)ο笃?/p>
Q5.1? extends和implements有什么不同?
答:對于class而言,extends用于(單)繼承一個類(class),而implements用于實現(xiàn)一個接口(interf
ace)。
interface的引入是為了部分地提供多繼承的功能。
在interface中只需聲明方法頭,而將方法體留給實現(xiàn)的class來做。
這些實現(xiàn)的class的實例完全可以當(dāng)作interface的實例來對待。
在interface之間也可以聲明為extends(多繼承)的關(guān)系。
注意一個interface可以extends多個其他interface。
Q5.2? java怎么實現(xiàn)多繼承?
答:java不支持顯式的多繼承。
因為在顯式多繼承的語言例如c++中,會出現(xiàn)子類被迫聲明祖先虛基類構(gòu)造函數(shù)的問題,
而這是違反面向?qū)ο蟮姆庋b性原則的。
java提供了interface和implements關(guān)鍵字來部分地實現(xiàn)多繼承。參見Q5.1。
Q5.3 abstract是什么?
答:被聲明為abstract的方法無需給出方法體,留給子類來實現(xiàn)。
而如果一個類中有abstract方法,那么這個類也必須聲明為abstract。
被聲明為abstract的類無法實例化,盡管它可以定義構(gòu)造方法供子類使用。
Q5.4 public,protected,private有什么不同?
答:這些關(guān)鍵字用于聲明類和成員的可見性。
public成員可以被任何類訪問,
protected成員限于自己和子類訪問,
private成員限于自己訪問。
Java還提供了第四種的默認(rèn)可見性,一般稱為package private,當(dāng)沒有任何public,protected,private修飾符時,成員
是同一包內(nèi)可見。
類可以用public或默認(rèn)來修飾。
Q5.5 Override和Overload有什么不同?
答:Override是指父類和子類之間方法的繼承關(guān)系,這些方法有著相同的名稱和參數(shù)類型
。
Overload是指同一個類中不同方法(可以在子類也可以在父類中定義)間的關(guān)系,
這些方法有著相同的名稱和不同的參數(shù)類型。
Q5.6 我繼承了一個方法,但現(xiàn)在我想調(diào)用在父類中定義的方法。
答:用super.xxx()可以在子類中調(diào)用父類方法。
Q5.7 我想在子類的構(gòu)造方法中調(diào)用父類的構(gòu)造方法,該怎么辦?
答:在子類構(gòu)造方法的第一行調(diào)用super(...)即可。
Q5.8 我在同一個類中定義了好幾個構(gòu)造方法并且想在一個構(gòu)造方法中調(diào)用另一個。
答:在構(gòu)造方法第一行調(diào)用this(...)。
Q5.9 我沒有定義構(gòu)造方法會怎么樣?
答:自動獲得一個無參數(shù)的構(gòu)造方法。
Q5.10 我調(diào)用無參數(shù)的構(gòu)造方法失敗了。
答:如果你至少定義了一個構(gòu)造方法,就不再有自動提供的無參數(shù)的構(gòu)造方法了。
你需要另外顯式定義一個無參數(shù)的構(gòu)造方法。
另外一種可能是你的構(gòu)造方法或者類不是public的,參見Q5.4了解java中的可見性。
Q5.11 我該怎么定義類似于C++中的析構(gòu)方法(destructor)?
答:提供一個void finalize()方法。在Garbarge Collector回收該對象時會調(diào)用該方法。
注意實際上你很難判斷一個對象會在什么時候被回收。作者從未感到需要用到該方法。
Q5.12 我想將一個父類對象轉(zhuǎn)換成一個子類對象該怎么做?
答:強(qiáng)制類型轉(zhuǎn)換。如
public void meth(A a)
{
B b = (B)a;
}
如果a實際上并不是B的實例,會拋出ClassCastException。所以請確保a確實是B的實例。
Q5.13 其實我不確定a是不是B的實例,能不能分情況處理?
答:可以使用instanceof操作符。例如
if( a instanceof B )
{
B b = (B)a;
}
else
{
...
}
Q5.14 我在方法里修改了一個對象的值,但是退出方法后我發(fā)現(xiàn)這個對象的值沒變!
答:很可能你把傳入?yún)?shù)重賦了一個新對象,例如下列代碼就會造成這種錯誤:
public void fun1(A a) //a是局部參數(shù),指向了一個外在對象。
{
a = new A(); //a指向了一個新對象,和外在對象脫鉤了。如果你要讓a作為傳出變量,
不要寫這一句。
??????? a.setAttr(attr);//修改了新對象的值,外在對象沒有被修改。
}
基本類型也會出現(xiàn)這種情況。例如:
public void fun2(int a)
{
a = 10;//只作用于本方法,外面的變量不會變化。
}
六、java.util篇
Q6.1 java能動態(tài)分配數(shù)組嗎?
答:可以。例如int n = 3; Language[] myLanguages = new Language[n];
Q6.2 我怎么知道數(shù)組的長度?
答:用length屬性。如上例中的? myLanguages.length 就為 3。
Q6.3 我還想讓數(shù)組的長度能自動改變,能夠增加/刪除元素。
答:用順序表--java.util.List接口。
你可以選擇用ArrayList或是LinkedList,前者是數(shù)組實現(xiàn),后者是鏈表實現(xiàn)。
例如:? List list = new ArrayList(); 或是 List list = new LinkedList();? 。
Q??? 什么是鏈表?為什么要有ArrayList和LinkedList兩種List?
答:請補習(xí)數(shù)據(jù)結(jié)構(gòu)。
Q6.5 我想用隊列/棧。
答:用java.util.LinkedList。
Q6.6 我希望不要有重復(fù)的元素。
答:用集合--java.util.Set接口。例如:Set set = new HashSet()。
Q6.7 我想遍歷集合/Map。
答:用java.util.Iterator。參見API。
Q6.8 我還要能夠排序。
答:用java.util.TreeSet。例如:Set set = new TreeSet()。放進(jìn)去的元素會自動排序
。
你需要為元素實現(xiàn)Comparable接口,還可能需要提供equals()方法,compareTo()方法,h
ashCode()方法。
Q6.9 但是我想給數(shù)組排序。
答:java.util.Arrays類包含了sort等實用方法。
Q6.10 我想按不同方式排序。
答:為每種方式定義一個實現(xiàn)了接口Comparator的排序類并和Arrays或TreeSet綜合運用。
Q6.11 Map有什么用?
答:存儲key-value的關(guān)鍵字-值對,你可以通過關(guān)鍵字來快速存取相應(yīng)的值。
Q6.12 set方法沒問題,但是get方法返回的是Object。
答:強(qiáng)制類型轉(zhuǎn)換成你需要的類型。參見Q5.12。
Q6.13 ArrayList和Vector有什么不同?HashMap和Hashtable有什么不同?
答:ArrayList和HashMap是多線程不安全的,在多個線程中訪問同一個ArrayList對象可能
會引起沖突并導(dǎo)致錯誤。
而Vector和Hashtable是多線程安全的,即使在多個線程中同時訪問同一個Vector對象也不
會引起差錯。
看起來我們更應(yīng)該使用Vector和Hashtable,但是實際上Vector和Hashtable的性能太差,
所以如果你不在多線程中使用的話,還是應(yīng)該用ArrayList和HashMap。
Q6.14 我要獲得一個隨機(jī)數(shù)。
答:使用java.util.Random類。
Q6.15 我比較兩個String總是false,但是它們明明都是"abc" !
答:比較String一定要使用equals或equalsIgnoreCase方法,不要使用 == !
==比較的是兩個引用(變量)是否指向了同一個對象,而不是比較其內(nèi)容。
Q6.16 我想修改一個String但是在String類中沒找到編輯方法。
答:使用StringBuffer類。
String str = "......."; //待處理的字符串
StringBuffer buffer = new StringBuffer(str); //使用該字符串初始化一個StringBuf
fer
buffer.append("..."); //調(diào)用StringBuffer的相關(guān)API來編輯字符串
String str2 = buffer.toString(); //獲得編輯后的字符串。
另外,如果你需要將多個字符串連接起來,請盡量避免使用+號直接連接,而是使用Strin
gBuffer.append()方法。
Q6.17 我想處理日期/時間。
答:使用java.util.Date類。你可以使用java.text.SimpleDateFormat類來在String和Da
te間互相轉(zhuǎn)換。
SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); //規(guī)
定日期格式
Date date = formatter.parse("2003-07-26 18:30:35"); //將符合格式的String轉(zhuǎn)換為
Date
String s = formatter.format(date); //將Date轉(zhuǎn)換為符合格式的String
關(guān)于定義日期格式的詳細(xì)信息請參見API。
?
J2EE FAQ
?
目錄:
一、準(zhǔn)備篇
Q1.1?? 什么是J2EE?它和普通的Java有什么不同?
Q1.2?? J2EE好學(xué)嗎?
Q1.3?? J2EE有什么用?
Q1.4?? 學(xué)J2EE有前途嗎?
Q1.5?? 據(jù)說J2EE的性能不如.NET好,是真的嗎?
Q1.6?? 聽你說了這么多,我想學(xué)著玩玩。
Q1.7?? 學(xué)習(xí)J2EE該怎么開始?
Q1.8?? 我下了一個J2EE服務(wù)器但是不會配置。
Q1.9?? 我發(fā)現(xiàn)你沒有提到Tomcat。
二、 Servlet/JSP篇
Q2.1?? 什么是Servlet?
Q2.2?? 我怎么獲得Http請求里的參數(shù)?
Q2.3?? 我怎么返回結(jié)果?
Q2.4?? sendRedirect()和forward()有什么不同?
Q2.5?? 我寫了一個Servlet程序,怎么運行它?
Q2.6?? EAR和WAR有什么不同?
Q2.7?? EAR格式是怎樣的?
Q2.8?? WAR格式是怎樣的?
Q2.9?? 我的普通HTML文件/JSP文件應(yīng)當(dāng)放在哪里?
Q2.10? 我訪問不到servlet,甚至連HTML文件都訪問不到!
Q2.11? 我能訪問HTML但是訪問不到servlet。
Q2.12? 什么是JSP?它和Servlet有什么區(qū)別?
Q2.13? 我的JSP顯示的漢字是亂碼。
Q2.14? 為什么使用gb18030而不是gb2312?
Q2.15? 在JSP里面怎么引用Java Bean。
Q2.16? 我想在servlet間傳遞數(shù)據(jù)。
Q2.17? 怎么調(diào)用cookie?
Q2.18? 怎么在JSP里面實現(xiàn)文件下載?
Q2.19? 怎么實現(xiàn)文件上傳?
Q2.20? 我想讓頁面自動刷新,比如聊天室。
Q2.21? 我想讓用戶登錄以后才能訪問頁面。
Q2.22? 我想要能注冊用戶。
Q2.23? 怎么在JSP中訪問數(shù)據(jù)庫?
Q2.24? 什么是JSTL?
一、準(zhǔn)備篇
Q1.1? 什么是J2EE?它和普通的Java有什么不同?
答:J2EE全稱為Java2 Platform, Enterprise Edition。
“J2EE平臺本質(zhì)上是一個分布式的服務(wù)器應(yīng)用程序設(shè)計環(huán)境——一個Java環(huán)境,它提供了
:
·宿主應(yīng)用的一個運行基礎(chǔ)框架環(huán)境。
·一套用來創(chuàng)建應(yīng)用的Java擴(kuò)展API。”
Q1.2? J2EE好學(xué)嗎?
答:J2EE是很多技術(shù)的集合體,并且還在成長中。
你會遇到很多專有名詞:比如(X)HTML,Servlet/JSP,JDBC,JMS,JNDI,EJB,XML,Web
Service……。
尤其是XML和Web Service正在快速成長。幸運的是,你不需要等到學(xué)會所有技術(shù)后再開始
編程。
大體上J2EE可以分成3個主要應(yīng)用方式:Servlet/JSP,EJB,Web Service 和一些支撐技術(shù)
例如JDBC和JNDI。
你可以一個一個的學(xué)。
Q1.3 J2EE有什么用?
答:用來建設(shè)大型的分布式企業(yè)級應(yīng)用程序。或者用更時髦的名詞說就是“電子商務(wù)”應(yīng)
用程序。
這些企業(yè)可能大到擁有中心數(shù)據(jù)庫服務(wù)器,Web服務(wù)器集群和遍布全國的辦公終端,也可能
小到只不過想做一個網(wǎng)站。但是你肯定聽過“殺雞焉用牛刀”的古訓(xùn)。
Q1.4 學(xué)J2EE有前途嗎?
答:在這一市場目前只有一種技術(shù)可以和J2EE競爭,那就是Microsoft的.NET。
相對來說.NET要“新”一些而J2EE要“老”一些。這也意味著.NET更易用一點而J2EE更成
熟一點。
但是.NET只能用于Windows平臺(Microsoft聲稱要開發(fā)C#在Linux上的虛擬機(jī)但是尚未兌現(xiàn)
該諾言)。
在過去幾年,.NET的市場份額并不理想。不過Microsoft還有Longhorn這一殺手锏,鹿死誰
手還很難說。
Q1.5 據(jù)說J2EE的性能不如.NET好,是真的嗎?
答:在Sun公司提供的樣例程序Pet Store上,Microsoft聲稱不如相同的.NET程序好。
而Sun公司反駁說這一程序不能真正體現(xiàn)J2EE的性能,并且指責(zé)Microsoft在數(shù)據(jù)庫上做了
優(yōu)化。
作者沒有學(xué)習(xí)過.NET因而不能妄下斷言。
無論如何,大型分布式程序中的性能瓶頸通常首先來自于錯誤的設(shè)計。
Q1.6 聽你說了這么多,我想學(xué)著玩玩。
答:除非你想靠它當(dāng)飯吃或者作為技術(shù)儲備,否則請不要浪費你的時間。
Flash要好玩得多。計算機(jī)游戲就更加好玩了。
Q1.7 學(xué)習(xí)J2EE該怎么開始?
答:首先,下載一個免費的J2EE服務(wù)器。其次,去java.sun.com下載J2EE的API。第三,找
一本好的參考書。最后,找一個順手的IDE。
J2EE服務(wù)器。你可以用Sun的J2EE SDK(免費),或者Weblogic(性能最好,但是太大,而
且作者不推薦盜版行為),
或者JBoss(免費,就是文檔太少),或者JRun(開發(fā)版免費,作者用這個)。
參考書作者感覺Wrox的《J2EE服務(wù)器端高級編程》不錯,但是太老(作者手頭的是2001年
中文版)。
(似乎很多人不喜歡這本書......所以你得自己判斷它是否適合你。)
你還需要去下載一些最新的技術(shù)資料(當(dāng)然肯定是英文的)。
IDE如果你的機(jī)器配置夠好(內(nèi)存至少512M以上,256M或以下請勿考慮),可以用IBM的WS
AD,不然就繼續(xù)用Eclipse或者其他。
你也可以經(jīng)常去水木清華的Java版逛逛,但是在發(fā)貼前先看看精華區(qū)里有沒有你要的答案
。
Q1.8 我下了一個J2EE服務(wù)器但是不會配置。
答:請認(rèn)真閱讀隨機(jī)指導(dǎo)文檔,不同的服務(wù)器的配置都不一樣,作者愛莫能助。
Q1.9 我發(fā)現(xiàn)你沒有提到Tomcat。
答:Tomcat只是一個Web服務(wù)器,更準(zhǔn)確地說主要只是一個Web Container。
如果你想要學(xué)習(xí)EJB的話,Tomcat無法滿足你的需要。
二、 Servlet/JSP篇
Q2.1 什么是Servlet?
答:一個Servlet是一個Java類。它處理Http(s)請求并作出響應(yīng),包括返回一個HTML頁面
或轉(zhuǎn)交給其他URL處理。
Servlet必須運行在一個Web Container例如Tomcat中。
Servlet必須是javax.servlet.http.HttpServlet的子類,
你可以繼承doGet()或者doPost()方法,兩者分別對應(yīng)于Http(s)中的Get請求和Post請求。
Q2.2 我怎么獲得Http請求里的參數(shù)?
答:HttpRequest的getParameter()方法。例如:String paramValue = request.getPara
meter("paramName");
Q2.3 我怎么返回結(jié)果?
答:你可以利用相關(guān)API打開一個輸出流,并向流中直接寫入一個HTML頁面。
但是作者完全不贊成這樣做。一方面這樣做會很羅嗦。
另一方面從Model-View-Controller模式(在《J2EE核心模式》中被歸為Front Controlle
r模式)的觀點來看,
你應(yīng)當(dāng)提供一些HTML或者JSP作為視圖(view),而Servlet則根據(jù)請求參數(shù)決定轉(zhuǎn)到哪一
個視圖。
你可以利用response.sendRedirect(...)方法或request.getDispatcher(...).forward()
方法來實現(xiàn)。
Q2.4 sendRedirect()和forward()有什么不同?
答:sendRedirect()是向瀏覽器發(fā)送一個redirect通知,瀏覽器向新的URL發(fā)送一個新的請
求。
而forward是在服務(wù)器端直接將請求轉(zhuǎn)到新的URL,對于瀏覽器是透明的。
換而言之,sendRedirect()應(yīng)當(dāng)將共享數(shù)據(jù)放在session中,forward應(yīng)當(dāng)將共享數(shù)據(jù)放在
request中(當(dāng)然你也可以放在session中,但放在request中可以有效減小session中的數(shù)
據(jù)量,從而改善性能)。
前者瀏覽器的地址欄顯示的是新的URL,后者瀏覽器的地址欄顯示的是Servlet的URL。
因而當(dāng)刷新目標(biāo)URL時,兩者會造成一些差別。
Q2.5 我寫了一個Servlet程序,怎么運行它?
答:開發(fā)J2EE程序有一個部署(deploy)的概念,實際上是開發(fā)——部署——運行的三部
曲。
大多數(shù)服務(wù)器支持Hot deploy。你只需要在相應(yīng)的Application目錄(具體路徑依賴于服務(wù)
器)下面
建立一個符合WAR或EAR格式(參見Q2.7,Q2.8)的目錄,啟動服務(wù)器,就可以通過瀏覽器
訪問了。
特別的,你的Servlet的class文件應(yīng)當(dāng)放在/WEB-INF/classes目錄中。
注意J2EE SDK不支持Hot deploy,你需要通過它的deploy tool來部署。
Tomcat只支持WAR格式。
Q2.6 EAR和WAR有什么不同?
答:EAR是一個完整的J2EE應(yīng)用程序,包括Web部分和EJB部分。
WAR只是其中的Web部分。
Q2.7 EAR格式是怎樣的?
答:一個EAR可以包含任意多個WAR或EJB JAR,并且包含一個META-INF的目錄。
在/META-INF中包含了一個application.xml,其中描述了這個EAR包含哪些模塊,以及安全
性配置。
細(xì)節(jié)請看參考書。
Q2.8 WAR格式是怎樣的?
答:一個WAR包含一個WEB-INF的目錄,這個目錄下包含classes目錄,lib目錄和web.xml。
/WEB-INF/classes存放按package組織的class文件,/WEB-INF/lib目錄存放jar文件,
web.xml描述了很多東西,請讀參考書。
Q2.9 我的普通HTML文件/JSP文件應(yīng)當(dāng)放在哪里?
答:放在除了/WEB-INF以外的其他地方。
感謝antegg網(wǎng)友對于安全性的提醒:
如果你想直接用http://url/***.jsp的方式來訪問,就要像上面說得那樣放。
但是這樣的做法是不安全的,安全的做法是把所有的JSP頁面放在/WEB-INF目錄下面,并且
通過WEB-CONTAINER來訪問。
作者意見:
我更喜歡用filter來做安全性檢查。
在MVC模式中,JSP只是一個視圖而已,一般無需特別擔(dān)憂安全性。和普通的html放在一起
也利于維護(hù)。
Q2.10 我訪問不到servlet,甚至連HTML文件都訪問不到!
答:
第一你沒啟動服務(wù)器。
第二你敲錯了端口。
第三你沒有正確配置context-path。
第四你的服務(wù)器不支持auto reload或者你關(guān)閉了這一選項,你得重啟服務(wù)器或重新部署W
AR。
第五確認(rèn)你沒有把HTML放在/WEB-INF目錄下,那是訪問不到的。
Q2.11 我能訪問HTML但是訪問不到servlet。
答:請檢查你的web.xml文件。確保你正確定義了<servlet>和<servlet-mapping>元素。
前者標(biāo)識了一個servlet,后者將一個相對于context-path的URL映射到一個servlet。
在Tomcat中你可以通過/context-path/servlet/package/servletname的形式訪問servlet
,
但是這只是Tomcat的便捷訪問方式,并不是正式規(guī)范。
細(xì)節(jié)請看參考書。
Q2.12? 什么是JSP?它和Servlet有什么區(qū)別?
答:你可以將JSP當(dāng)做一個可擴(kuò)充的HTML來對待。
雖然在本質(zhì)上JSP文件會被服務(wù)器自動翻譯為相應(yīng)的Servlet來執(zhí)行。
可以說Servlet是面向Java程序員而JSP是面向HTML程序員的,除此之外兩者功能完全等價
。
Q2.13? 我的JSP顯示的漢字是亂碼。
答:在你的JSP開頭加上一行 <%@ page contentType="text/html; charset=gb18030"%>
如果你已經(jīng)聲明了page我想你知道該怎么修改。
Q2.14? 為什么使用gb18030而不是gb2312?
答:gb18030是繼gb2312之后的下一代漢字編碼標(biāo)準(zhǔn),最終將過渡到Unicode。
Q2.15? 在JSP里面怎么引用Java Bean。
答:首先,確認(rèn)你要引用的類在/WEB-INF/classes下或在/WEB-INF/lib的某個jar內(nèi)。
其次,在JSP里加一行 <jsp:useBean id="..." scope="..." class="..."/>
具體解釋請看參考書。
Q2.16? 我想在servlet間傳遞數(shù)據(jù)。
答:利用session。在Servlet/JSP中,你可以在4個地方保存數(shù)據(jù)。
1) page,本頁面。
2) session,用來存放客戶相關(guān)的信息,比如購物車,對應(yīng)接口為javax.servlet.http.H
ttpSession。
session機(jī)制實際上是cookie和URL Rewriting的抽象,服務(wù)器會自動使用cookie或URL Re
writing來實現(xiàn)。
3) request,可以在forward()時傳遞信息,對應(yīng)接口為javax.servlet.http.HttpReques
t。
4) application,或稱context,存放全局信息,對應(yīng)接口為javax.servlet.ServletCont
ext。
Q2.17? 怎么調(diào)用cookie?
答:作者建議使用session,你總是會遇到某些禁用cookie的用戶。這時session會自動使
用URL重寫來實現(xiàn)。
Q2.18? 怎么在JSP里面實現(xiàn)文件下載?
答:實際上這是一個HTML的問題。答案是一個超鏈接<a>。
Q2.19? 怎么實現(xiàn)文件上傳?
答:客戶端是HTML問題,在form中設(shè)置method為post,enctype為multi-part/form-data,
加一個<input type="file">。
而在接收的servlet中只是一個I/O問題,你可以使用jakarta的file-upload庫。
Q2.20? 我想讓頁面自動刷新,比如聊天室。
答:這是一個HTML問題,在<head>部分中加一條<meta http-equiv="refresh" content="
5" url="...">。
這是所謂的Client-pull,客戶端刷新技術(shù)。
相對的還有Server-push,服務(wù)器端刷新技術(shù),但是這一技術(shù)由于要占用服務(wù)器端資源而會
在大量訪問時出現(xiàn)瓶頸現(xiàn)象,參見http://216.239.33.104/search?q=cache:autUfoakirY
J:www.kfunigraz.ac.at/edvndwww/books/books/javaenterprise/servlet/ch06_03.htm+
server-push+servlet&hl=zh-CN&ie=UTF-8
Q2.21? 我想讓用戶登錄以后才能訪問頁面。
答:使用聲明式安全措施。
你只需要在web.xml中定義安全角色(Role),并定義受保護(hù)的URL集合只能由特定Role訪
問。
大多數(shù)服務(wù)器支持基于數(shù)據(jù)庫的用戶映射,你只要在相應(yīng)數(shù)據(jù)庫中建立兩張表并配置服務(wù)
器就可以了。
注意J2EE SDK不支持基于數(shù)據(jù)庫的用戶映射。
細(xì)節(jié)請看參考書和服務(wù)器文檔。
不過在商業(yè)環(huán)境中,J2EE所提供的聲明式安全措施仍然偏弱。一般商業(yè)程序會使用數(shù)據(jù)庫
存儲user-role-privilege模型來達(dá)到安全性要求,細(xì)節(jié)請詢問你的構(gòu)架設(shè)計師。
Q2.22? 我想要能注冊用戶。
答:參看Q2.21。在接受注冊請求的Servlet中執(zhí)行寫入數(shù)據(jù)庫操作即可。
Q2.23? 怎么在JSP中訪問數(shù)據(jù)庫?
答:標(biāo)準(zhǔn)做法是使用DAO模式,定義一個Java bean來訪問數(shù)據(jù)庫并在JSP中使用。
然而,當(dāng)你的數(shù)據(jù)庫模式很簡單時,你可以使用JSTL中的<sql:query>標(biāo)簽來快速訪問。
在一般的J2EE項目中,JSP處于表示層(展現(xiàn)層),需要先后通過業(yè)務(wù)層和集成層才會訪問
到數(shù)據(jù)庫,所以這個問題確實只會在很小的程序中才會遇到。
Q2.24? 什么是JSTL?
答:JSTL是Jsp Standard Tag Library的縮寫。這是一組通用標(biāo)簽并將成為JSP 2.0的一部
分。
其中包含賦值<c:set>,分支<c:if>,循環(huán)<c:forEach>,查詢數(shù)據(jù)庫<sql:query>,更新數(shù)
據(jù)庫<sql:update>
等。目前你需要像添加自定義標(biāo)簽庫一樣來添加JSTL,但是可以預(yù)計JSP 2.0會將JSTL作為
組成部分。
標(biāo)簽庫可以在