Ⅰ java是近幾年的語言嗎
Java是一種計算機編程語言,擁有跨平台、面向對象、泛型編程的特性,廣泛應用於企業級Web應用開發和移動應用開發。
1991 年Sun公司的James Gosling等人開始開發名稱為 Oak 的語言。希望用於控制嵌入在有線電視交換盒、PDA等的微處理器
1994年將Oak語言更名為Java
1998年JDK1.2時,更名為Java 2 Platform
分為標准版J2SE,企業版J2EE,微型版J2ME
Java 既安全、可移植,又可跨平台,而且人們發現它能夠解決Internet 上的大型應用問題
Internet使Java成為網上最流行的編程語言
Java對Internet的影響也意義深遠
B/S的興起 & C/S的沒落
任職於太陽微系統的詹姆斯•高斯林等人於1990年代初開發Java語言的雛形,最初被命名為Oak,目標設置在家用電器等小型系統的程序語言,應用在電視機、電話、鬧鍾、烤麵包機等家用電器的控制和通信。由於這些智能化家電的市場需求沒有預期的高,Sun公司放棄了該項計劃。隨著1990年代互聯網的發展,Sun公司看見Oak在互聯網上應用的前景,於是改造了Oak,於1995年5月以Java的名稱正式發布。Java伴隨著互聯網的迅猛發展而發展,逐漸成為重要的網路編程語言。
Java編程語言的風格十分接近C++語言。繼承了C++語言面向對象技術的核心,Java舍棄了C++語言中容易引起錯誤的指針,改以引用替換,同時移除原C++與原來運算符重載,也移除多重繼承特性,改用介面替換,增加垃圾回收器功能。在Java SE 1.5版本中引入了泛型編程、類型安全的枚舉、不定長參數和自動裝/拆箱特性。太陽微系統對Java語言的解釋是:「Java編程語言是個簡單、面向對象、分布式、解釋性、健壯、安全與系統無關、可移植、高性能、多線程和動態的語言。」
Java不同於一般的編譯語言或直譯語言。它首先將源代碼編譯成位元組碼,然後依賴各種不同平台上的虛擬機來解釋執行位元組碼,從而實現了「一次編寫,到處運行」的跨平台特性。在早期JVM中,這在一定程度上降低了Java程序的運行效率。但在J2SE1.4.2發布後,Java的運行速度有了大幅提升。
與傳統型態不同,Sun公司在推出Java時就將其作為開放的技術。全球數以萬計的Java開發公司被要求所設計的Java軟體必須相互兼容。「Java語言靠群體的力量而非公司的力量」是 Sun公司的口號之一,並獲得了廣大軟體開發商的認同。這與微軟公司所倡導的注重精英和封閉式的模式完全不同,此外,微軟公司後來推出了與之競爭的.NET平台以及模仿Java的C#語言。後來Sun公司被甲骨文公司並購,Java也隨之成為甲骨文公司的產品。
Ⅱ 最早出現的Web編程語言是什麼 A、VRML B、HTML C、JAVA D、ASP
樓主的概念沒有搞清楚,沒有明確的「Web編程語言」這個概念
HTML是數據描述語言,是XML的一個子集(它屬於XML的一種),確切得說它是對數據的一種描述
VRML則是另一種數據描述語言
數據描述語言的作用是描述數據,比如說你的瀏覽器要和伺服器交流,那麼一個說中文一個說英文大家肯定聽不懂,於是就有了HTML,伺服器給你傳送了一個HTML,你的瀏覽器拿到的是HTML這個純文本的東西,但它認識,並且會把它轉化成一個漂亮的頁面。
HTML就是這個作用,它用<center>告訴你這個字要居中,用<img src="...">告訴你還需要下載某個圖片,等等,它不是編程語言,而是一種對數據格式的描述。
JAVA和ASP則是腳本語言,類似的還有php, python, 包括C/C++之類的也可以歸納進來。它的作用是生成HTML頁面。比如我的網頁有一個表格,這些表格的數據來自於後台資料庫。於是我可以用JAVA(通常是JSP)或者ASP把數據從資料庫讀出來,整理成一個HTML文件,再把這個文件傳送給客戶。目前最流行的腳本語言是PHP, ASP, JSP,它們簡單而強大。當然C/C++也可以實現這些功能,比如網路知道的後台就有C++的模塊,因為它更快速。
若問誕生時間,毫無疑問C/C++最早,分別是1972年和1980年,它們誕生於互聯網出生之前。Java生於94年,asp比它晚兩年。
而對於數據描述語言,HTML誕生於1990年,是專門伴隨著Web而出生的。而VRML始於1994年
Ⅲ javaWeb怎麼記錄修改的歷史
看到這個需求,我第一反應是設計在java層做更新記錄好像更方便。不需要任何其他知識點了。
資料庫加一張表就行,比如名叫record
表裡面 entry property old new date 類似這么幾個欄位,java層再加一個這個表對應的實體類Record,並且有一個insert方法
在Problem的update方法里,很容易能獲取到這幾個值,update成功以後創建一個Record對象insert到表裡。
這樣做的好處是可以收集任意一個實體類的修改記錄,可能有User,Person等等。查詢的時候根據entry
name這個欄位來區分。這樣無論多少次修改,都能保存直觀的歷史記錄。
至於這樣污染了update的代碼,你可以思考下依靠spring的aop編程,比如後置通知之類的,將比較新老值,組裝成Record對象等邏輯,分離到一個通用、獨立的方法里。其實這一點還是需要思考一下,如果才能更優雅地實現。
Ⅳ java Web 怎麼記錄修改的歷史
我知道你是否使用Spring框架, 如果使用Spring框架的話, 使用aop就能很簡單的進行實現
首先必須要設計一個history表, 包含操作用戶, 行為類型, 內容
面向某些操作進行切面編程, 因為輸入的是一個類, 那麼就可以直接將改類變成一個history實例存入到資料庫中
可以設計一個界面, 對history表進行管理查詢
Ⅳ 什麼是java 的web2.0開發
問題1 什麼是web2.0開發
要理解WEB2.0,先得看WEB的歷史。 World Wide Web,簡稱WWW,是英國人TimBerners-Lee 1989年在歐洲共同體的一個大型科研機構任職時發明的。通過WEB,互聯網上的資源,可以在一個網頁里比較直觀的表示出來;而且資源之間,在網頁上可以鏈來鏈去。在WEB1.0上做出巨大貢獻的公司有Netscape,Yahoo和Google。 Netscape研發出第一個大規模商用的瀏覽器,Yahoo的楊致遠提出了互聯網黃頁, 而Google後來居上,推出了大受歡迎的搜索服務。
搜索最大的貢獻是,把互聯網上海量的信息,用機器初步分了個線索。但是,光知道網頁里有哪些關鍵字,只解決了人瀏覽網頁的需求。所以,Tim-Berners-Lee在提出WWW不久,即開始推崇語義網(Semantic Web)的概念。為什麼呢?因為互聯網上的內容,機器不能理解。他的理想是,網頁製作時和架構資料庫時,大家都用一種語義的方式,將網頁里的內容表述成機器可以理解的格式。這樣,整個互聯網就成了一個結構嚴謹的知識庫。從理想的角度,這是很誘人的,因為科學家和機器都喜歡有次序的東西。Berners-Lee關心的是,互聯網上數據,及能否被其它的互聯網應用所重復引用。舉一個例子說明標准資料庫的魅力。有個產品叫LiberyLink。裝了它後,到Amazon上去瀏覽時,會自動告訴你某一本書在用戶當地的圖書館能否找到,書號是多少等。因為一本書有統一的書號和書名,兩個不同的互聯網服務(Amazon 和當地圖書館資料庫檢索)可以公享數據,給用戶提供全新服務。
但是,語義網提出之後,曲高和寡,響應的人不多。為什麼?因為指望要網頁的製作者提供這么多額外的信息去讓機器理解一個網頁,太難;簡直就是人給機器打工。這違反了人們能偷懶就偷懶的本性。看看Google的成功就知道。 Google有個Page Rank技術,將網頁之間互相鏈接的關系,用來做結果排序的一個依據,變相利用了網頁製作人的判斷力。想一想網頁的製作者們,從數量來說,比純瀏覽者的數量小得多。但Google就這一個革新,用上了網頁的製作者的一部份力量,已將其推上了互聯網的頂峰。
所以互聯網下一步,是要讓所有的人都忙起來,全民織網,然後用軟體,機器的力量使這些信息更容易被需要的人找到和瀏覽。如果說WEB1.0是以數據為核心的網,那我覺得WEB2.0是以人為出發點的互聯網。 我們看一看最近的一些WEB2.0產品,就可以理解以上觀點。
Blog: 用戶織網,發表新知識,和其他用戶內容鏈接,進而非常自然的組織這些內容。
RSS: 用戶產生內容自動分發,定閱
Podcasting: 個人視頻/聲頻的發布/定閱
SNS: blog+人和人之間的鏈接
WIKI: 用戶共同建設一個大網路全書
從知識生產的角度看,WEB1.0的任務,是將以前沒有放在網上的人類知識,通過商業的力量,放到網上去。WEB2.0的任務是,將這些知識,通過每個用戶的瀏覽求知的力量,協作工作,把知識有機的組織起來,在這個過程中繼續將知識深化,並產生新的思想火花;
從內容產生者角度看,WEB1.0是商業公司為主體把內容往網上搬,而WEB2.0則是以用戶為主,以簡便隨意方式,通過blog/podcasting 方式把新內容往網上搬;
從交互性看,WEB1.0是網站對用戶為主;WEB2.0是以P2P為主。
從技術上看,WEB客戶端化,工作效率越來越高。比如像Ajax技術, GoogleMAP/Gmail裡面用得出神入化。
我們看到,用戶在互聯網上的作用越來越大;他們貢獻內容,傳播內容,而且提供了這些內容之間的鏈接關系和瀏覽路徑。在SNS裡面,內容是以用戶為核心來組織的。WEB2.0是以用戶為核心的互聯網。
那麼,這種意義上的WEB2.0,和Tim Berners-Lee的語義網,有什麼不同呢?語義網的出發點是數據的規整及可重復被機器調用,提出使用語義化的內容發布工具, 試圖從規則和技術標准上使互聯網更加有序。 Google等搜索引擎,在沒有語義網的情況下,盡可能的給互聯網提供了線索。 WEB2.0則是鼓勵用戶用最方便的辦法發布內容(blog/podcasting),但是通過用戶自發的(blog)或者系統自動以人為核心(SNS)的互相鏈接給這些看似凌亂的內容提供索引。 因為這些線索是用戶自己提供,更加符合用戶使用感受。互聯網逐漸從以關鍵字為核心的組織方式和閱讀方式,到以互聯網用戶的個人portal(SNS)為線索,或者以個人的思想脈絡(blog/rss)為線索的閱讀方式。WEB2.0強調用戶之間的協作。WIKI是個典型例子。從這個角度看,互聯網是在變得更有序,每個用戶都在貢獻:要麼貢獻內容,要麼貢獻內容的次序.
對下一代互聯網的看法,還會有很多的討論。有一點可以肯定,WEB2.0是以人為核心線索的網。提供更方便用戶織網的工具,鼓勵提供內容。根據用戶在互聯網上留下的痕跡,組織瀏覽的線索,提供相關的服務,給用戶創造新的價值,給整個互聯網產生新的價值,才是WEB2.0商業之道。
java中的web2.0開發呢
java是一種技術,就是JSP做網站 相當於ASP編程 PHP編程 ASP.net編程 等
Ⅵ Java web框架入門學習的路線是怎麼樣的求詳解
JavaWeb核心框架
持久層框架:Hibernate、iBATIS
2.表現層框架:Struts1、Struts2
3.業務層框架:Spring
1、Hibernate:ORM
Hibernate是一個Java ORM開發框架
ORM是Object Relation Mapping的縮寫,顧名思義,即對象關系映射。
ORM是一種以面向對象的方式來進行資料庫操作的技術。Web開發中常用的語言,都會有對應的ORM框架。而Hibernate就是Java開發中一種常用ORM框架,另一個現在流行的ORM框架是Mybatis。
為什麼需要ORM框架?
簡單地理解,通過Java進行資料庫訪問的正常流程可以分為以下幾步:
准備好SQL語句
調用JDBC的API傳入SQL語句,設置參數
解析JDBC返回的結果
這個過程實際上非常麻煩,比如:
在Java代碼中拼接SQL非常麻煩,而且易於出錯
JDBC的代碼調用有很多重復性的代碼
從JDBC返回的結果轉換成領域模型的Java對象很繁瑣
而使用ORM框架,則可以讓我們用面向對象的方式來操作資料庫,比如通過一個簡單的函數調用就完成上面整個流程,直接返回映射為Java對象的結果。這個流程中很大一部分工作其實可以交給ORM自動化地幫我們執行。對,類似MVC框架,ORM框架會幫你處理好相關的繁瑣事情!
2. Struts:MVC
Struts是一個Java Web MVC開發框架。MVC早在1978年就作為Smalltalk的一種設計模式被提出來了,引用到Web應用中來時:
模型Model用於封裝與業務邏輯相關的數據和數據處理方法
視圖View是數據的HTML展現
控制器Controller負責響應請求,協調Model和View
Model,View和Controller的分開,是一種典型的關注點分離的思想,不僅使得代碼復用性和組織性更好,使得Web應用的配置性和靈活性更好。
MVC開發模式下,Java Web開發會遇到URL路由、模板渲染、表單綁定/提交/驗證、Session封裝、許可權驗證、國際化等一系列通用的問題,而MVC框架會將這些通用問題都封裝進框架中,你在應用中根據自己的場景進行簡單的配置和編碼即可,MVC框架就能幫你處理好一切,可以極大地簡化代碼。
3.Spring:DI/AOP
Spring對應的關鍵詞是DI(依賴注入)與AOP(面向切面編程),可以認為是一個以DI和AOP為核心Java Web一站式的集成(粘合)框架。
其中DI也稱為IoC(控制發轉)用於管理Java對象之間的依賴關系(一定要說DI是IoC實現方式的童鞋們見評論區),AOP用於解耦業務代碼和公共服務代碼(如日誌,安全,事務等)。DI和AOP能夠讓代碼更加簡單,具有良好的松耦合特性和可測試性,極大地簡化開發。理解這兩者是使用Spring框架的基礎。
Spring框架對Java企業應用開發中的各類通用問題都進行了良好的抽象,因此也能夠把應用各個層次所涉及的特定的功能和開發框架(如接下來要說的MVC框架、ORM框架)方便得組合到一起(這也得益於依賴注入和面向切面編程帶來的強大功能)。Spring是一個極其優秀的一站式的Full-Stack集成框架,因此基於Spring核心,對Java應用開發中的各類通用問題幾乎都提供了針對性的開發框架,比如你耳熟能詳(如果你對這個問題感興趣的話)的Spring MVC,Spring Data。
Java曾經有另外一個類似的一站式框架粘合框架Seam,這是Hibernate的作者、脾氣火爆的大神Gavin King的作品,核心是基於依賴注入來黏合JSF和EJB,不過推出時Spring已經大殺四方,Seam基本已經退出歷史舞台了。記得Seam提過一個我認為很不錯的概念:「雙向注入」,類似現在前端框架中的雙向綁定,當時來說還是很超前的。
Ⅶ JavaWeb類似與微博私信功能的系統如何實現,還可以查看歷史記錄
現在好多使用現成的東西做的。Ajax是技術,和你說的業務沒有關系。推薦搜一下ThinkPHP,資料庫的話不是一時半會可以說清楚的,看下這個吧http://www.ithinksns.org/p_2526.html
Ⅷ JavaWeb學習路線
JavaWeb核心框架
持久層框架:Hibernate、iBATIS
表現層框架:Struts1、Struts2
業務層框架:Spring
java學習路線圖:
1、Hibernate:ORM
Hibernate是一個Java ORM開發框架
ORM是Object Relation Mapping的縮寫,顧名思義,即對象關系映射。
ORM是一種以面向對象的方式來進行資料庫操作的技術。Web開發中常用的語言,都會有對應的ORM框架。而Hibernate就是Java開發中一種常用ORM框架,另一個現在流行的ORM框架是Mybatis。
為什麼需要ORM框架?
簡單地理解,通過Java進行資料庫訪問的正常流程可以分為以下幾步:
准備好SQL語句
調用JDBC的API傳入SQL語句,設置參數
解析JDBC返回的結果
這個過程實際上非常麻煩,比如:
在Java代碼中拼接SQL非常麻煩,而且易於出錯
JDBC的代碼調用有很多重復性的代碼
從JDBC返回的結果轉換成領域模型的Java對象很繁瑣
而使用ORM框架,則可以讓我們用面向對象的方式來操作資料庫,比如通過一個簡單的函數調用就完成上面整個流程,直接返回映射為Java對象的結果。這個流程中很大一部分工作其實可以交給ORM自動化地幫我們執行。對,類似MVC框架,ORM框架會幫你處理好相關的繁瑣事情!
2. Struts:MVC
Struts是一個Java Web MVC開發框架。MVC早在1978年就作為Smalltalk的一種設計模式被提出來了,引用到Web應用中來時:
模型Model用於封裝與業務邏輯相關的數據和數據處理方法
視圖View是數據的HTML展現
控制器Controller負責響應請求,協調Model和View
Model,View和Controller的分開,是一種典型的關注點分離的思想,不僅使得代碼復用性和組織性更好,使得Web應用的配置性和靈活性更好。
MVC開發模式下,Java Web開發會遇到URL路由、模板渲染、表單綁定/提交/驗證、Session封裝、許可權驗證、國際化等一系列通用的問題,而MVC框架會將這些通用問題都封裝進框架中,你在應用中根據自己的場景進行簡單的配置和編碼即可,MVC框架就能幫你處理好一切,可以極大地簡化代碼。
3.Spring:DI/AOP
Spring對應的關鍵詞是DI(依賴注入)與AOP(面向切面編程),可以認為是一個以DI和AOP為核心Java Web一站式的集成(粘合)框架。
其中DI也稱為IoC(控制發轉)用於管理Java對象之間的依賴關系(一定要說DI是IoC實現方式的童鞋們見評論區),AOP用於解耦業務代碼和公共服務代碼(如日誌,安全,事務等)。DI和AOP能夠讓代碼更加簡單,具有良好的松耦合特性和可測試性,極大地簡化開發。理解這兩者是使用Spring框架的基礎。
Spring框架對Java企業應用開發中的各類通用問題都進行了良好的抽象,因此也能夠把應用各個層次所涉及的特定的功能和開發框架(如接下來要說的MVC框架、ORM框架)方便得組合到一起(這也得益於依賴注入和面向切面編程帶來的強大功能)。Spring是一個極其優秀的一站式的Full-Stack集成框架,因此基於Spring核心,對Java應用開發中的各類通用問題幾乎都提供了針對性的開發框架,比如你耳熟能詳(如果你對這個問題感興趣的話)的Spring MVC,Spring Data。
Java曾經有另外一個類似的一站式框架粘合框架Seam,這是Hibernate的作者、脾氣火爆的大神Gavin King的作品,核心是基於依賴注入來黏合JSF和EJB,不過推出時Spring已經大殺四方,Seam基本已經退出歷史舞台了。記得Seam提過一個我認為很不錯的概念:「雙向注入」,類似現在前端框架中的雙向綁定,當時來說還是很超前的。
Ⅸ Java語言的發展歷史
Sun的Java語言開發小組成立於1991年,其目的是開拓消費類電子產品市場,例如:互動式電視,烤麵包箱等。Sun內部人員把這個項目稱為Green,那時World Wide Web還在圖紙上呢。該小組的領導人是James Gosling,41歲。於1984年加盟Sun Microsystem公司,以前在一家IBM研究機構工作。他是Sun NeWs窗口系統的總設計師,雖然當時NeWs在技術上非常成功,但在商業上卻完全失敗,沒有了Java那麼好的運氣。Gosling是一位非常傑出的程序員,GOSMACS也是Gosling寫的,它是第一個用C實現的EMACS的文本編輯器。
在研究開發過程中,Gosling 深刻體會到消費類電子產品和工作站產品的開發哲學之間差異:消費類電子產品要求高可靠、費用低、標准化、使用簡單,而工作站用戶要求強大的計算能力,而不在此乎價格以及操作的復雜性。消費類電子產品用戶並不關心CPU的型號,也不欣賞專用昂貴的RISC處理器,他們需要建立在一個標准基礎之上,一系列可選的方案,從8086-80586都可以上。
從C++開始 為了使整個系統與平台無關,Gosling首先從改寫C++編譯器著手。但是Gosling在改寫過程中感到僅C++是無法滿足需要的,於是在1991年6月份開始准備開發一個新的語言,那麼給它起一個什麼名字呢? Gosling回首向窗外望去,看見一棵老橡樹,於是建一個目錄叫Oak,這就是Java語言的前身。(後來發現Oak已是Sun公司的另一個語言的注冊商標,才改名為Java,即爪哇,太平洋上一個盛產咖啡的島嶼的名字)。
Gosling在開始寫Java時,並不局限於擴充語言機制本身,更注重於語言所運行軟硬體環境,他要建立一個系統,這個系統運行於一個巨大的、分布的、異質的網路環境中,完成各電子設備之間的通訊與協同工作。Gosling在設計中採用了虛機器碼(Virtual Machine Code)方式。即Java語言編譯後產生的是虛機器碼,虛機器碼運行在一個解釋器上,每一個操作系統均有一個解釋器,這樣一來,Java就成了平台無關語言。這和Gosling設計的Sun NeWs窗口系統有著相同的技術味道,在NeWs中用戶界面統一用Postscript描述,不同的顯示器有不同的Postscript解釋器,這樣便保證了用戶界面的良好的可移植性。
當Patrick Naughton加入該小組後,整個工作進展神速。Naughton也是Sun公司的技術骨幹,曾經是Open Windows的項目的負責人。經過17個月的奮戰,整個系統勝利完成。它是由一個操作系統,一種語言(Java),一個用戶界面,一個新的硬體平台,三塊專用晶元的構成。而通常情況下,這樣的項目在Sun公司要75個人干三年。項目完成後,在Sun公司內部做一次展示和鑒定,觀眾的反應是: 在各方面都採用了嶄新的、非常大膽的技術。許多參觀者對Java留下了非常深刻的印象,特別得到Sun的二位領導人Scott McNealy和Bill Joy的關注,但Java的前途未卜。
初戰告敗
接著,Java項目的工作人員開始做應用規劃,著手成立一家公司,從事消費類電子產品的開發,這家公司就是FirstPerson Inc.。公司的第一個項目就是Time-Warner的投標項目,頂置盒式操作系統和請求式電視技術。雖然FirstPerson Inc.在技術毫不遜色於任何公司,但是由於經營策略上的失誤,敗給了SGI。FirstPerson一直到1994年初仍在堅持開發專用的頂置盒式操作系統,但實踐證明,這個市場尚未成熟。例如:好幾家互動式有線電視網的實驗都以失敗告終。
Naughton立即認識到研究方向應該轉移。在Naughton的努力下,研究開始向在線服務,CD-ROM和基於網路的台式機方向轉移。最後FirstPerson解散,一部分人去了Sun Interactive開發數字視頻數據伺服器,而另一部分開始把Java用於基於網路的台式機系統。
Java語言的轉折點
到了1994年,WWW已如火如荼的發展起來。Gosling意識到WWW需要一個中性的瀏覽器,它不依賴於任何硬體平台和軟體平台。它應是一種實時性較高,可靠安全,有交互功能的瀏覽器。於是Gosling決定用Java開發一個新的Web瀏覽器。
Ⅹ java畢設求救,題目是:基於編輯歷史的web數據質量評估系統
Web上的數據質量良莠不齊,本系統根據維基網路網站數據編輯歷史實現網頁質量評估系統。
1. 准確理解web數據質量的相關概念;
2. 理解編輯歷史的先關演算法;
3. 評估結果的圖形化顯示
簡單網上找吧