;”" />
第一篇:java學習心得筆記
j2ee學習筆記
注:框架可以用m.7334dd.com action=” ”);
out.print(response.encodeurl(“sessionexample”));
out.print(“form action=” ”);
out.print(“method = get>;”);
2) out.print(“<p>;<a href=” ”);
out.print(response.encodeurl(“sessionexample?database=foo&datavalue=bar”));
out.println(“” >;url encoded </a>;”);
3.singlethreadmodel
默認的,每一個servlet definition in a container只有一個servlet class的實例。
只有實現了singlethreadmodel,container才會讓servlet有多個實例。
servlet specification上建議,不要使用synchronized,而使用singlethreadmodel。
singlethreadmodel(沒有方法)
保證servlet在同一時刻只處理一個客戶的請求。
singlethreadmodel是耗費資源的,特別是當有大量的請求發(fā)送給servlet時,singlethreadmodel的作用是使包容器以同步時鐘的方式調用service方法。
這等同于在servlet的service()方法種使用synchronized.
single thread model一般使用在需要響應一個heavy request的時候,比如是一個需要和數據庫打交道的連接。
2. 在重載servlet地init( )方法后,一定要記得調用super.init( );
3. the client通過發(fā)送一個blank line表示它已經結束request
而the server通過關閉the socket來表示response已結束了。
4. 一個http servlet可以送三種東西給client
1) a single status code
2) any number of http headers
3) a response body
5. servlet之間信息共享的一個最簡單的方法就是
system.getproperties().put(“key”,”value”);
6. post和get
post:將form內各字段名稱和內容放置在html header內傳送給server
get:?之后的查詢字符串要使用urlencode,經過urlencode后,這個字符串不再帶有空格,以后將在server上恢復所帶有的空格。
get是m.7334dd.com中,可以通過serveltcontext的
setattribute( )
getattribute( )
removeattribute( )
來共享對象
10. 利用request.getparameter( )得到的string存在字符集問題。
可以用strtitle = request.getparameter(“title”);
strtitle = nem.7334dd.coment is the start tag, the end tag,and everything (including other elements) in betm.7334dd.com/stockquote.m.7334dd.coma targetnamespace=http://example.com/stockquote.xsd
xmlns="http://m.7334dd.com
content-type: text/xml; charset="utf-8"
content-length: nnnn
soapaction: "some-uri"
<soap-env:envelope
xmlns:soap-env="http://schemas.xmlsoap.org/soap/envelope/"
關。
以下是你應該回避使用的一些java特色,并且在你的ejb組件的實現代碼中要嚴格限
制它們的使用:
1.使用static,非final 字段。建議你在ejb組件中把所有的static字段都聲明為final型的。這樣可以保證前后一致的運行期語義,使得ejb容器有可以在多個java虛擬機之間分發(fā)組件實例的靈活性。
2.使用線程同步原語來同步多個組件實例的運行。避免這個問題,你就可以使ejb容器靈活的在多個java虛擬機之間分發(fā)組件實例。
3.使用am.7334dd.com.netpermission,java.io.reflect.reflectpermission,java.lang.security.securitypermission,以便加強先前所列出的編程限制。
許多ejb容器沒有加強這些限制,他們希望ejb組件開發(fā)者能遵守這些編程限制或者是帶有冒險想法違背了這些限制。違背這些限制的ejb組件,比標準方法依賴過多或過少的安全許可,都將很少能在多個ejb容器間移植。另外,代碼中都將隱藏著一些不確定的、難以預測的問題。所有這些都足以使ejb組件開發(fā)者應該知道這些編程限制,同時也應該認真地遵守它們。
任何違背了這些編程限制的ejb組件的實現代碼在編譯時都不能檢查出來,因為這些特點都是java語言和j2se中不可缺少的部分。
對于ejb組件的這些限制同樣適用于ejb組件所使用的幫助/訪問(helper/access)類,j2ee應用程序使用java文檔(jar)文件格式打包到一個帶.ear(代表enterprise archive)擴展名的文件中,這個ear文件對于發(fā)送給文件部署器來說是標準的格式。ear文件中包括在一個或多個ejb-jar文件中的ejb組件,還可能有ejb-jar所依賴的庫文件。所有ear文件中的代碼都是經過深思熟慮開發(fā)的應用程序并且都遵守編程限制和訪問許可集。
未來版本的規(guī)范可能會指定通過部署工具來定制安全許可的能力,通過這種方法指定了一個合法的組件應授予的許可權限,也指定了一個標準方法的需求:如從文件系統(tǒng)中讀文件應有哪些要求。一些ejb容器/服務器目前在它們的部署工具中都提供了比標準權限或多或少的許可權限,這些并不是ejb1.1規(guī)范中所需要的。
理解這些約束
ejb容器是ejb組件生存和執(zhí)行的運行期環(huán)境,ejb容器為ejb組件實例提供了一些服務如:事務管理、安全持久化、資源訪問、客戶端連接。ejb容器也負責ejb組件實例整個生命期的管理、擴展問題以及并發(fā)處理。所以,ejb組件就這樣寄居在一個被管理的執(zhí)行環(huán)境中--即ejb容器。
因為ejb容器完全負責ejb組件的生命期、并發(fā)處理、資源訪問、安全等等,所以與容器本身的鎖定和并發(fā)管理相沖突的可能性就需要消除,許多限制都需要使用來填上潛在的安全漏洞。除了與ejb容器責任與安全沖突的問題,ejb組件還意味著僅僅聚焦于商務邏輯,它依賴于ejb容器所提供的服務而不是自己來直接解決底層的系統(tǒng)層的問題。
可能的問題
通常,ejb組件在容器之間的移植不可避免地與如下問題相關:
1.它需要依靠的受限制的特點在特定ejb容器中沒有得到加強。
2.它需要依靠的非標準的服務從容器中可獲得。
為了保證ejb組件的可移植性和一致的行為,你應該使用一個具有與java2平臺安全
策略集相一致的策略集的容器來測試ejb組件,并且其加強了前述的編程限制。
總結
ejb組件開發(fā)者應該知道這些推薦的關于ejb組件的編程限制,明白它們的重要性,并且從組件的穩(wěn)定性和可移植性利益方面考慮來遵循它們。因為這些編程限制能阻止你使用標準的java語言的特點,違背了這些編程限制在編譯時不會知道,并且加強這些限制也不是ejb容器的責任。所有這些原因都使你應很小心地遵守這些編程限制,這些限制在組件的合同中已經成為了一個條款,并且它們對于建造可靠的、可移植的組件是非常重要的。
2. 優(yōu)化ejb
entity bean為在應用程序和設計中描述持久化商業(yè)對象(persistent business objec ts)提供了一個清晰的模型。在java對象模型中,簡單對象通常都是以一種簡單的方式進行處理但是,很多商業(yè)對象所需要的事務化的持久性管理沒有得到實現。entity bean將持久化機制封裝在容器提供的服務里,并且隱藏了所有的復雜性。entity bean允許應用程序操縱他們就像處理一個一般的java對象應用。除了從調用代碼中隱藏持久化的形式和機制外,entity bean還允許ejb容器對對象的持久化進行優(yōu)化,保證數據存儲具有開放性,靈活性,以及可部署性。在一些基于ejb技術的項目中,廣泛的使用oo技術導致了對entity bean的大量使用,sun的工程師們已經積累了很多使用entity bean的經驗,這篇文章就詳細闡述的這些卡發(fā)經驗:
*探索各種優(yōu)化方法
*提供性能優(yōu)化和提高適用性的法則和建議
*討論如何避免一些教訓。
法則1:只要可以,盡量使用cmp
cmp方式不僅減少了編碼的工作量,而且在container中以及container產生的數據庫訪問代碼中包括了許多優(yōu)化的可能。container可以訪問內存緩沖中的bean,這就允許它可以監(jiān)視緩沖中的任何變化。這樣的話就在事物沒有提交之前,如果緩存的數據沒有變化就不用寫到數據庫中。就可以避免許多不必要的數據庫寫操作。另外一個優(yōu)化是在調用find方法的時候。通常情況下find方法需要進行以下數據庫操作:
查找數據庫中的紀錄并且獲得主鍵
將紀錄數據裝入緩存
cmp允許將這兩步操作優(yōu)化為一步就可以搞定。[具體怎么做我也沒弄明白,原文沒有具體闡述]
法則2:寫代碼時盡量保證對bmp和cmp都支持
許多情況下,ejb的開發(fā)者可能無法控制他們寫的bean怎么樣被部署,以及使用的container是不是支持cmp.
一個有效的解決方案是,將商業(yè)邏輯的編碼完全和持久化機制分離。再cmp類中實現商業(yè)邏輯,然后再編寫一個bmp類,用該類繼承cmp類。這樣的話,所有的商業(yè)邏輯都在cmp類中,而持久化機制在bmp中實現。[我覺得這種情況在實際工作中很少遇到,但是作者解決問題的思路值得學習]
法則3:把ejbstore中的數據庫訪問減小到最少。
如果使用bmp,設置一個緩存數據改變標志dirty非常有用。所有改變數據庫中底層數據的操作,都要設置dirty,而在ejbstore()中,首先檢測dirty的值,如果dirty的值沒有改變,表明目前數據庫中的數據與緩存的一致,就不必進行數據庫操作了,反之,就要把緩存數據寫入數據庫。
法則4:總是將從lookup和find中獲得的引用進行緩存。(cache)
引用緩存對session bean和entity bean 都是適用的。
通過jndi lookup獲得ejb資源。比如datasource,bean的引用等等都要付出相當大的代價。因此應該避免多余的lookup.可以這樣做:
將這些引用定義為實例變量。
從setentitycontext(session bean使用setsessioncontext)方法查找他們。setentitycontext方法對于一個bean實例只執(zhí)行一次,所有的相關引用都在這一次中進行查找,這樣查找的代價就不是那么昂貴了。應該避免在其他方法中查找引用。尤其是訪問數據庫的方法:ejbload()和ejbstore(),如果在這些頻繁調用的方法中進行datasource的查找,勢必造成時間的浪費。
調用其他entity bean的finder方法也是一種重量級的調用。多次調用finder()方法的代價非常高。如果這種引用不適合放在setentitycontext這樣的初始化時執(zhí)行的方法中執(zhí)行,就應該在適當的時候緩存finder的執(zhí)行結果。只是要注意的是,如果這個引用只對當前的entity有效,你就需要在bean從緩沖池中取出來代表另外一個實體時清除掉這些引用。,這些操作應該在ejbactivate()中進行。
法則5:總是使用prepare statements
這條優(yōu)化法則適用于所有訪問關系數據庫的操作。
數據庫在處理每一個sql statement的時候,執(zhí)行前都要對statement進行編譯。一些數據庫具有緩存statement和statement的編譯后形式的功能。數據庫可以把新的statement和緩存中的進行匹配。然而,如果要使用這一優(yōu)化特性,新的statement要必須和緩存中的statement完全匹配。
對于non-prepared statement,數據和statement本身作為一個字符串傳遞,這樣由于前后調用的數據不同而不能匹配,就導致無法使用這種優(yōu)化。而對于prepared statement,數據和statement是分開傳遞給數據庫的,這樣statement就可以和cache中已編譯的statement進行匹配。statement就不必每次都進行編譯操作。從而使用該優(yōu)化屬性。
這項技術在一些小型的數據庫訪問中能夠減少statement將近90%的執(zhí)行時間。
法則6:完全關閉所有的statement
在編寫bmp的數據庫訪問代碼時,記住一定要在數據庫訪問調用之后關閉statement,因為每個打開的statement對應于數據庫中的一個打開的游標。
security
1.加密
對稱加密
(1)分組密碼
(2)流密碼
常用的對稱加密算法:
des和tripledes
blom.7334dd.comasterc ard 和visa 公司于1996 年發(fā)布,專家們認為set 是保證用戶與商家在電子商務與在線交易中免受欺騙的重要手段。傳統(tǒng)的信用卡交易者總在擔心不誠實的店員會將自己的信用卡號碼透露給他人,而在線交易也是如此,持卡者總在擔心服務器端的管理員會將信用卡號碼泄露出去,或者擔心黑客會在管理員不知情的情況下盜取信用卡號碼。事實上這些擔心都是必要的,而set 標準則可以保證用戶的信用卡號碼只傳送給信用卡公司進行認證,不會被系統(tǒng)管理員看到,也不會留在交易服務器的硬盤上給黑客以可乘之機。
5.pki
pki是一種易于管理的、集中化的網絡安全方案。它可支持多種形式的數字認證: 數據加密、數字簽字、不可否認、身份鑒別、密鑰管理以及交叉認證等。pki可通過一個基于認證的框架處理所有的數據加密和數字簽字工作。p ki標準與協(xié)議的開發(fā)迄今已有15年的歷史,目前的pki已完全可以向企業(yè)網絡提供有效的安全保障。
pki是一種遵循標準的密鑰管理平臺,它能夠為所有網絡應用透明地提供采用加密和數字簽名等密碼服務所必需的密鑰和證書管理。pki必須具有
1)ca、
2)證書庫、
3)密鑰備份及恢復系統(tǒng)、
4)證書作廢處理系統(tǒng)、
5)客戶端證書處理系統(tǒng)
等基本成分,構建pki也將圍繞著這五大系統(tǒng)來構建
一個pki由眾多部件組成,這些部件共同完成兩個主要功能:
1)為數據加密
2)創(chuàng)建數字認證。
服務器(即后端)產品是這一系統(tǒng)的核心,這些數據庫管理著數字認證、公共密鑰及專用密鑰( 分別用于數據的加密和解密)。
ca數據庫負責發(fā)布、廢除和修改x.509數字認證信息,它裝有用戶的公共密鑰、證書有效期以及認證功能(例如對數據的加密或對數字簽字的驗證) 。為了防止對數據簽字的篡改,ca在把每一數字簽字發(fā)送給發(fā)出請求的客戶機之前,需對每一個數字簽字進行認證。一旦數字認證得以創(chuàng)建, 它將會被自動存儲于x.500目錄中,x.500目錄為樹形結構。ldap(lightm.7334dd.compleaction());
...
}
}
public class jaasexampleaction implements privilegedaction {
public object run() {
filem.7334dd.comission"
name="com.ibm.security.sample.bid"
actions="create" />;
<permission classname=
"com.ibm.resource.security.auth.resourcepermission"
name="com.ibm.security.sample.bid"
actions="read" />;
<permission classname=
"com.ibm.resource.security.auth.resourcepermission"
name="com.ibm.security.sample.bid"
actions="m.7334dd.com.ibm.resource.security.auth.resourcepermission 類保護敏感代碼。例如,auction 類擁有下列構造函數:
public auction() {
permission permission =
nem.7334dd.comple.auction", "m.7334dd.com.security.sample.auction", "accept", this);
accesscontroller.checkpermission(permission);
// sensitive code
this.accepted = flag;
}
public boolean fulfills(subject user, string relationship) {
if( relationship.equalsignorecase("auctionom.7334dd.com.resource.security.auth.policy 可以用于指定另一個不同的文件名和位置。
m.7334dd.coml 文件未被修改時,上述這些才都是真的。
示例安裝
下面的安裝指導假設您正在使用 jdk 1.3 并且已經把文件解壓縮到 d:jaasexample 目錄。通過將文件解壓縮到這個目錄,您可以省去一些工作;否則您就必須使用正確的路徑名修改 policy 和 resourcesecurity.xml 策略文件。
下面是運行該示例需要做的工作:
下載這個示例的源文件。
把 jaas.jar 和 jaasmod.jar 復制到 jdk jrelibext 目錄(即 d:jdk1.3jrelibext)。
向位于 jdk 的 jrelibsecurity 目錄(即 d:jdk1.3jrelibsecurity)中的 java.security 文件的末尾添加下面的字符串:auth.policy.provider=com.ibm.resource.security.auth.xmlpolicyfile。
執(zhí)行 run.bat 文件。
結束語
類實例級授權把訪問控制分離到一個通用框架(該框架使用基于所有權和特定關系的策略)中。然后管理員可以在應用程序的生命周期內更改這些策略。用這種方法擴展 jaas 減少了您或另一個程序員必須在應用程序生命周期內業(yè)務規(guī)則發(fā)生更改時重寫代碼的可能性。
通過將關系字符串抽象為類可以進一步擴展特定關系這個概念。不調用 resource 實現類的 fulfills(subject user, string relationship) 方法,而只要調用 relationship 實現類中定義的新 fulfills(subject user, resource resource) 方法。這樣就會允許許多 resource 實現類使用相同的關系邏輯。
6.java的安全性
1. the security manager是一個application-m.7334dd.comanager (jdbc 1.0) 接口,j2ee 組件可以獲得物理數據庫連接對象(connection)。要獲得邏輯(合用的)連接,j2ee 組件必須使用以下這些 jdbc 2.0 合用管理器接口:
javax.sql.connectionpooldatasource 接口,該接口充當合用的 java.sql.connection 對象的資源管理器連接 factory。每家數據庫服務器供應商都提供該接口的實現
(例如,oracle 實現 oracle.jdbc.pool.oracleconnectionpooldatasource 類)。
javax.sql.pooledconnection 接口,該接口封裝到數據庫的物理連接。同樣,數據庫供應商提供其實現。
對于那些接口和 xa 連接的每一個,都存在一個 xa(x/open 規(guī)范)等價定義。
2. resultset
在jdbc2.0中,為了獲得一個uptatable result,在query語句里必須包含primarykey,并且查詢的內容里必須來自一個table
ava.sql.resultset接口中定義了三種類型的結果集
type_form.7334dd.comanager 的規(guī)范。
javatransaction service (jts) specifies the implementation of a transaction manager m.7334dd.comport java.am.7334dd.com.*;
public class mousetest
{
public static void main(string[] args)
{
mouseframe frame=nem.7334dd.comove(rectangle2d s)
{
if(s==null) return;
if(s==current) current=null;
squares.remove(s);
repaint();
}
private static final int side_length=20;//正方形的邊長
private arraylist<rectangle2d> squares;//存放所有已繪制的方塊(鼠標有效繪制路徑)
private rectangle2d current;//當前需要繪制的方塊
private class mousehandler extends mouseadapter
{
/*
* 當鼠標按鈕被按下時,先查找當前點是否已經包含在前期圖新內,* 否,則添加至數組列表
*/
public void mousepressed(mouseevent event)
{
current=find(event.getpoint());
if(current==null)
add(event.getpoint());
}
/*
* 處理鼠標點擊事件,如果當前點包含于圖形之中,且鼠標連續(xù)點擊兩次以上,則擦除該圖形。
*/
public void mouseclicked(mouseevent event)
{
current=find(event.getpoint());
if(current!=null && event.getclickcount()>=2)
remove(current);
}
}
private class mousemotionhandler implements mousemotionlistener
{
/*
* 改變鼠標形狀
h);*/public void mousemoved(mouseevent event){if(find(event.getpoint())==null)setcursor(cursor.getdefaultcursor());elsesetcursor(cursor.getpredefinedcursor(cursor.crosshair_cursor));}/** 拖動圖形*/public void mousedragged(mouseevent event){if(current!=null){int x=event.getpoint().x;int y=event.getpoint().y;current.setframe(x-side_length/2,y-side_length/2,side_length,side_lengt
}}}} repaint();
第三篇:關于java學習的一點心得體會
管理科學與工程學院11信管2班孫鑫201*4548
關于java學習的一點心得體會
我是學信管專業(yè)的,這學期除了學習了java軟件開發(fā)綜合實驗這門選修課外,還有自己本專業(yè)要學的java面向對象的程序設計。學習了近一學期的java課程,覺得是該總結自己的心得體會了。開始學習任何一門課(包括java),興趣最重要。一直覺得自己在學習了計算機編程語言(也就是c語言),學到了很多東西,再學習java的話,應該問題不大,但在學習了幾個星期后,還是明確感到了,有點吃力,于是趁學校開設這門選修課,并且有自己院的老師講解,還有了上機的機會,比自己自學省事多了,于是鼓足信心,開始了漫長的java征途。
還記得我編寫的第一個程序是簡單的輸出程序。當時自己不是很理解為什么main方法要這樣來定義public static void main(string[] args),問了好多同學,他們告訴我的答案是一樣的“java本身要求就是這樣子的”,但我自己不甘心,就自己進行了探索:把main改個名字運行一下,看看報什么錯誤,然后根據出錯信息進行分析;把main的public取掉,在試試看,報什么錯誤;static去掉還能不能運行;不知道m(xù)ain方法是否一定要傳一個string[]數組的,把string[]改掉,改成int[],或者string試試看;不知道是否必須寫args參數名稱的,也可以把args改成別的名字,看看運行結果如何。 結果一個簡單程序反復改了七八次,不斷運行,分析運行結果,最后就徹底明白為什么了main方法是這 1
樣定義的了。接著在以后的學習中我也采用這樣的方法解決問題,卻發(fā)現自己的速度比別人慢了好多,我就把自己的課余時間也分一部分給了java。
因為基礎是最重要的,只有基礎牢固才有可能對后面的學習有更加深刻的認識!
學習一門新的語言,參考書是離不開的。聽專業(yè)課老師說訂的教材偏難,不適合我們初學者,于是我在圖書館借了本參考書(一本篇幅較短的入門書來學習那些最簡單、最基本的東西,包括學習java語法等)。同時,對一個最簡單的程序也應該多去調試,多想想如果改動一下會出現什么結果?為什么必須那樣寫?多去想想這些問題然后去操作,會讓你有更多的收獲。這樣反復地思考是很有用的。
在學習java的語法時,java的語法是類似c語言的,所以學習的比較輕松。唯一需要注意的是有幾個不容易搞清楚的關鍵字的用法,public,protected,private,static,什么時候用,為什么要用,怎么用,和同學一起討論了好久才得以解決。
在學習java的面向對象的編程語言的特性。比如繼承,抽象類,方法的多態(tài),重載,覆蓋。對于一個沒有面向對象語言背景的人來說,我覺得這個過程需要花很長很長時間,因為學習java之前沒有c++的經驗,只有c語言的經驗,花了很長時間,才徹底把這些概念都搞清楚,把書上面的例子反復的揣摩,修改,嘗試,把那幾章內容反復的看過來,看過去,看了很多遍,才徹底領悟了。
此外,我對于static,public,private等等一開始都不是很懂,
都是把書上面的例子運行成功,然后就開始破壞它,不斷的根據自己心里面的疑問來重新改寫程序,看看能不能運行,運行出來是個什么樣子,是否可以得到預期的結果。這樣雖然比較費時間,不過一個例子程序這樣反復破壞幾次之后。我就對這個相關的知識徹底學通了。有時候甚至故意寫一些錯誤的代碼來運行,看看能否得到預期的運行錯誤。這樣對于編程的掌握是及其深刻的。
在學習java的過程中我得出這樣的結論:
1.學習中,要養(yǎng)成良好的習慣(寫括號時要成對,字母大小寫要區(qū)分,單詞拼寫要準確)。
2.在學習的過程中,最好不是僅僅停留在java表層,不是抄書上的例子運行出結果就可以。要注意,即便對一個簡單的例子也要有耐心去琢磨、調試、改動。
3.在學習的過程中一定要動手做、試著寫代碼,而不是抱一本書看看就行。很多東西和體會必須自己動手才能真正屬于自己。
4. 在 java 的學習過程中,可能會遇到形形色色的問題不容易解決,應多去專業(yè)論壇了解相關的知識,書本上的知識有限。要會從網上搜索有用的信息 加以整理,促進學習的深入和知識水平的提高。
看了好多網上課程,說學到一定程度要嘗試著自己做東西,但覺得自己僅僅經過一學期的學習,還遠遠不夠,希望自己在以后學習中繼續(xù)努力,能夠真真正正擁有一門編程語言,對自己今后的發(fā)展起到作用。
第四篇:java學習心得
java學習心得
一、 如何學好java??
1. 就本人認為學好java關鍵就在于態(tài)度。態(tài)度是學習好java的前
提,積極的態(tài)度注定你就比別人學得認真,自然最終學的一定
比不認真的人學的好!
2. 有良好的前提,不努力也不行的,所以呀!還得練習。要做到
常練習,多看,多思考(舉一反三,多方位的,全面的使你的
程序更加的完美);
3. 最后一點,就是多多交流!閉門造車永遠是落后的學習方式,
所以好要和身邊的一切可以交流技術的人積極交流,畢竟個人
的力量有限的!
二、 java中那些重要知識點。。ū救苏J為最主要的是思想,
知識點也很重要,關鍵是在學習中總結出自己的一套思想,好的槍手都是子彈喂出來的,好的程序員都是寫代
碼寫出來的)
1. java數據類型
a) 基本數據類型:byte、short、int、long、float、double、char、
boolean(注意各自的取值范圍,還有轉換方式)
b) 引用數據類型: 數組、類、接口。
2. 運算符號
a) 算術運算符:+、 - 、* 、/ 、 %、++、--;
b) 賦值運算符:=、+= 、-= 、*= 、/=、%=;
c) 比較運算符:<、>、=<、=>、!=;(返回值都是false/true) d) 邏輯運算符:&&、||、!
e) 位運算符:用于操作二進制位的運算符:<<、>>、>>>……
4. 基本數據結構:
a) 順序結構
b) 選擇結構(if……else……,sm.7334dd.com$的代碼封鎖,所以轉投java了。
學習java已經8個月了,在這里跟大家說下心得,我剛開始是看<<thinking in java>> 第三版,因為學校沒開java課,所以幾乎全是自學,用了將近二個月的時間把這本大書啃完,感覺這書不錯,但也有很多人說這書不好,的確這書不是按常規(guī)的順序講的,內容跳躍性強,但講的很深入,比較適合有cc++基礎的人看,這書看完,你就算基本掌握 java的基礎了,也就j2se部分。
現在java分三大部分基礎,從大到小排列:j2ee, j2se, j2me!
j2ee:這個就是現在最流行,也很java技術用的最多的地方,java企業(yè)應用,要學好它,首先就要有java的基礎,這是最基本的,然后學習servlet,jsp,javabean以及基本的mvc結構,當然還有其他輔助知識,比如js,html還有一個對數據庫的操作,這些都需要時間來學習,學完這些后基本就可以做些簡單的m.7334dd.coml語句和應用都很好的結合,除了web方面,軟件項目方面有沒有一個比較明確的方向,如果有,可以告之小弟么~
2.我聽說做web方面,應該先學jsp,html,再學mvc,不然很容易本末倒置,那ssh這樣的技術學習,有沒有一個比較明確的先后順序。
3.java ee這樣的一個學習過程,能不能有一個比較好學習心得可以推薦。我有一定的java基礎,可以編寫一些java小程序,但是到了web這些方面,思維總是不夠清晰,很容易混亂,對象方法和類之間總是不能很好的去擴展。希望各位幫幫忙,介紹一些學習心得,包括學習java技術的順序,并推薦一些書吧。
來源:網絡整理 免責聲明:本文僅限學習分享,如產生版權問題,請聯系我們及時刪除。