Tính đến tháng 11 năm 2024, phiên bản mới nhất là Java 23, được phát hành vào 17 tháng 9 năm 2024.Oracle phát hành bản cập nhật miễn phí cho công chúng với phiên bảnkế thừaJava 8 LTS vào tháng 1 năm 2019 cho mục đích sử dụng thương mại, mặc dù nếu không nó sẽ vẫn hỗ trợ Java 8 với các bản cập nhật công khai cho mục đích sử dụng cá nhân vô thời hạn. Các nhà cung cấp khác đã bắt đầu cung cấpcác bản miễn phí của OpenJDK 8 và 11 mà vẫn đang nhận được bảo mật và các nâng cấp khác.
Oracle (và những công ty khác) khuyên người dùng nên gỡ cài đặt các phiên bản Java đã lỗi thời vì những rủi ro nghiêm trọng do các vấn đề bảo mật chưa được giải quyết.[21] Vì Java 9, 10, 12, 13 và 14 không còn được hỗ trợ, Oracle khuyên người dùng nên chuyển ngay sang phiên bản mới nhất (hiện tại là Java 23) hoặc bản phát hành LTS.
James Gosling, Mike Sheridan vàPatrick Naughton khởi xướng dự án ngôn ngữ Java vào tháng 6 năm 1991.[22] Java ban đầu được thiết kế cho truyền hình tương tác, nhưng nó quá tiên tiến đối với ngành truyền hình cáp kỹ thuật số vào thời điểm đó.[23] Ban đầu ngôn ngữ này được gọi làOak theo tên mộtcây sồi bên ngoài văn phòng của Gosling. Sau đó, dự án có tên làGreen và cuối cùng được đổi tên thànhJava, từcà phê Java, loại cà phê đến từIndonesia.[24] Gosling đã thiết kế Java với cú pháp kiểuC/C++ mà các lập trình viên hệ thống và ứng dụng đã quen thuộc.[25]
Sun Microsystems đã phát hành bản triển khai công khai đầu tiên dưới dạng Java 1.0 vào năm 1996.[26] Nó hứa hẹn khả năngViết một lần, Chạy mọi nơi (WORA), cung cấp thời gian chạy miễn phí trên cácnền tảng phổ biến. Khá an toàn và có tính năng bảo mật có thể định cấu hình, nó cho phép các hạn chế truy cập mạng và tệp. Cáctrình duyệt web lớn đã sớm kết hợp khả năng chạycác ứng dụng Java trong các trang web và Java nhanh chóng trở nên phổ biến. Trình biên dịch Java 1.0 được viết lại bằngJava bởiArthur van Hoff để tuân thủ nghiêm ngặt đặc tả ngôn ngữ Java 1.0.[27] Với sự ra đời của Java 2 (ban đầu được phát hành với tên gọi J2SE 1.2 vào tháng 12 năm 1998–1999), các phiên bản mới có nhiều cấu hình được xây dựng cho các loại nền tảng khác nhau. J2EE bao gồm các công nghệ và API cho các ứng dụng doanh nghiệp thường chạy trong môi trường máy chủ, trong khi các API đặc trưng của J2ME được tối ưu hóa cho các ứng dụng di động. Phiên bản dành cho máy tính để bàn được đổi tên thành J2SE. Năm 2006, vì mục đích tiếp thị, Sun đã đổi tên các phiên bản J2 mới lần lượt làJava EE,Java ME vàJava SE.
Năm 1997, Sun Microsystems đã tiếp cận cơ quantiêu chuẩn ISO/IEC JTC 1 và sau đó làEcma International để chính thức hóa Java, nhưng sau đó công ty nhanh chóng rút khỏi quy trình này.[28][29][30] Java vẫn là mộttiêu chuẩnthực tế, được kiểm soát thông quaQuy trình cộng đồng Java.[31] Đã có lúc, Sun cung cấp hầu hết các triển khai Java của mình mà không tính phí, bất chấp trạng tháiphần mềm độc quyền của họ. Sun đã tạo ra doanh thu từ Java thông qua việc bán giấy phép cho các sản phẩm chuyên biệt như Hệ thống Doanh nghiệp Java.
Vào ngày 13 tháng 11 năm 2006, Sun đã phát hành phần lớn máy ảo Java (JVM) của mình dưới dạngphần mềm mã nguồn mở và miễn phí (FOSS), theo các điều khoản củaGiấy phép Công cộng GNU (GPL). Vào ngày 8 tháng 5 năm 2007, Sun đã hoàn thành quá trình, cung cấp tất cả mã cốt lõi của JVM theocác điều khoản phân phốiphần mềm miễn phí/nguồn mở, ngoại trừ một phần nhỏ mã mà Sun không giữ bản quyền.[32][33]
Phó chủ tịch Rich Green của Sun nói rằng vai trò lý tưởng của Sun đối với Java là như mộtnhà truyền giáo.[34] Sau khiTập đoàn Oracle mua lại Sun Microsystems vào năm 2009–10, Oracle đã tự mô tả mình là người quản lý công nghệ Java với cam kết không ngừng thúc đẩy cộng đồng tham gia và minh bạch.[35] Điều này không ngăn được Oracle đệ đơn kiện Google ngay sau đó vì đã sử dụng Java bên trongAndroid SDK.
Ngày 2 tháng 4 năm 2010, James Gosling từ chức tạiOracle.[36]
Vào tháng 1 năm 2016, Oracle đã thông báo rằng môi trường thời gian chạy Java dựa trên JDK 9 sẽ ngừng cung cấp plugin trình duyệt.[37]
Sun đã xác định và hỗ trợ bốn phiên bản Java nhắm mục tiêu các môi trường ứng dụng khác nhau và phân đoạn nhiềuAPI của nó để chúng thuộc về một trong các nền tảng. Các nền tảng là:
Một mục tiêu thiết kế của Java là tính di động, có nghĩa là các chương trình được viết cho nền tảng Java phải chạy tương tự nhau trên bất kỳ sự kết hợp nào giữa phần cứng vàhệ điều hành với hỗ trợ thời gian chạy thích hợp. Điều này đạt được bằng cách biêndịch mã ngôn ngữ Java sang một đại diện trung gian được gọi làbytecode Java, thay vì trực tiếp tớimã máy cụ thể về kiến trúc. Các lệnh bytecode trong Java tương tự như mã máy, nhưng chúng được thiết kế để thực thi bởi mộtmáy ảo (VM) được viết riêng cho phần cứng máy chủ.Người dùng cuối thường sử dụngJava Runtime Environment (JRE) được cài đặt trên máy của họ cho các ứng dụng Java độc lập hoặc trong trình duyệt web chocác ứng dụng Java.
Các thư viện tiêu chuẩn cung cấp một cách chung để truy cập các tính năng dành riêng cho máy chủ như đồ họa,phân luồng vàmạng.
Việc sử dụng bytecode phổ biến làm cho việc chuyển cổng trở nên đơn giản. Tuy nhiên, chi phí củaviệc thông dịch bytecode thành các lệnh máy làm cho các chương trình được thông dịch hầu như luôn chạy chậm hơn các chương trìnhthực thi gốc. Các trình biên dịchjust-in-time (JIT) biên dịch bytecode thành mã máy trong thời gian chạy đã được giới thiệu từ giai đoạn đầu. Bản thân Java độc lập với nền tảng và được điều chỉnh cho phù hợp với nền tảng cụ thể màmáy ảo Java (JVM) chạy trên nó, máy này sẽ dịch bytecode Java sang ngôn ngữ máy của nền tảng.[48]
Các chương trình được viết bằng Java nổi tiếng là chậm hơn và đòi hỏi nhiều bộ nhớ hơn các chương trình được viết bằngC++.[49][50] Tuy nhiên, tốc độ thực thi của các chương trình Java được cải thiện đáng kể với sự ra đời củatính năng biên dịch đúng lúc vào năm 1997–1998 choJava 1.1,[51] việc bổ sung các tính năng ngôn ngữ hỗ trợ phân tích mã tốt hơn (chẳng hạn như các lớp bên trong, lớp StringBuilder, các xác nhận tùy chọn,...) và tối ưu hóa trong máy ảo Java, chẳng hạn nhưHotSpot trở thành mặc định cho JVM của Sun vào năm 2000. Với Java 1.5, hiệu suất đã được cải thiện với việc bổ sung góijava.util.concurrent, và được cải thiện hơn nữa với Java 1.6.
Một số nền tảng cung cấp hỗ trợ phần cứng trực tiếp cho Java; có những bộ điều khiển vi mô có thể chạy bytecode Java trong phần cứng thay vì máy ảo Java phần mềm,[52] và một số bộ xử lý dựa trênARM có thể có hỗ trợ phần cứng để thực thi bytecode Java thông qua tùy chọnJazelle của chúng, mặc dù hỗ trợ hầu hết đã bị loại bỏ trong các triển khai hiện tại của ARM.
Java sử dụngbộ thu gom rác tự động (AGC) để quản lý bộ nhớ trongvòng đời đối tượng. Lập trình viên xác định thời điểm các đối tượng được tạo và thời gian chạy Java chịu trách nhiệm khôi phục bộ nhớ khi các đối tượng không còn được sử dụng. Khi không còn tham chiếu đến một đối tượng,bộ nhớ không thể truy cập sẽ đủ điều kiện để được giải phóng tự động bởi bộ thu gom rác. Một cái gì đó tương tự nhưrò rỉ bộ nhớ vẫn có thể xảy ra nếu mã của lập trình viên giữ một tham chiếu đến một đối tượng không còn cần thiết, thường là khi các đối tượng không còn cần thiết được lưu trữ trong các bộ chứa vẫn đang được sử dụng. Nếu các phương thức cho một đối tượng không tồn tại được gọi, một ngoại lệcon trỏ null sẽ được đưa ra.[53][54]
Một trong những ý tưởng đằng sau mô hình quản lý bộ nhớ tự động của Java là các lập trình viên có thể không phải chịu gánh nặng khi phải thực hiện quản lý bộ nhớ thủ công. Trong một số ngôn ngữ, bộ nhớ để tạo các đối tượng được cấp phát ngầm trênngăn xếp hoặc được cấp phát và phân bổ rõ ràng từheap. Trong trường hợp thứ hai, trách nhiệm quản lý bộ nhớ thuộc về lập trình viên. Nếu chương trình không phân bổ một đối tượng, mộtrò rỉ bộ nhớ sẽ xảy ra. Nếu chương trình cố gắng truy cập hoặc phân bổ bộ nhớ đã được phân bổ, kết quả là không xác định và khó dự đoán, và chương trình có thể trở nên không ổn định hoặc gặp sự cố. Điều này có thể được khắc phục một phần bằng cách sử dụng cáccon trỏ thông minh, nhưng chúng làm tăng thêm chi phí và sự phức tạp. Lưu ý rằng việc thu gom rác không ngăn chặn rò rỉbộ nhớ logic, tức là những nơi bộ nhớ vẫn được tham chiếu nhưng không bao giờ được sử dụng.
Việc thu gom rác có thể xảy ra bất cứ lúc nào. Lý tưởng nhất, nó sẽ xảy ra khi một chương trình không hoạt động. Nó được đảm bảo sẽ được kích hoạt nếu không có đủ bộ nhớ trống trên heap để cấp phát một đối tượng mới; điều này có thể khiến một chương trình bị dừng trong giây lát. Không thể quản lý bộ nhớ rõ ràng trong Java.
Java không hỗ trợsố học con trỏ kiểu C/C++, trong đó địa chỉ đối tượng có thể được thao tác số học (ví dụ: bằng cách thêm hoặc trừ một phần bù). Điều này cho phép bộ thu gom rác di chuyển các đối tượng được tham chiếu và đảm bảo an toàn và bảo mật kiểu.
Giống như trong C++ và một số ngôn ngữ hướng đối tượng khác, các biến củakiểu dữ liệu nguyên thủy của Java hoặc được lưu trữ trực tiếp trong các trường (đối với các đối tượng) hoặc trênngăn xếp (đối với các phương thức) chứ không phải trên heap, điều này thường đúng đối với dữ liệu không nguyên thủy các loại (nhưng hãy xemphân tích thoát). Đây là một quyết định có ý thức của các nhà thiết kế của Java vì lý do hiệu suất.
Java chứa nhiều loại trình thu gom rác. Theo mặc định, HotSpot sử dụngbộ thu gom rác quét song song.[55] Tuy nhiên, cũng có một số trình thu gom rác khác có thể được sử dụng để quản lý đống rác. Đối với 90% ứng dụng trong Java, bộ thu gom rácđồng thời Mark-Sweep (CMS) là đủ.[56] Oracle đặt mục tiêu thay thế CMS bằng Garbage-First Collector (G1).[57]
Giải quyết được vấn đề quản lý bộ nhớ không giúp lập trình viên bớt gánh nặng xử lý đúng cách các loại tài nguyên khác, như kết nối mạng hoặc cơ sở dữ liệu, xử lý tệp,... đặc biệt là khi có lỗi.
Applet Java là các chương trình đượcnhúng vào trong các ứng dụng khác, thường là trong một trang web hiển thị trongtrình duyệt web. API của applet Java hiện không còn được dùng nữa kể từ năm 2017.[58]
Công nghệJakarta Servlet cung cấp cho các nhà phát triển web một cơ chế nhất quán, đơn giản để mở rộng chức năng củamáy chủ web và để truy cập các hệ thống kinh doanh hiện có. Servlet là các thành phần Java EEphía máy chủ tạo ra các phản hồi (thường là các trangHTML) cho các yêu cầu (thường là các yêu cầuHTTP) từmáy khách.
Ở một mức độ nào đó, API củaJakarta Servlet đã được thay thế bởi hai công nghệ Java cho dịch vụ web:
Biểu đồ sự phổ biến của 10 ngôn ngữ lập trình phổ biến nhất thế giới từ 30 tháng 6 năm 2001 đến 9 tháng 12 năm 2017. Trong suốt thời gian 16 năm này, Java và C luôn giữ hai vị trí đầu.
Tính đến ngày 21 tháng 1 năm 2021, Java là ngôn ngữ lập trình phổ biến thứ nhì thế giới với tỷ lệ 11,96% chỉ xếp sau ngôn ngữ C. Qua nhiều năm Java và C vẫn luôn chiếm hai vị trí đầu tiên trong bảng các ngôn ngữ lập trình phổ biến nhất suốt 20 năm qua, tuy những năm gần đây độ phổ biến có xu hướng giảm nhưng Java vẫn giữ được tỷ lệ trên 10% mặc cho sự phát triển chóng mặt của thế giới công nghệ, Java thể hiện đẳng cấp một ngôn ngữ lập trình chất lượng của nhân loại.[59]
^Binstock, Andrew (ngày 20 tháng 5 năm 2015)."Java's 20 Years of Innovation".Forbes.Lưu trữ bản gốc ngày 14 tháng 3 năm 2016. Truy cập ngày 18 tháng 3 năm 2016.
^Niklaus Wirth stated on a number of public occasions, e.g. in a lecture at the Polytechnic Museum, Moscow in September, 2005 (several independent first-hand accounts in Russian exist, e.g. one with an audio recording:Filippova, Elena (ngày 22 tháng 9 năm 2005)."Niklaus Wirth's lecture at the Polytechnic Museum in Moscow".Bản gốc lưu trữ ngày 1 tháng 12 năm 2020. Truy cập ngày 5 tháng 1 năm 2013.), that the Sun Java design team licenced the Oberon compiler sources a number of years prior to the release of Java and examined it: a (relative) compactness, type safety, garbage collection, no multiple inheritance for classes -- all these key overall design features are shared by Java and Oberon.
^Patrick Naughton citesObjective-C as a strong influence on the design of the Java programming language, stating that notable direct derivatives include Java interfaces (derived from Objective-C'sprotocol) and primitive wrapper classes.[3]
^TechMetrix Research (1999)."History of Java"(PDF).Java Application Servers Report.Bản gốc(PDF) lưu trữ ngày 29 tháng 12 năm 2010. Truy cập ngày 5 tháng 1 năm 2013.The project went ahead under the name "green" and the language was based on an old model ofUCSD Pascal, which makes it possible to generate interpretive code
^The Java Language Team.About Microsoft's "Delegates" (White Paper). JavaSoft, Sun Microsystems, Inc.Bản gốc lưu trữ ngày 27 tháng 6 năm 2012.In the summer of 1996, Sun was designing the precursor to what is now the event model of the AWT and the JavaBeans component architecture. Borland contributed greatly to this process. We looked very carefully at Delphi Object Pascal and built a working prototype of bound method references in order to understand their interaction with the Java programming language and its APIs.
^McMillan, Robert (ngày 1 tháng 8 năm 2013)."Is Java Losing Its Mojo?".Bản gốc lưu trữ ngày 15 tháng 2 năm 2017. Truy cập ngày 8 tháng 3 năm 2017.Java is on the wane, at least according to one outfit that keeps on eye on the ever-changing world of computer programming languages. For more than a decade, it has dominated theTIOBE Programming Community Index, and is back on top – a snapshot of software developer enthusiasm that looks at things like internet search results to measure how much buzz different languages have. But lately, Java has been slipping.
^Object-oriented programming"The History of Java Technology".Sun Developer Network. k. 1995.Bản gốc lưu trữ ngày 10 tháng 2 năm 2010. Truy cập ngày 30 tháng 4 năm 2010.
^"Oracle and Java".oracle.com. Oracle Corporation. Truy cập ngày 23 tháng 8 năm 2010.Oracle has been a leading and substantive supporter of Java since its emergence in 1995 and takes on the new role as steward of Java technology with a relentless commitment to fostering a community of participation and transparency.
^"Oracle and Java".oracle.com. Oracle Corporation.Bản gốc lưu trữ ngày 31 tháng 1 năm 2010. Truy cập ngày 23 tháng 8 năm 2010.Oracle has been a leading and substantive supporter of Java since its emergence in 1995 and takes on the new role as steward of Java technology with a relentless commitment to fostering a community of participation and transparency.
^Salcic, Zoran; Park, Heejong; Teich, Jürgen; Malik, Avinash; Nadeem, Muhammad (ngày 22 tháng 7 năm 2017). "Noc-HMP: A Heterogeneous Multicore Processor for Embedded Systems Designed in SystemJ".ACM Transactions on Design Automation of Electronic Systems. Quyển 22 số 4. tr. 73.doi:10.1145/3073416.ISSN1084-4309.