可以自由的從MP3機上下載音樂文件,而且大大提升了傳輸的速度,
首先從:
http://bbs.imp3.net/attachment.php?aid=99466下載一個iriver的插件
運行TC--->菜單點配置--->插件---->文件系統插件點設置--->點添加新插件,這時候就添加下邊附件中的插件就行了。
然后軟件運行時的界面就和我們的IMM差不多,不過功能更強大,安裝只占4.5MB。
不過要想訪問MP3(有驅無驅都好使)請點主菜單欄下面的盤符欄的網上鄰居
就會找到,然后一切OK
posted @
2006-02-24 17:52 rkind 閱讀(525) |
評論 (0) |
編輯 收藏
一直以來,認為實現這種上傳要比下載簡單的多,可是等到真正去實現的時候,才發現原來挺麻煩的
遇到的問題有:
1中文文件名的問題。
2文件沒有下載提示直接就打開,包括rar的。
就這么兩個小問題卻讓我花了三天的時間,不得不汗一下我的效率。
首先來說中文鏈接的問題,tomcat默認是不支持中文URL的,但是可以在Sever.xml中把 Connector 的屬性加上一條: URIEncoding="GBK";然后在傳遞之前,鏈接的中文還要先encode一下
例如:java.net.URLEncoder.encode(“測試.txt”); 這樣中文就會變成%D%F之類的,總之就可以正常傳遞了。
而關于點擊文件直接就打開了是比較郁悶,查找了些資料,也試了網上的一些方法,一直不行
,最后采用的文件流的方式,才順利解決。代碼大致如下:
while(rs.next()){
try{
OutputStream o=response.getOutputStream();
byte b[]=new byte[500];
filename=rs.getString("filename");//rs.為從數據庫查找到的結果集
filename=java.net.URLEncoder.encode(filename).trim();
File file=new File("d:/upload/20060221/",rs.getString("filename"));
//
response.setHeader("Content-Disposition","attachment; filename="+filename);
response.setContentType("APPLICATION/OCTET-STREAM");
long fileLength=file.length();
String length=String.valueOf(fileLength);
response.setHeader("Content_Length",length);
java.io.FileInputStream in = new java.io.FileInputStream(file);
int n=0;
while ((n=in.read(b)) != -1) {
o.write(b,0,n);
}
in.close();
o.close();
}catch(Exception e){
System.out.print(e);
}
}
rs.close();
這樣的話,中英文文件都能正常下載并使用,但是中文文件用Ie直接下載下來后文件名還是亂碼,用下載工具則一切正常。
posted @
2006-02-21 15:58 rkind 閱讀(259) |
評論 (0) |
編輯 收藏
以前裝過sql server,后來刪掉。現在重裝,卻出現“以前的某個程序安裝已在安裝計算機上創建掛起的文件操作。運行安裝程序之前必須重新啟動計算機”錯誤。無法進行下去。
參考網上資料,總算搞定。步驟是:
1)添加/刪除程序中徹底刪除sql server。
2)將沒有刪除的sql server目錄也刪除掉。
3)打開注冊表編輯器,在HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager中找到PendingFileRenameOperations項目,并刪除它。這樣就可以清除安裝暫掛項目。
4)刪除注冊表中跟sql server相關的鍵。
其實估計只要做第3步就可以搞定,這樣就可以清除安裝暫掛項目。自己是先走了1,2,4,最后做了3才搞定。所以估計3才是最關鍵的。
ME too
posted @
2006-02-21 09:47 rkind 閱讀(172) |
評論 (0) |
編輯 收藏
前兩天要把我們信息平臺上的tomcat4加為服務,
剛一開始就想先遷移到tomcat5上可是遷移以后數據庫總是聯不上,郁悶了好久。
后來又從網上找直接把tomcat4加為服務的腳本,嘗試了幾次,總是找不到tomcat的目錄,原來批處理文件里面不識別空格,把文件名改了下,服務算是加上了,可啟動時卻總是出錯誤,又重新裝了一次tomcat4.1.3,發現裝完以后在 /bin的文件夾里,根本就沒有tomcat.exe,著實有些郁悶,看來原來那個tomcat.exe肯定是從tomcat5里面拷過來的。不經意間又裝了一遍tomcat4.1.3,發現有一個選項(NT service xp/2000;only)郁悶啊,這不是直接就可以加為服務嗎,暈死了過去。。。。
這說明我還是太粗心了,裝過那么多回tomcat,也想過這個ntservice,怎么就記過這就是加成服務的呢
,我說網上相關的東西怎么這么少,原來是apahce已經帶了這個功能。
posted @
2006-02-14 11:17 rkind 閱讀(279) |
評論 (0) |
編輯 收藏
把以下代碼粘貼到首頁中,就可以從counter.txt中讀取訪問量。
一定要注意路徑的問題,剛開始直接用counter.txt,結果總是找不到文件,而且用絕對路徑也不行,
但是用/counter.txt就沒有問題
<%!
int number=0;
synchronized void countPeople(){
if(number==0){
try{
FileInputStream in=new FileInputStream("/counter.txt");
DataInputStream dataIn=new DataInputStream(in);
number=dataIn.readInt();
number++;
in.close();
dataIn.close();
}catch(FileNotFoundException e){
number++;
try{
FileOutputStream out=new FileOutputStream("/counter.txt");
DataOutputStream dataOut=new DataOutputStream(out);
dataOut.writeInt(number);
out.close();
dataOut.close();
}catch(IOException ffe){
System.out.print(ffe);
}
}catch(IOException ee){
System.out.println(ee);
}
}else{
number++;
try{
FileOutputStream out=new FileOutputStream("/counter.txt");
DataOutputStream dataOut=new DataOutputStream(out);
dataOut.writeInt(number);
out.close();
dataOut.close();
}catch(FileNotFoundException e){
System.out.println(e);
}
catch(IOException e){
System.out.println(e);
}
}
}
%>
<% countPeople();%>
posted @
2006-01-19 11:26 rkind 閱讀(325) |
評論 (0) |
編輯 收藏
我們在ie地址欄搜索時,頁面老是自動進入265導航網站,一看就是垃圾網站,你還弄不掉,煩死人了,教大家一個方法,可以弄掉265!!!
1、首先進入C:\WINDOWS\system32\drivers找到ETC這個文件夾
2、將ETC文件夾里面的hosts用記事本打開
3、在最后一欄上加上127.0.0.1 auto.search.msn.com
4、保存退出即可。
你試試,就清靜多了
posted @
2006-01-18 15:37 rkind 閱讀(512) |
評論 (0) |
編輯 收藏
您的人格類型是: ISFJ(內向,感覺,情感,判斷) |
您的工作中的優勢: ◆ 能夠很好地集中精力,關注焦點 ◆ 很強的工作倫理,工作努力而且很負責任 ◆ 良好的協作技巧,能和別人建立和諧友好的關系 ◆ 講求實效的工作態度,辦事方法切實可行 ◆ 十分關注細節,能夠準確把握事實 ◆ 樂于助人,給同事和下屬職員的工作提供支持和幫助 ◆ 了解公司(或者組織)的經歷,能夠很好地維護公司的傳統 ◆ 杰出的組織才能 ◆ 愿意在傳統的機構中工作,而且兢兢業業,不遺余力 ◆ 能夠連續工作,對于相同的工作不會感到厭倦 ◆ 非常強的責任意識,別人可以信賴 ◆ 喜歡運用固定的辦事程序,尊重別人的地位和能力 ◆ 通情達理,視角現實
您工作中可能存在的不足: ◆ 可能會低估自己的能力,難于堅持維護自己的需要和利益 ◆ 不愿意嘗試新的和未經考驗的觀點和想法 ◆ 對反對意見過于敏感,在緊張的環境中容易感到壓抑 ◆ 可能只關注眼前的細節,而對整體和未來不太重視 ◆ 傾向于同時投入到過多的工作任務中去 ◆ 難以適應新的情況,或者在不同工作任務中間來回切換時有困難 ◆ 易于被需要同時解決太多的任務或者項目時會弄得無所適從 ◆ 如果自己得不到充分的重視和贊賞,可能會感到灰心喪氣 ◆ 一旦做出決定,就不愿意從頭考慮同一個問題
| |
posted @
2006-01-10 17:10 rkind 閱讀(170) |
評論 (0) |
編輯 收藏
<form action="submit_1.html" method=post>
<input type=image src="exa.gif" name="sub1">
</form>
就是這簡單
posted @
2006-01-04 13:58 rkind 閱讀(510) |
評論 (0) |
編輯 收藏
1、如何學習Spring?
你可以通過下列途徑學習spring:
(1) spring下載包中doc目錄下的MVC-step-by-step和sample目錄下的例子都是比較好的spring開發的例子。
(2) AppFuse集成了目前最流行的幾個開源輕量級框架或者工具 Ant,XDoclet,Spring,Hibernate(iBATIS),JUnit,Cactus,StrutsTestCase,Canoo's WebTest,Struts Menu,Display Tag Library,OSCache,JSTL,Struts 。
你可以通過AppFuse源代碼來學習spring。
AppFuse網站:http://raibledesigns.com/wiki/Wiki.jsp?page=AppFuse
(3)Spring 開發指南(夏昕)(http://www.xiaxin.net/Spring_Dev_Guide.rar)
一本spring的入門書籍,里面介紹了反轉控制和依賴注射的概念,以及spring的bean管理,spring的MVC,spring和hibernte,iBatis的結合。
(4) spring學習的中文論壇
SpringFramework中文論壇(http://spring.jactiongroup.net)
Java視線論壇(http://forum.javaeye.com)的spring欄目
2、利用Spring框架編程,console打印出log4j:WARN Please initialize the log4j system properly?
說明你的log4j.properties沒有配置。請把log4j.properties放到工程的classpath中,eclipse的classpath為bin目錄,由于編譯后src目錄下的文件會拷貝到bin目錄下,所以你可以把log4j.properties放到src目錄下。
這里給出一個log4j.properties的例子:
log4j.rootLogger=DEBUG,stdout log4j.appender.stdout=org.apache.log4j.ConsoleAppender log4j.appender.stdout.layout=org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern=%d %5p (%F:%L) - %m%n |
3、出現 java.lang.NoClassDefFoundError?
一般情況下是由于你沒有把必要的jar包放到lib中。
比如你要采用spring和hibernate(帶事務支持的話),你除了spring.jar外還需要hibernat.jar、aopalliance.jar、cglig.jar、jakarta-commons下的幾個jar包。
http://www.springframework.org/download.html下載spring開發包,提供兩種zip包
spring-framework-1.1.3-with-dependencies.zip和spring-framework-1.1.3.zip,我建議你下載spring-framework-1.1.3-with-dependencies.zip。這個zip解壓縮后比后者多一個lib目錄,其中有hibernate、j2ee、dom4j、aopalliance、jakarta-commons等常用包。
4、java.io.FileNotFoundException: Could not open class path resource [....hbm.xml],提示找不到xml文件?
原因一般有兩個:
(1)該xml文件沒有在classpath中。
(2)applicationContext-hibernate.xml中的xml名字沒有帶包名。比如:
<bean id="sessionFactory" class="org.springframework.orm.hibernate.LocalSessionFactoryBean"> <property name="dataSource"><ref bean="dataSource"/></property> <property name="mappingResources"> <list> <value>User.hbm.xml</value> 錯,改為: <value>com/yz/spring/domain/User.hbm.xml</value> </list> </property> <property name="hibernateProperties"> <props> <prop key="hibernate.dialect"> net.sf.hibernate.dialect.MySQLDialect </prop> <prop key="hibernate.show_sql">true</prop> </props> </property> </bean> |
5、org.springframework.beans.NotWritablePropertyException: Invalid property 'postDao' of bean class?
出現異常的原因是在application-xxx.xml中property name的錯誤。
<property name="...."> 中name的名字是與bean的set方法相關的,而且要注意大小寫。
比如
public class PostManageImpl extends BaseManage implements PostManage { private PostDAO dao = null; public void setPostDAO(PostDAO postDAO){ this.dao = postDAO; } } |
那么xml的定義應該是:
<bean id="postManage" parent="txProxyTemplate"> <property name="target"> <bean class="com.yz.spring.service.implement.PostManageImpl"> <property name="postDAO"><ref bean="postDAO"/></property> 對 <property name="dao"><ref bean="postDAO"/></property> 錯 </bean> </property> </bean> |
6、Spring中如何實現事務管理?
首先,如果使用mysql,確定mysql為InnoDB類型。
事務管理的控制應該放到商業邏輯層。你可以寫個處理商業邏輯的JavaBean,在該JavaBean中調用DAO,然后把該Bean的方法納入spring的事務管理。
比如:xml文件定義如下:
<bean id="txProxyTemplate" abstract="true" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean"> <property name="transactionManager"><ref bean="transactionManager"/></property> <property name="transactionAttributes"> <props> <prop key="save*">PROPAGATION_REQUIRED</prop> <prop key="remove*">PROPAGATION_REQUIRED</prop> <prop key="*">PROPAGATION_REQUIRED</prop> </props> </property> </bean>
<bean id="userManage" parent="txProxyTemplate"> <property name="target"> <bean class="com.yz.spring.service.implement.UserManageImpl"> <property name="userDAO"><ref bean="userDAO"/></property> </bean> </property> </bean> |
com.yz.spring.service.implement.UserManageImpl就是我們的實現商業邏輯的JavaBean。我們通過parent元素聲明其事務支持。
7、如何管理Spring框架下更多的JavaBean?
JavaBean越多,spring配置文件就越大,這樣不易維護。為了使配置清晰,我們可以將JavaBean分類管理,放在不同的配置文件中。 應用啟動時將所有的xml同時加載。
比如:
DAO層的JavaBean放到applicationContext-hibernate.xml中,商業邏輯層的JavaBean放到applicationContext-service.xml中。然后啟動類中調用以下代碼載入所有的ApplicationContext。
String[] paths = {"com/yz/spring/dao/hibernate/applicationContext-hibernate.xml", "com/yz/spring/service/applicationContext-service.xml"}; ctx = new ClassPathXmlApplicationContext(paths); |
8、web應用中如何加載ApplicationContext?
可以通過定義web.xml,由web容器自動加載。
<servlet> <servlet-name>context</servlet-name> <servlet-class>org.springframework.web.context.ContextLoaderServlet</servlet-class> <load-on-startup>1</load-on-startup> </servlet>
<context-param> <param-name>contextConfigLocation</param-name> <param-value>/WEB-INF/applicationContext-hibernate.xml</param-value> <param-value>/WEB-INF/applicationContext-service.xml</param-value> </context-param> |
9、在spring中如何配置的log4j?
在web.xml中加入以下代碼即可。
<context-param> <param-name>log4jConfigLocation</param-name> <param-value>/WEB-INF/log4j.properties</param-value> </context-param> |
10、Spring框架入門的編程問題解決了,我該如何更深地領會Spring框架呢?
這兩本書你該去看看。這兩本書是由Spring的作者Rod Johnson編寫的。
Expert One on one J2EE Design and Development Expert One on one J2EE Development Without EJB |
你也該看看martinfowler的Inversion of Control Containers and the Dependency Injection pattern。
http://www.martinfowler.com/articles/injection.html |
再好好研讀一下spring的文檔。
http://www.jactiongroup.net/reference/html/index.html(中文版,未全部翻譯) |
還有就是多實踐吧。
posted @
2005-12-06 17:54 rkind 閱讀(206) |
評論 (0) |
編輯 收藏
abstract class和interface是Java語言中對于抽象類定義進行支持的兩種機制,正是由于這兩種機制的存在,才賦予了Java強大的面向對象能力。abstract class和interface之間在對于抽象類定義的支持方面具有很大的相似性,甚至可以相互替換,因此很多開發者在進行抽象類定義時對于abstract class和interface的選擇顯得比較隨意。
其實,兩者之間還是有很大的區別的,對于它們的選擇甚至反映出對于問題領域本質的理解、對于設計意圖的理解是否正確、合理。本文將對它們之間的區別進行一番剖析,試圖給開發者提供一個在二者之間進行選擇的依據。
一、理解抽象類
abstract class和interface在Java語言中都是用來進行抽象類(本文中的抽象類并非從abstract class翻譯而來,它表示的是一個抽象體,而abstract class為Java語言中用于定義抽象類的一種方法,請讀者注意區分)定義的,那么什么是抽象類,使用抽象類能為我們帶來什么好處呢?
在面向對象的概念中,我們知道所有的對象都是通過類來描繪的,但是反過來卻不是這樣。并不是所有的類都是用來描繪對象的,如果一個類中沒有包含足夠的信息來描繪一個具體的對象,這樣的類就是抽象類。抽象類往往用來表征我們在對問題領域進行分析、設計中得出的抽象概念,是對一系列看上去不同,但是本質上相同的具體概念的抽象。
比如:如果我們進行一個圖形編輯軟件的開發,就會發現問題領域存在著圓、三角形這樣一些具體概念,它們是不同的,但是它們又都屬于形狀這樣一個概念,形狀這個概念在問題領域是不存在的,它就是一個抽象概念。正是因為抽象的概念在問題領域沒有對應的具體概念,所以用以表征抽象概念的抽象類是不能夠實例化的。
在面向對象領域,抽象類主要用來進行類型隱藏。我們可以構造出一個固定的一組行為的抽象描述,但是這組行為卻能夠有任意個可能的具體實現方式。這個抽象描述就是抽象類,而這一組任意個可能的具體實現則表現為所有可能的派生類。模塊可以操作一個抽象體。由于模塊依賴于一個固定的抽象體,因此它可以是不允許修改的;同時,通過從這個抽象體派生,也可擴展此模塊的行為功能。熟悉OCP的讀者一定知道,為了能夠實現面向對象設計的一個最核心的原則OCP(Open-Closed Principle),抽象類是其中的關鍵所在。
二、從語法定義層面看abstract class和interface
在語法層面,Java語言對于abstract class和interface給出了不同的定義方式,下面以定義一個名為Demo的抽象類為例來說明這種不同。使用abstract class的方式定義Demo抽象類的方式如下:
abstract class Demo {
abstract void method1();
abstract void method2();
…
} |
使用interface的方式定義Demo抽象類的方式如下:
interface Demo {
void method1();
void method2();
…
} |
在abstract class方式中,Demo可以有自己的數據成員,也可以有非abstarct的成員方法,而在interface方式的實現中,Demo只能夠有靜態的不能被修改的數據成員(也就是必須是static final的,不過在interface中一般不定義數據成員),所有的成員方法都是abstract的。從某種意義上說,interface是一種特殊形式的abstract class。
從編程的角度來看,abstract class和interface都可以用來實現"design by contract"的思想。但是在具體的使用上面還是有一些區別的。
首先,abstract class在Java語言中表示的是一種繼承關系,一個類只能使用一次繼承關系。但是,一個類卻可以實現多個interface。也許,這是Java語言的設計者在考慮Java對于多重繼承的支持方面的一種折中考慮吧。
其次,在abstract class的定義中,我們可以賦予方法的默認行為。但是在interface的定義中,方法卻不能擁有默認行為,為了繞過這個限制,必須使用委托,但是這會 增加一些復雜性,有時會造成很大的麻煩。
在抽象類中不能定義默認行為還存在另一個比較嚴重的問題,那就是可能會造成維護上的麻煩。因為如果后來想修改類的界面(一般通過abstract class或者interface來表示)以適應新的情況(比如,添加新的方法或者給已用的方法中添加新的參數)時,就會非常的麻煩,可能要花費很多的時間(對于派生類很多的情況,尤為如此)。但是如果界面是通過abstract class來實現的,那么可能就只需要修改定義在abstract class中的默認行為就可以了。
同樣,如果不能在抽象類中定義默認行為,就會導致同樣的方法實現出現在該抽象類的每一個派生類中,違反了"one rule,one place"原則,造成代碼重復,同樣不利于以后的維護。因此,在abstract class和interface間進行選擇時要非常的小心。
三、從設計理念層面看abstract class和interface
上面主要從語法定義和編程的角度論述了abstract class和interface的區別,這些層面的區別是比較低層次的、非本質的。本文將從另一個層面:abstract class和interface所反映出的設計理念,來分析一下二者的區別。作者認為,從這個層面進行分析才能理解二者概念的本質所在。
前面已經提到過,abstarct class在Java語言中體現了一種繼承關系,要想使得繼承關系合理,父類和派生類之間必須存在"is a"關系,即父類和派生類在概念本質上應該是相同的。對于interface 來說則不然,并不要求interface的實現者和interface定義在概念本質上是一致的,僅僅是實現了interface定義的契約而已。為了使論述便于理解,下面將通過一個簡單的實例進行說明。
考慮這樣一個例子,假設在我們的問題領域中有一個關于Door的抽象概念,該Door具有執行兩個動作open和close,此時我們可以通過abstract class或者interface來定義一個表示該抽象概念的類型,定義方式分別如下所示:
使用abstract class方式定義Door:
abstract class Door {
abstract void open();
abstract void close();
}
使用interface方式定義Door:
interface Door {
void open();
void close();
} |
其他具體的Door類型可以extends使用abstract class方式定義的Door或者implements使用interface方式定義的Door。看起來好像使用abstract class和interface沒有大的區別。
如果現在要求Door還要具有報警的功能。我們該如何設計針對該例子的類結構呢(在本例中,主要是為了展示abstract class和interface反映在設計理念上的區別,其他方面無關的問題都做了簡化或者忽略)下面將羅列出可能的解決方案,并從設計理念層面對這些不同的方案進行分析。
解決方案一:
簡單的在Door的定義中增加一個alarm方法,如下:
abstract class Door {
abstract void open();
abstract void close();
abstract void alarm();
}
或者
interface Door {
void open();
void close();
void alarm();
} |
那么具有報警功能的AlarmDoor的定義方式如下:
class AlarmDoor extends Door {
void open() { … }
void close() { … }
void alarm() { … }
}
或者
class AlarmDoor implements Door {
void open() { … }
void close() { … }
void alarm() { … }
} |
這種方法違反了面向對象設計中的一個核心原則ISP(Interface Segregation Priciple),在Door的定義中把Door概念本身固有的行為方法和另外一個概念"報警器"的行為方法混在了一起。這樣引起的一個問題是那些僅僅依賴于Door這個概念的模塊會因為"報警器"這個概念的改變(比如:修改alarm方法的參數)而改變,反之依然。
解決方案二:
既然open、close和alarm屬于兩個不同的概念,根據ISP原則應該把它們分別定義在代表這兩個概念的抽象類中。定義方式有:這兩個概念都使用abstract class方式定義;兩個概念都使用interface方式定義;一個概念使用abstract class方式定義,另一個概念使用interface方式定義。
顯然,由于Java語言不支持多重繼承,所以兩個概念都使用abstract class方式定義是不可行的。后面兩種方式都是可行的,但是對于它們的選擇卻反映出對于問題領域中的概念本質的理解、對于設計意圖的反映是否正確、合理。我們一一來分析、說明。
如果兩個概念都使用interface方式來定義,那么就反映出兩個問題:
1、我們可能沒有理解清楚問題領域,AlarmDoor在概念本質上到底是Door還是報警器?
2、如果我們對于問題領域的理解沒有問題,比如:我們通過對于問題領域的分析發現AlarmDoor在概念本質上和Door是一致的,那么我們在實現時就沒有能夠正確的揭示我們的設計意圖,因為在這兩個概念的定義上(均使用interface方式定義)反映不出上述含義。
如果我們對于問題領域的理解是:AlarmDoor在概念本質上是Door,同時它有具有報警的功能。我們該如何來設計、實現來明確的反映出我們的意思呢?前面已經說過,abstract class在Java語言中表示一種繼承關系,而繼承關系在本質上是"is a"關系。所以對于Door這個概念,我們應該使用abstarct class方式來定義。另外,AlarmDoor又具有報警功能,說明它又能夠完成報警概念中定義的行為,所以報警概念可以通過interface方式定義。如下所示:
abstract class Door {
abstract void open();
abstract void close();
}
interface Alarm {
void alarm();
}
class AlarmDoor extends Door implements Alarm {
void open() { … }
void close() { … }
void alarm() { … }
} |
這種實現方式基本上能夠明確的反映出我們對于問題領域的理解,正確的揭示我們的設計意圖。其實abstract class表示的是"is a"關系,interface表示的是"like a"關系,大家在選擇時可以作為一個依據,當然這是建立在對問題領域的理解上的,比如:如果我們認為AlarmDoor在概念本質上是報警器,同時又具有Door的功能,那么上述的定義方式就要反過來了。
abstract class和interface是Java語言中的兩種定義抽象類的方式,它們之間有很大的相似性。但是對于它們的選擇卻又往往反映出對于問題領域中的概念本質的理解、對于設計意圖的反映是否正確、合理,因為它們表現了概念間的不同的關系(雖然都能夠實現需求的功能)。這其實也是語言的一種的慣用法,希望讀者朋友能夠細細體會
posted @
2005-12-06 11:03 rkind 閱讀(223) |
評論 (0) |
編輯 收藏