作為一個(gè)軟件工程專業(yè)的過(guò)來(lái)人,希望我的回答能夠幫助你,假設(shè)你每天堅(jiān)持學(xué)習(xí)
創(chuàng)新互聯(lián)建站主要業(yè)務(wù)有網(wǎng)站營(yíng)銷策劃、成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)、微信公眾號(hào)開發(fā)、小程序設(shè)計(jì)、H5響應(yīng)式網(wǎng)站、程序開發(fā)等業(yè)務(wù)。一次合作終身朋友,是我們奉行的宗旨;我們不僅僅把客戶當(dāng)客戶,還把客戶視為我們的合作伙伴,在開展業(yè)務(wù)的過(guò)程中,公司還積累了豐富的行業(yè)經(jīng)驗(yàn)、營(yíng)銷型網(wǎng)站資源和合作伙伴關(guān)系資源,并逐漸建立起規(guī)范的客戶服務(wù)和保障體系。
首先找一本簡(jiǎn)單的教材,先對(duì)java有個(gè)基本的認(rèn)識(shí)(大概看那么半個(gè)月就差不多了,隨便下載一本入門的書就行了)
然后推薦你看java核心技術(shù),分為上下兩卷,已經(jīng)是第八版了,大概有一千六七百頁(yè);當(dāng) 你看完后,基本的java知識(shí)已經(jīng)掌握了(記住,一定要多練習(xí)?。?我那時(shí)候一個(gè)暑假看完第一遍,每天看將近十個(gè)小時(shí)加練習(xí),但是要弄懂,呵呵,至少看個(gè)三四遍吧,這兩本書只要能搞懂70%就很不錯(cuò)了)
這個(gè)時(shí)候你可以看看thinking in java中文名"java編程思想",這本書寫的比較難,如果你看不懂,那么你要多做練習(xí),慢慢看,如果看完了,而且懂了,那么證明你的java水平到達(dá)了一個(gè)更高的層次;(去參加面試的時(shí)候問(wèn)的那些java知識(shí)完全可以應(yīng)付過(guò)來(lái)了)(或者你可以先看下面的書,邊看thinking in java這本書,這樣也是可以的,而且學(xué)習(xí)的效率應(yīng)該會(huì)高些)
然后java就會(huì)分方向,j2me(手機(jī)編程)不建議你去學(xué)這個(gè)(要學(xué)就學(xué)android手機(jī)編程),已經(jīng)過(guò)時(shí)了;j2ee方向(Web編程),先學(xué)html,javaScript,css(這些書多得數(shù)不清,呵呵),然后就學(xué)servlet和jsp,《jsp應(yīng)用開發(fā)詳解》(入門) 《Servlet與JSP核心編程》(核心)這兩本書還不錯(cuò),然后就可以學(xué)SSH(三大框架,這個(gè)書一大堆),
學(xué)習(xí)struts的時(shí)候建議你從struts1開始學(xué)起《精通Struts基于MVC的Java Web設(shè)計(jì)與開發(fā)》,然后就可以學(xué)習(xí)struts2《Struts2權(quán)威指南》,接下來(lái)學(xué)習(xí)Hibernate《精通Hibernate:Java對(duì)象持久化技術(shù)詳解》,最后學(xué)習(xí)Spring《spring2.0技術(shù)手冊(cè)》(提示:只要你java基礎(chǔ)學(xué)得好,這些東西都會(huì)學(xué)得很快)
這個(gè)時(shí)候你就要把注意力放在設(shè)計(jì)模式,數(shù)據(jù)結(jié)構(gòu)和計(jì)算機(jī)算法上面來(lái)了, 設(shè)計(jì)模式可以先看深入淺出設(shè)計(jì)模式 然后再看java與模式, 數(shù)據(jù)結(jié)構(gòu)建議你看清華大學(xué)嚴(yán)慰敏老師寫的那本教材; 計(jì)算機(jī)算法要了解基本的排序,如果你不做底層,只做應(yīng)用的話,沒(méi)有必要去看那個(gè)算法導(dǎo)論這本書太難了。 (設(shè)計(jì)模式,數(shù)據(jù)結(jié)構(gòu)和算法才是真正的精髓,要有很多年的編程經(jīng)驗(yàn)才能夠使用得游刃有余,光看懂還不行的,一定要多練習(xí),到了這個(gè)境界才是真正的java高手)(我學(xué)java有三年了,這是我的體會(huì))
等你掌握前面的這些知識(shí)之后,推薦你看effective java,這本書是目前java領(lǐng)域公認(rèn)的高級(jí)書籍。在項(xiàng)目中你肯定會(huì)遇到一些前端的知識(shí),那么你得精通javascript,JavaScript權(quán)威指南(入門), JavaScript高級(jí)程序設(shè)計(jì)(進(jìn)階),這兩本書弄懂了,那么學(xué)習(xí)jquery和extjs都會(huì)很快的。
還有要提醒你一下,對(duì)于初學(xué)者,不要使用eclipse編程工具,建議你先用記事本寫程序,當(dāng)你比較熟練了之后就可以使用eclipse這些工具了。
不要心急,不要圖快,所有的書要一本本的慢慢看,多看幾遍(一本書看上個(gè)四五遍,你就可以成高手,呵呵)。
java基礎(chǔ)(j2se)的重點(diǎn)有:繼承、多態(tài)、流、線程、網(wǎng)絡(luò)編程、反射、集合、數(shù)據(jù)庫(kù)連接、泛型、JNI技術(shù)、分布式技術(shù)還有解析xml也是很重要的,如果你想學(xué)android手機(jī)編程,那么SWING和AWT要熟悉一下。如果你不想學(xué)Web編程(j2ee),那么我建議你可以學(xué)android手機(jī)編程《Google+Android開發(fā)入門與實(shí)戰(zhàn)》(入門) 《Google Android SDK開發(fā)范例大全》(深入)(建議把a(bǔ)ndroid當(dāng)作業(yè)余愛(ài)好,把web編程當(dāng)作主攻方向,因?yàn)閖2ee包含了大量框架知識(shí)),書很多,可以自己去搜。多想 多看 多練才是王道,不要相信什么培訓(xùn)機(jī)構(gòu),這些都沒(méi)啥用,真正學(xué)好只能靠你自己。
面向?qū)ο笏枷?java基礎(chǔ)(j2se)+數(shù)據(jù)結(jié)構(gòu)+設(shè)計(jì)模式+計(jì)算機(jī)算法 為核心,學(xué)好了這幾個(gè)8000元/月輕而易舉,什么都可以不學(xué)好,唯獨(dú)這幾科一定要學(xué)好,切記切記!
當(dāng)然,隨著你的技術(shù)水平的提高,你還會(huì)要學(xué)習(xí)其他的語(yǔ)言,不過(guò)這都是后話,等你把上面的東西掌握了,我再告訴你怎么學(xué)(高并發(fā)等內(nèi)容),哈哈!
你現(xiàn)在還是在校的學(xué)生,那么請(qǐng)記住,不要沉迷于游戲,把時(shí)間用于學(xué)習(xí)上面的知識(shí),千萬(wàn)別聽(tīng)一些人說(shuō)什么'學(xué)校學(xué)的東西工作都用不到',完全是胡扯,我很負(fù)責(zé)任的告訴你,只有學(xué)校里學(xué)的東西才是真正有技術(shù)含量的東西,真正工作了,你就沒(méi)有那么多時(shí)間來(lái)學(xué)習(xí)了(唉,感觸很深吶)
以上的內(nèi)容是我學(xué)習(xí)的總結(jié),當(dāng)然我走過(guò)很多彎路,現(xiàn)在我把這條正確的路徑介紹給你,也是希望你能夠少走彎路,希望幾年之后,你能夠比現(xiàn)在的我更牛X(呵呵,吹個(gè)小牛)!加油!參考資料來(lái)源:
簡(jiǎn)單的Java加密算法有:
第一種. BASE
Base是網(wǎng)絡(luò)上最常見(jiàn)的用于傳輸Bit字節(jié)代碼的編碼方式之一,大家可以查看RFC~RFC,上面有MIME的詳細(xì)規(guī)范。Base編碼可用于在HTTP環(huán)境下傳遞較長(zhǎng)的標(biāo)識(shí)信息。例如,在Java Persistence系統(tǒng)Hibernate中,就采用了Base來(lái)將一個(gè)較長(zhǎng)的唯一標(biāo)識(shí)符(一般為-bit的UUID)編碼為一個(gè)字符串,用作HTTP表單和HTTP GET URL中的參數(shù)。在其他應(yīng)用程序中,也常常需要把二進(jìn)制數(shù)據(jù)編碼為適合放在URL(包括隱藏表單域)中的形式。此時(shí),采用Base編碼具有不可讀性,即所編碼的數(shù)據(jù)不會(huì)被人用肉眼所直接看到。
第二種. MD
MD即Message-Digest Algorithm (信息-摘要算法),用于確保信息傳輸完整一致。是計(jì)算機(jī)廣泛使用的雜湊算法之一(又譯摘要算法、哈希算法),主流編程語(yǔ)言普遍已有MD實(shí)現(xiàn)。將數(shù)據(jù)(如漢字)運(yùn)算為另一固定長(zhǎng)度值,是雜湊算法的基礎(chǔ)原理,MD的前身有MD、MD和MD。
MD算法具有以下特點(diǎn):
壓縮性:任意長(zhǎng)度的數(shù)據(jù),算出的MD值長(zhǎng)度都是固定的。
容易計(jì)算:從原數(shù)據(jù)計(jì)算出MD值很容易。
抗修改性:對(duì)原數(shù)據(jù)進(jìn)行任何改動(dòng),哪怕只修改個(gè)字節(jié),所得到的MD值都有很大區(qū)別。
弱抗碰撞:已知原數(shù)據(jù)和其MD值,想找到一個(gè)具有相同MD值的數(shù)據(jù)(即偽造數(shù)據(jù))是非常困難的。
強(qiáng)抗碰撞:想找到兩個(gè)不同的數(shù)據(jù),使它們具有相同的MD值,是非常困難的。
MD的作用是讓大容量信息在用數(shù)字簽名軟件簽署私人密鑰前被”壓縮”成一種保密的格式(就是把一個(gè)任意長(zhǎng)度的字節(jié)串變換成一定長(zhǎng)的十六進(jìn)制數(shù)字串)。除了MD以外,其中比較有名的還有sha-、RIPEMD以及Haval等。
第三種.SHA
安全哈希算法(Secure Hash Algorithm)主要適用于數(shù)字簽名標(biāo)準(zhǔn)(Digital Signature Standard DSS)里面定義的數(shù)字簽名算法(Digital Signature Algorithm DSA)。對(duì)于長(zhǎng)度小于^位的消息,SHA會(huì)產(chǎn)生一個(gè)位的消息摘要。該算法經(jīng)過(guò)加密專家多年來(lái)的發(fā)展和改進(jìn)已日益完善,并被廣泛使用。該算法的思想是接收一段明文,然后以一種不可逆的方式將它轉(zhuǎn)換成一段(通常更?。┟芪?,也可以簡(jiǎn)單的理解為取一串輸入碼(稱為預(yù)映射或信息),并把它們轉(zhuǎn)化為長(zhǎng)度較短、位數(shù)固定的輸出序列即散列值(也稱為信息摘要或信息認(rèn)證代碼)的過(guò)程。散列函數(shù)值可以說(shuō)是對(duì)明文的一種“指紋”或是“摘要”所以對(duì)散列值的數(shù)字簽名就可以視為對(duì)此明文的數(shù)字簽名。
SHA-與MD的比較
因?yàn)槎呔蒑D導(dǎo)出,SHA-和MD彼此很相似。相應(yīng)的,他們的強(qiáng)度和其他特性也是相似,但還有以下幾點(diǎn)不同:
對(duì)強(qiáng)行攻擊的安全性:最顯著和最重要的區(qū)別是SHA-摘要比MD摘要長(zhǎng) 位。使用強(qiáng)行技術(shù),產(chǎn)生任何一個(gè)報(bào)文使其摘要等于給定報(bào)摘要的難度對(duì)MD是^數(shù)量級(jí)的操作,而對(duì)SHA-則是^數(shù)量級(jí)的操作。這樣,SHA-對(duì)強(qiáng)行攻擊有更大的強(qiáng)度。
對(duì)密碼分析的安全性:由于MD的設(shè)計(jì),易受密碼分析的攻擊,SHA-顯得不易受這樣的攻擊。
速度:在相同的硬件上,SHA-的運(yùn)行速度比MD慢。
第四種.HMAC
HMAC(Hash Message Authentication Code,散列消息鑒別碼,基于密鑰的Hash算法的認(rèn)證協(xié)議。消息鑒別碼實(shí)現(xiàn)鑒別的原理是,用公開函數(shù)和密鑰產(chǎn)生一個(gè)固定長(zhǎng)度的值作為認(rèn)證標(biāo)識(shí),用這個(gè)標(biāo)識(shí)鑒別消息的完整性。使用一個(gè)密鑰生成一個(gè)固定大小的小數(shù)據(jù)塊,即MAC,并將其加入到消息中,然后傳輸。接收方利用與發(fā)送方共享的密鑰進(jìn)行鑒別認(rèn)證等。
Java技術(shù)與Java虛擬機(jī)中文JAVA技術(shù)網(wǎng)g0cVV+]
中文JAVA技術(shù)網(wǎng)I5Zz[ }'Og G6Y
說(shuō)起Java,人們首先想到的是Java編程語(yǔ)言,然而事實(shí)上,Java是一種技術(shù),它由四方面組成:Java編程語(yǔ)言、Java類文件格式、Java虛擬機(jī)和Java應(yīng)用程序接口(Java API)。它們的關(guān)系如下圖所示:
[)|)k3b9M#\)w%Q{~r0中文JAVA技術(shù)網(wǎng):cP+] _2tRtm*K
中文JAVA技術(shù)網(wǎng)yz;_Y0FB
圖1 Java四個(gè)方面的關(guān)系
,YWx ^L |Q0運(yùn)行期環(huán)境代表著Java平臺(tái),開發(fā)人員編寫Java代碼(.java文件),然后將之編譯成字節(jié)碼(.class文件)。最后字節(jié)碼被裝入內(nèi)存,一旦字節(jié)碼進(jìn)入虛擬機(jī),它就會(huì)被解釋器解釋執(zhí)行,或者是被即時(shí)代碼發(fā)生器有選擇的轉(zhuǎn)換成機(jī)器碼執(zhí)行。從上圖也可以看出Java平臺(tái)由Java虛擬機(jī)和Java應(yīng)用程序接口搭建,Java語(yǔ)言則是進(jìn)入這個(gè)平臺(tái)的通道,用Java語(yǔ)言編寫并編譯的程序可以運(yùn)行在這個(gè)平臺(tái)上。這個(gè)平臺(tái)的結(jié)構(gòu)如下圖所示:
x[+DX0\:W-o@a0中文JAVA技術(shù)網(wǎng)"? c3Y6bj-_
中文JAVA技術(shù)網(wǎng)P @+O3lf_pJ b
中文JAVA技術(shù)網(wǎng)5h:OY TyL2\|Z
在Java平臺(tái)的結(jié)構(gòu)中, 可以看出,Java虛擬機(jī)(JVM) 處在核心的位置,是程序與底層操作系統(tǒng)和硬件無(wú)關(guān)的關(guān)鍵。它的下方是移植接口,移植接口由兩部分組成:適配器和Java操作系統(tǒng), 其中依賴于平臺(tái)的部分稱為適配器;JVM 通過(guò)移植接口在具體的平臺(tái)和操作系統(tǒng)上實(shí)現(xiàn);在JVM 的上方是Java的基本類庫(kù)和擴(kuò)展類庫(kù)以及它們的API, 利用Java API編寫的應(yīng)用程序(application) 和小程序(Java applet) 可以在任何Java平臺(tái)上運(yùn)行而無(wú)需考慮底層平臺(tái), 就是因?yàn)橛蠮ava虛擬機(jī)(JVM)實(shí)現(xiàn)了程序與操作系統(tǒng)的分離,從而實(shí)現(xiàn)了Java 的平臺(tái)無(wú)關(guān)性。
h6l-v;HV1SvYO0中文JAVA技術(shù)網(wǎng)-G5cAK(e w}
那么到底什么是Java虛擬機(jī)(JVM)呢?通常我們談?wù)揓VM時(shí),我們的意思可能是:中文JAVA技術(shù)網(wǎng),T,Y5d(B5r
中文JAVA技術(shù)網(wǎng)yWv~s;J
對(duì)JVM規(guī)范的的比較抽象的說(shuō)明;
b0r[/o_k+p0對(duì)JVM的具體實(shí)現(xiàn);中文JAVA技術(shù)網(wǎng)Xdt8M1sP T_"_s
在程序運(yùn)行期間所生成的一個(gè)JVM實(shí)例。中文JAVA技術(shù)網(wǎng)H k0g,~ hO\
中文JAVA技術(shù)網(wǎng)C3@ w6O-a
對(duì)JVM規(guī)范的的抽象說(shuō)明是一些概念的集合,它們已經(jīng)在書《The Java Virtual Machine Specification》(《Java虛擬機(jī)規(guī)范》)中被詳細(xì)地描述了;對(duì)JVM的具體實(shí)現(xiàn)要么是軟件,要么是軟件和硬件的組合,它已經(jīng)被許多生產(chǎn)廠商所實(shí)現(xiàn),并存在于多種平臺(tái)之上;運(yùn)行Java程序的任務(wù)由JVM的運(yùn)行期實(shí)例單個(gè)承擔(dān)。在本文中我們所討論的Java虛擬機(jī)(JVM)主要針對(duì)第三種情況而言。它可以被看成一個(gè)想象中的機(jī)器,在實(shí)際的計(jì)算機(jī)上通過(guò)軟件模擬來(lái)實(shí)現(xiàn),有自己想象中的硬件,如處理器、堆棧、寄存器等,還有自己相應(yīng)的指令系統(tǒng)。中文JAVA技術(shù)網(wǎng)nC/D IHP,|
A)R-DFw o2X0JVM在它的生存周期中有一個(gè)明確的任務(wù),那就是運(yùn)行Java程序,因此當(dāng)Java程序啟動(dòng)的時(shí)候,就產(chǎn)生JVM的一個(gè)實(shí)例;當(dāng)程序運(yùn)行結(jié)束的時(shí)候,該實(shí)例也跟著消失了。下面我們從JVM的體系結(jié)構(gòu)和它的運(yùn)行過(guò)程這兩個(gè)方面來(lái)對(duì)它進(jìn)行比較深入的研究。
Z6?gXm!~0Java虛擬機(jī)的體系結(jié)構(gòu)
2XFZ@"I I,\0
e-i'_;P X a0剛才已經(jīng)提到,JVM可以由不同的廠商來(lái)實(shí)現(xiàn)。由于廠商的不同必然導(dǎo)致JVM在實(shí)現(xiàn)上的一些不同,然而JVM還是可以實(shí)現(xiàn)跨平臺(tái)的特性,這就要?dú)w功于設(shè)計(jì)JVM時(shí)的體系結(jié)構(gòu)了。中文JAVA技術(shù)網(wǎng){ v2TtMlG?"]*N
中文JAVA技術(shù)網(wǎng),HK3YQN k
我們知道,一個(gè)JVM實(shí)例的行為不光是它自己的事,還涉及到它的子系統(tǒng)、存儲(chǔ)區(qū)域、數(shù)據(jù)類型和指令這些部分,它們描述了JVM的一個(gè)抽象的內(nèi)部體系結(jié)構(gòu),其目的不光規(guī)定實(shí)現(xiàn)JVM時(shí)它內(nèi)部的體系結(jié)構(gòu),更重要的是提供了一種方式,用于嚴(yán)格定義實(shí)現(xiàn)時(shí)的外部行為。每個(gè)JVM都有兩種機(jī)制,一個(gè)是裝載具有合適名稱的類(類或是接口),叫做類裝載子系統(tǒng);另外的一個(gè)負(fù)責(zé)執(zhí)行包含在已裝載的類或接口中的指令,叫做運(yùn)行引擎。每個(gè)JVM又包括方法區(qū)、堆、Java棧、程序計(jì)數(shù)器和本地方法棧這五個(gè)部分,這幾個(gè)部分和類裝載機(jī)制與運(yùn)行引擎機(jī)制一起組成的體系結(jié)構(gòu)圖為:中文JAVA技術(shù)網(wǎng)BW0EZCI
2o\d oz0中文JAVA技術(shù)網(wǎng)%K1Hl:f ~(@Y(U
圖3 JVM的體系結(jié)構(gòu)中文JAVA技術(shù)網(wǎng)0P/b(jt U$x
7{F*d8f7ySt:Q0JVM的每個(gè)實(shí)例都有一個(gè)它自己的方法域和一個(gè)堆,運(yùn)行于JVM內(nèi)的所有的線程都共享這些區(qū)域;當(dāng)虛擬機(jī)裝載類文件的時(shí)候,它解析其中的二進(jìn)制數(shù)據(jù)所包含的類信息,并把它們放到方法域中;當(dāng)程序運(yùn)行的時(shí)候,JVM把程序初始化的所有對(duì)象置于堆上;而每個(gè)線程創(chuàng)建的時(shí)候,都會(huì)擁有自己的程序計(jì)數(shù)器和Java棧,其中程序計(jì)數(shù)器中的值指向下一條即將被執(zhí)行的指令,線程的Java棧則存儲(chǔ)為該線程調(diào)用Java方法的狀態(tài);本地方法調(diào)用的狀態(tài)被存儲(chǔ)在本地方法棧,該方法棧依賴于具體的實(shí)現(xiàn)。中文JAVA技術(shù)網(wǎng) t?!Pz!B]
"^x1MT5qj0下面分別對(duì)這幾個(gè)部分進(jìn)行說(shuō)明。
/}C2v7b:]%vo[|0中文JAVA技術(shù)網(wǎng)'z/@1RG7[E1`8B
執(zhí)行引擎處于JVM的核心位置,在Java虛擬機(jī)規(guī)范中,它的行為是由指令集所決定的。盡管對(duì)于每條指令,規(guī)范很詳細(xì)地說(shuō)明了當(dāng)JVM執(zhí)行字節(jié)碼遇到指令時(shí),它的實(shí)現(xiàn)應(yīng)該做什么,但對(duì)于怎么做卻言之甚少。Java虛擬機(jī)支持大約248個(gè)字節(jié)碼。每個(gè)字節(jié)碼執(zhí)行一種基本的CPU運(yùn)算,例如,把一個(gè)整數(shù)加到寄存器,子程序轉(zhuǎn)移等。Java指令集相當(dāng)于Java程序的匯編語(yǔ)言。中文JAVA技術(shù)網(wǎng) ^sH2X*b,Z
q3[ OT`z"M4V0Java指令集中的指令包含一個(gè)單字節(jié)的操作符,用于指定要執(zhí)行的操作,還有0個(gè)或多個(gè)操作數(shù),提供操作所需的參數(shù)或數(shù)據(jù)。許多指令沒(méi)有操作數(shù),僅由一個(gè)單字節(jié)的操作符構(gòu)成。
P.R.Uxbfc0
o"o qq9_0虛擬機(jī)的內(nèi)層循環(huán)的執(zhí)行過(guò)程如下:中文JAVA技術(shù)網(wǎng)3Hn8B r,xE
MjHj(zBG t"m P0do{
l$Iz V!M9[0取一個(gè)操作符字節(jié);中文JAVA技術(shù)網(wǎng)7[?3o?,v A|3b+O R
根據(jù)操作符的值執(zhí)行一個(gè)動(dòng)作;
I(^e)G)Hf6`0}while(程序未結(jié)束)中文JAVA技術(shù)網(wǎng)y}0J/|:so
中文JAVA技術(shù)網(wǎng)c|%L(ud
由于指令系統(tǒng)的簡(jiǎn)單性,使得虛擬機(jī)執(zhí)行的過(guò)程十分簡(jiǎn)單,從而有利于提高執(zhí)行的效率。指令中操作數(shù)的數(shù)量和大小是由操作符決定的。如果操作數(shù)比一個(gè)字節(jié)大,那么它存儲(chǔ)的順序是高位字節(jié)優(yōu)先。例如,一個(gè)16位的參數(shù)存放時(shí)占用兩個(gè)字節(jié),其值為:
0H.w`wb}.X0中文JAVA技術(shù)網(wǎng)y{X;n.u4PT+e)D7\E
第一個(gè)字節(jié)*256+第二個(gè)字節(jié)字節(jié)碼。中文JAVA技術(shù)網(wǎng)"V[]J!_0v+D
5^t6E[3aW![0指令流一般只是字節(jié)對(duì)齊的。指令tableswitch和lookup是例外,在這兩條指令內(nèi)部要求強(qiáng)制的4字節(jié)邊界對(duì)齊。
#Rop'v6w FS0中文JAVA技術(shù)網(wǎng)g8Ai _)iw8r
對(duì)于本地方法接口,實(shí)現(xiàn)JVM并不要求一定要有它的支持,甚至可以完全沒(méi)有。Sun公司實(shí)現(xiàn)Java本地接口(JNI)是出于可移植性的考慮,當(dāng)然我們也可以設(shè)計(jì)出其它的本地接口來(lái)代替Sun公司的JNI。但是這些設(shè)計(jì)與實(shí)現(xiàn)是比較復(fù)雜的事情,需要確保垃圾回收器不會(huì)將那些正在被本地方法調(diào)用的對(duì)象釋放掉。
~:Jin+U$zE SI7Y0
"j1lJ`7Dd0v"v0Java的堆是一個(gè)運(yùn)行時(shí)數(shù)據(jù)區(qū),類的實(shí)例(對(duì)象)從中分配空間,它的管理是由垃圾回收來(lái)負(fù)責(zé)的:不給程序員顯式釋放對(duì)象的能力。Java不規(guī)定具體使用的垃圾回收算法,可以根據(jù)系統(tǒng)的需求使用各種各樣的算法。中文JAVA技術(shù)網(wǎng)'z/wgb.s
中文JAVA技術(shù)網(wǎng)\TMY[:H)Z#@ tr
這個(gè)就是遞歸的,買書的話可以買 計(jì)算機(jī)算法設(shè)計(jì)與分析 電子工業(yè)出版社的
提高算法能力就是要多做題
當(dāng)你把這兩個(gè)網(wǎng)站的題目都做出來(lái),你就是個(gè)算法牛人了。
快速排序
使用快速排序方法對(duì)a[ 0 :n- 1 ]排序
從a[ 0 :n- 1 ]中選擇一個(gè)元素作為m i d d l e,該元素為支點(diǎn)
把余下的元素分割為兩段left 和r i g h t,使得l e f t中的元素都小于等于支點(diǎn),而right 中的元素都大于等于支點(diǎn)
遞歸地使用快速排序方法對(duì)left 進(jìn)行排序
遞歸地使用快速排序方法對(duì)right 進(jìn)行排序
所得結(jié)果為l e f t + m i d d l e + r i g h t
public class QuickSort {
static Integer[] a = {49, 38, 65, 97, 76, 13, 27, 49};
public int partition(int l, int r){
int i = l, j = r + 1;
int x = a[l];
while(true){
while(a[++i]x ir);
while(a[--j]x jl);
if(i=j) break;
a[i] = a[i]^a[j];
a[j] = a[i]^a[j];
a[i] = a[i]^a[j];
}
a[l] = a[j];
a[j] = x;
return j;
}
public void quicksort(int l, int r){
if(lr){
int q = partition(l,r);
quicksort(l,q-1);//左邊排序
quicksort(q+1,r);//右邊排序
}
}
public static void main(String[] args){
QuickSort qs = new QuickSort();
qs.quicksort(0, a.length-1);
for(int i=0; ia.length; i++){
System.out.print(a[i]+",");
}
}
}
1. 請(qǐng)把下面的java代碼用偽代碼寫出來(lái)
偽代碼(Pseudocode)是一種算法描述語(yǔ)言。
使用偽代碼的目的是為了使被描述的算法可以容易地以任何一種編程語(yǔ)言(Pascal,C,Java,etc)實(shí)現(xiàn)。因此,偽代碼必須結(jié)構(gòu)清晰、代碼簡(jiǎn)單、可讀性好,并且類似自然語(yǔ)言。
介于自然語(yǔ)言與編程語(yǔ)言之間。以編程語(yǔ)言的書寫形式指明算法職能。
使用偽代碼, 不用拘泥于具體實(shí)現(xiàn)。相比程序語(yǔ)言(例如Java, C++,C, Dephi 等等)它更類似自然語(yǔ)言。
它是半角式化、不標(biāo)準(zhǔn)的語(yǔ)言??梢詫⒄麄€(gè)算法運(yùn)行過(guò)程的結(jié)構(gòu)用接近自然語(yǔ)言的形式(可以使用任何一種你熟悉的文字,關(guān)鍵是把程序的意思表達(dá)出來(lái))描述出來(lái)。
String path = "***"File f = new File(path);public void test (F f)File []fs = f遍歷文件夾;for(。){ if(fs[i]是文件){ 輸入 }else{ 遞歸test(fs[i]); }}。
2. JAVA 偽代碼
提示輸入一個(gè)大于2且11的數(shù)字
輸入一整型數(shù)值給Vertices,
if(Vertices 3 || Vertices 11){
提示重新輸入且應(yīng)輸入
退出程序
}else{
生成一個(gè)Vertices * Vertices 大小的數(shù)組Graph,
填充數(shù)組 :行號(hào)與列號(hào)相同填充0,其余填充10以內(nèi)隨機(jī)數(shù)
交換元素:以[i][j]位置的數(shù)值與[j][i]位置的數(shù)值互換
最后打印數(shù)組各元素
}
3. 請(qǐng)把下列用java代碼 用偽代碼寫出來(lái)
偽代碼(Pseudocode)是一種算法描述語(yǔ)言。使用偽代碼的目的是為了使被描述的算法可以容易地以任何一種編程語(yǔ)言(Pascal,C,Java,etc)實(shí)現(xiàn)。因此,偽代碼必須結(jié)構(gòu)清晰、代碼簡(jiǎn)單、可讀性好,并且類似自然語(yǔ)言。 介于自然語(yǔ)言與編程語(yǔ)言之間。以編程語(yǔ)言的書寫形式指明算法職能。使用偽代碼, 不用拘泥于具體實(shí)現(xiàn)。相比程序語(yǔ)言(例如Java, C++,C, Dephi 等等)它更類似自然語(yǔ)言。它是半角式化、不標(biāo)準(zhǔn)的語(yǔ)言??梢詫⒄麄€(gè)算法運(yùn)行過(guò)程的結(jié)構(gòu)用接近自然語(yǔ)言的形式(可以使用任何一種你熟悉的文字,關(guān)鍵是把程序的意思表達(dá)出來(lái))描述出來(lái)。
String path = "***"
File f = new File(path);
public void test (F f)
File []fs = f遍歷文件夾;
for(。){
if(fs[i]是文件){
輸入
}else{
遞歸test(fs[i]);
}
}
4. 偽代碼怎么寫
偽代碼(Pseudocode)是一種算法描述語(yǔ)言。
使用偽代碼的目的是為了使被描述的算法可以容易地以任何一種編程語(yǔ)言(Pascal,C,Java,etc)實(shí)現(xiàn)。因此,偽代碼必須結(jié)構(gòu)清晰、代碼簡(jiǎn)單、可讀性好,并且類似自然語(yǔ)言。
介于自然語(yǔ)言與編程語(yǔ)言之間。 它以編程語(yǔ)言的書寫形式指明算法的職能。
相比于程序語(yǔ)言(例如Java, C++,C, Dephi 等等)它更類似自然語(yǔ)言。它是半角式化、不標(biāo)準(zhǔn)的語(yǔ)言。
我們可以將整個(gè)算法運(yùn)行過(guò)程的結(jié)構(gòu)用接近自然語(yǔ)言的形式(這里,你可以使用任何一種你熟悉的文字,中文,英文 等等,關(guān)鍵是你把你程序的意思表達(dá)出來(lái))描述出來(lái). 使用偽代碼, 可以幫助我們更好的表述算法, 不用拘泥于具體的實(shí)現(xiàn). 人們?cè)谟貌煌木幊陶Z(yǔ)言實(shí)現(xiàn)同一個(gè)算法時(shí)意識(shí)到,他們的實(shí)現(xiàn)(注意:這里是實(shí)現(xiàn),不是功能)很不同。尤其是對(duì)于那些熟練于不同編程語(yǔ)言的程序員要理解一個(gè)(用其他編程語(yǔ)言編寫的程序的)功能時(shí)可能很難,因?yàn)槌绦蛘Z(yǔ)言的形式限制了程序員對(duì)程序關(guān)鍵部分的理解。
這樣偽代碼就應(yīng)運(yùn)而生了。 當(dāng)考慮算法功能(而不是其語(yǔ)言實(shí)現(xiàn))時(shí),偽代碼常常得到應(yīng)用。
計(jì)算機(jī)科學(xué)在教學(xué)中通常使用虛擬碼,以使得所有的程序員都能理解。 綜上,簡(jiǎn)單的說(shuō),讓人便于理解的代碼。
不依賴于語(yǔ)言的,用來(lái)表示程序執(zhí)行過(guò)程,而不一定能編譯運(yùn)行的代碼。在數(shù)據(jù)結(jié)構(gòu)講算法的時(shí)候用的很多。
5. 偽代碼的寫法
類Pascal語(yǔ)言的偽代碼的語(yǔ)法規(guī)則是: 在偽代碼中,每一條指令占一行(else if,例外)。指令后不跟任何符號(hào)(Pascal和C中語(yǔ)句要以分號(hào)結(jié)尾)。
偽代碼實(shí)例如下:
IF 九點(diǎn)以前 THEN
do 私人事務(wù);
ELSE 9點(diǎn)到18點(diǎn) THEN
工作;
ELSE
下班;
END IF
這樣不但可以達(dá)到文檔的效果,同時(shí)可以節(jié)約時(shí)間。更重要的是,使結(jié)構(gòu)比較清晰,表達(dá)方式更加直觀。
偽代碼(Pseudocode)是一種算法描述語(yǔ)言。使用偽代碼的目的是為了使被描述的算法可以容易地以任何一種編程語(yǔ)言(Pascal,C,Java,etc)實(shí)現(xiàn)。因此,偽代碼必須結(jié)構(gòu)清晰、代碼簡(jiǎn)單、可讀性好,并且類似自然語(yǔ)言。 介于自然語(yǔ)言與編程語(yǔ)言之間。
它以編程語(yǔ)言的書寫形式指明算法的職能。相比于程序語(yǔ)言(例如Java, C++,C, Dephi 等等)它更類似自然語(yǔ)言。它是半角式化、不標(biāo)準(zhǔn)的語(yǔ)言。
我們可以將整個(gè)算法運(yùn)行過(guò)程的結(jié)構(gòu)用接近自然語(yǔ)言的形式(這里,你可以使用任何一種你熟悉的文字,中文,英文 等等,關(guān)鍵是你把你程序的意思表達(dá)出來(lái))描述出來(lái)。使用偽代碼, 可以幫助我們更好的表述算法,不用拘泥于具體的實(shí)現(xiàn)。
6. 偽代碼的寫法
最低0.27元開通文庫(kù)會(huì)員,查看完整內(nèi)容 原發(fā)布者:wangwenjxnu 偽代碼偽代碼是用介于自然語(yǔ)言和計(jì)算機(jī)語(yǔ)言之間的文字和符號(hào)來(lái)描述算法。
每一行(或幾行)表示一個(gè)基本操作。它不用圖形符號(hào),因此書寫方便、格式緊湊,也比較好懂,便于向程序過(guò)渡。
偽代碼的7個(gè)主要部分:(1)算法名稱(2)指令序列(3)輸入/輸出(4)分支選擇(5)賦值(6)循環(huán)(7)算法結(jié)束1.算法名稱兩種表示算法的偽代碼:過(guò)程(Procedure)函數(shù)(Function)過(guò)程和函數(shù)的區(qū)別是:過(guò)程是執(zhí)行一系列的操作,不需要返回操作的結(jié)果,無(wú)返回?cái)?shù)據(jù);函數(shù)是執(zhí)行一系列的操作后,要將操作的結(jié)果返回,有返回?cái)?shù)據(jù)。算法偽代碼的書寫規(guī)則:Procedure([])Function([])如:ProcedureHanoi_Tower()FunctionFac(x)表示名為Fac的一個(gè)函數(shù)。
FunctionProg(n)表示名為Prog的一個(gè)函數(shù)。2.指令序列指令序列是算法的主體。
指令序列的書寫規(guī)則:用Begin作為開始、用End作為結(jié)束;用“{”作為開始、用“/}”作為結(jié)束。例如:Begin指令序列;End或者:{指令序列;/}3.輸出/輸出輸入:Input輸出:Output或Return4.分支選擇兩種分支:IfThen{指令序列/}IfThen{。
網(wǎng)頁(yè)名稱:計(jì)算機(jī)算法java代碼 計(jì)算機(jī)算法java代碼是什么
當(dāng)前鏈接:http://m.rwnh.cn/article38/hiehpp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供動(dòng)態(tài)網(wǎng)站、做網(wǎng)站、服務(wù)器托管、網(wǎng)站內(nèi)鏈、網(wǎng)站維護(hù)、App設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容