推薦!國外程序員整理的Java資源大全

jopen 9年前發布 | 79K 次閱讀 Java資源大全

Java 幾乎是許多程序員們的入門語言,并且也是世界上非常流行的編程語言。國外程序員 Andreas Kull 在其 Github 上整理了非常優秀的 Java 開發資源,推薦給大家。

譯文由 ImportNew唐尤華翻譯完成。

以下為具體資源列表。

構建

這里搜集了用來構建應用程序的工具。

  • Apache Maven:Maven 使用聲明進行構建并進行依賴管理,偏向于使用約定而不是配置進行構建。Maven 優于 Apache Ant。后者采用了一種過程化的方式進行配置,所以維護起來相當困難。
  • Gradle:Gradle 采用增量構建。Gradle 通過 Groovy 編程而不是傳統的 XML 聲明進行配置。Gradle 可以很好地配合 Maven 進行依賴管理,并且把 Ant 腳本當作頭等公民。

字節碼操作

編程操作 Java 字節碼的函數庫。

  • ASM:通用底層字節碼操作及分析。
  • Javassist:嘗試簡化字節碼編輯。
  • Byte Buddy:使用“流式 API”進一步簡化字節碼生成。

代碼分析

軟件度量和質量評估工具。

  • Checkstyle:對編程規范和標準進行靜態分析。
  • FindBugs:通過字節碼靜態分析找出潛在 Bug。
  • PMD:對源代碼中不良編程習慣進行分析。
  • SonarQube:通過插件集成其它分析組件,提供評估最終結果報告。

編譯器

創建分析器、解釋器和編譯器的框架。

  • ANTLR:功能完備的自頂向下分析復雜框架。
  • JavaCC:相對 ANTLR 更具體,上手略為簡單。支持語法語法超前預測(syntactic lookahead)。

持續集成

支持持續集成、測試和應用發布的工具。

  • Bamboo:Atlassian 的持續集成(CI)解決方案,包含很多其它產品。
  • CircleCI:提供托管服務,可免費試用。
  • Codeship:提供托管服務,提供有限免費計劃。
  • Go:ThoughtWork 開源持續集成解決方案。
  • Jenkins:提供基于服務器的部署服務。
  • TeamCity:JetBrain 持續集成方案,提供免費版。
  • Travis:提供托管服務,常用于開源項目。

數據庫

簡化數據庫交互的工具、庫。

  • Flyway:使用 Java API 輕松完成數據庫遷移。
  • H2:小型 SQL 數據庫,以內存操作著稱。
  • JDBI:便捷的 JDBC 抽象。
  • jOOQ:基于 SQL schema 生成類型安全代碼。
  • Presto:針對大數據的分布式 SQL 查詢引擎。
  • Querydsl:針對 Java 的類型安全統一查詢。

日期和時間

處理日期和時間的函數庫。

  • Joda-Time:Java 8 出現之前,它是日期、時間處理的標準函數庫。
  • Time4J:Java 高級日期、時間函數庫。

依賴注入

幫助代碼實現 控制反轉模式的函數庫。

  • Dagger:編譯期的注入框架,沒有使用反射,主要用于 Android 開發。
  • Guice:輕量級注入框架,功能強大可與 Dagger 媲美。

開發庫

從基礎層次上改進開發流程。

  • AspectJ:面向切面編程擴展,與程序無縫連接。
  • Auto:源代碼生成器集合。
  • DCEVM:通過修改 JVM,在運行時可無限次重定義已加載的類。OpenJDK 7、8 已提供支持,詳情可查看 這個分支(fork)
  • JRebel:商用軟件,無需重新部署可即時重新加載代碼及配置。
  • Lombok:代碼生成器,旨在減少 Java 冗余代碼。
  • RxJava:使用 JVM 中可觀察序列,創建異步、基于事件應用程序的函數庫。
  • Spring Loaded:另一個 JVM 類重載代理。
  • vert.x:JVM 多語言事件驅動應用框架。

分布式應用

用來開發分布式、具有容錯性應用程序的函數庫和框架。

  • Akka:構建并發、分布式和具有容錯功能的事件驅動應用程序所需的工具包和運行時。
  • Apache Storm:分布式實時計算系統。
  • Apache ZooKeeper:為大型分布式系統,使用分布式配置、同步和命名注冊提供協調服務。
  • Hazelcast:分布式、高可擴展性內存網格。
  • Hystrix:為分布式系統提供延遲和容錯處理。
  • JGroups:一組提供可靠消息傳輸的工具包,可用來創建集群。集群中的節點可互相發送消息。
  • Quasar:為 JVM 提供輕量級線程和 Actor。

發布

使用本機格式分發 Java 應用程序的工具。

  • Bintray:對二進制發布進行版本控制,可與 Maven 或 Gradle 配合使用。
  • IzPack:為跨平臺部署建立授權工具。
  • Launch4j:將 JAR 包裝為小巧的 Windows 可執行文件。
  • packr:將程序 JAR、資源和 JVM 打包成 Windows、Linux 和 Mac OS X 的本機文件。

文檔處理

用來處理 Office 格式文檔的函數庫。

  • Apache POI:支持 OOXML (XLSX、DOCX、PPTX)以及 OLE2 (XLS, DOC or PPT)格式的文檔。
  • jOpenDocument:處理 OpenDocument 格式文檔。

游戲開發

游戲開發框架。

  • jMonkeyEngine:支持現代 3D 開發的游戲引擎。
  • libGDX:全面的跨平臺高級開發框架。
  • LWJGL:抽象了 OpenGL、CL、AL 等函數庫的健壯框架。

GUI

用來創建現代圖形用戶界面的函數庫。

高性能

與高性能計算有關的資源,包括集合以及很多具體功能的函數庫。

  • Disruptor:線程間消息函數庫。
  • fastutil:快速緊湊的 Java 類型安全集合。
  • GS Collections:受 Smalltalk 啟發的集合框架。
  • hftc:Hash set 和 hash map。
  • HPPC:基本類型集合。
  • Javolution:針對實時嵌入式系統的函數庫。
  • Trove:基本類型集合。

IDE

視圖簡化開發的集成開發環境。

  • Eclipse:后臺做了很多工作,以其豐富插件著稱。
  • IntelliJ IDEA:支持很多 JVM 語言,為 Android 開發提供了很多不錯的選項。其商業版本主要面向企業用戶。
  • NetBeans:集成了很多 Java SE 和 Java EE 特性,包括數據庫訪問、服務器、HTML5 以及 AngularJS。

圖像處理

用來幫助創建、評估或操作圖形的函數庫。

  • Picasso:Android 下載圖像和圖像緩存函數庫。
  • ZXing:多種格式的一維、二維條形碼處理函數庫。

JSON

簡化 JSON 處理的函數庫。

  • Gson:將 Java 對象序列化為 JSON 及反向操作。使用時提供了很好的性能。
  • Jackson:與 GSON 類似,但如果需要頻繁初始化 Jackson 庫會帶來性能問題。

JVM 和 JDK

目前的 JVM、JDK 實現。

  • JDK 9:JDK 9 早期訪問版本。
  • OpenJDK:開源實現。

日志

記錄應用程序的日志函數庫。

  • Apache Log4j 2:對之前版本進行了完全重寫。現在的版本具備一個強大的插件和配置架構。
  • kibana:對日志進行分析并進行可視化。
  • Logback:Log4j 原班人馬作品。被證明是一個強健的日志函數庫,通過 Groovy 提供了很多有意思的配置選項。
  • logstash:日志文件管理工具。
  • SLF4J:日志抽象層,需要與某個具體日志框架配合使用。

機器學習

提供具體統計算法的工具。其算法可從數據中學習。

  • Apache Hadoop:對商用硬件集群上大規模數據存儲和處理的開源軟件框架。
  • Apache Mahout:專注協同過濾、聚類和分類的可擴展算法。
  • Apache Spark:開源數據分析集群計算框架。
  • h2o:用作大數據統計的分析引擎。
  • Weka:用作數據挖掘的算法集合,包括從預處理到可視化的各個層次。

消息

在客戶端之間進行消息傳遞,確保協議獨立性的工具。

  • Apache ActiveMQ:實現 JMS 的開源消息代理(broker),可將同步通訊轉為異步通訊。
  • Apache Kafka:高吞吐量分布式消息系統。
  • JBoss HornetQ:清晰、準確、模塊化且方便嵌入的消息工具。
  • JeroMQ:ZeroMQ 的純 Java 實現。

其它

其它資源。

  • Design Patterns:實現并解釋了最常見的設計模式
  • Jimfs:內存文件系統。
  • Lanterna:類似 curses 的簡單 console 文本 GUI 函數庫。
  • LightAdmin:可插入式 CRUD UI 函數庫,可用于快速應用開發。
  • Metrics:創建自己的軟件度量或者為支持框架添加度量信息,通過 JMX 或 HTTP 進行發布或者發送到數據庫。
  • OpenRefine:用來處理混亂數據的工具,包括清理、轉換、使用 Web Service 進行擴展并將其關聯到數據庫。
  • RoboVM:Java 編寫原生 iOS 應用。

自然語言處理

用來專門處理文本的函數庫。

  • Apache OpenNL:處理類似分詞等常見任務的工具。
  • CoreNLP:斯坦佛的 CoreNLP 提供了一組基礎工具,可以處理類似標簽、實體名識別和情感分析這樣的任務。
  • LingPipe:一組可以處理各種任務的工具集,支持 POS 標簽、情感分析等。
  • Mallet:統計學自然語言處理、文檔分類、聚類、主題建模等。

網絡

網絡編程函數庫。

  • Netty:構建高性能網絡應用程序開發框架。
  • OkHttp:一個 Android 和 Java 應用的 HTTP+SPDY 客戶端。

ORM

處理對象持久化的 API。

  • EclipseLink:支持許多持久化標準,JPA、JAXB、JCA 和 SDO。
  • Hibernate:廣泛使用、強健的持久化框架。Hibernate 的技術社區非常活躍。
  • Ebean:支持快速數據訪問和編碼的 ORM 框架。

PDF

用來幫助創建 PDF 文件的資源。

  • Apache FOP:從 XSL-FO 創建 PDF。
  • Apache PDFBox:用來創建和操作 PDF 的工具集。
  • DynamicReports:JasperReports 的精簡版。
  • iText:一個易于使用的 PDF 函數庫,用來編程創建 PDF 文件。注意,用于商業用途時需要許可證。
  • JasperReports:一個復雜的報表引擎。

REST 框架

用來創建 RESTful 服務的框架。

  • Dropwizard:偏向于自己使用的 Web 框架。用來構建 Web 應用程序,使用了 Jetty、Jackson、Jersey 和 Metrics。
  • Jersey:JAX-RS 參考實現。
  • RESTEasy:經過 JAX-RS 規范完全認證的可移植實現。
  • Retrofit:一個 Java 類型安全的 REST 客戶端。
  • Spark:受到 Sinatra 啟發的 Java REST 框架。
  • Swagger:Swagger 是一個規范且完整的框架,提供描述、生產、消費和可視化 RESTful Web Service。

科學

用于科學計算和分析的函數庫。

  • SCaVis:用于科學計算、數據分析和數據可視化環境。

搜索

文檔索引引擎,用于搜索和分析。

  • Apache Solr:一個完全的企業搜索引擎。為高吞吐量通信進行了優化。
  • Elasticsearch:一個分布式、支持多租戶(multitenant)全文本搜索引擎。提供了 RESTful Web 接口和無 schema 的 JSON 文檔。

安全

用于處理安全、認證、授權或會話管理的函數庫。

  • Apache Shiro:執行認證、授權、加密和會話管理。
  • Cryptomator:在云上進行客戶端跨平臺透明加密。
  • Keycloak:為瀏覽器應用和 RESTful Web Service 集成 SSO 和 IDM。目前還處于 beta 版本,但是看起來非常有前途。
  • PicketLink:PicketLink 是一個針對 Java 應用進行安全和身份認證管理的大型項目(Umbrella Project)。
  • Spring Security:專注認證、授權和多維度攻擊防護框架。

序列化

用來高效處理序列化的函數庫。

  • FlatBuffers:序列化函數庫,高效利用內存,無需解包和解析即可高效訪問序列化數據。
  • Kryo:快速和高效的對象圖形序列化框架。
  • MessagePack:一種高效的二進制序列化格式。

服務器

用來部署應用程序的服務器。

  • Apache Tomcat:針對 Servlet 和 JSP 的應用服務器,健壯性好且適用性強。
  • Apache TomEE:Tomcat 加 Java EE。
  • GlassFish:Java EE 開源參考實現,由 Oracle 資助開發。
  • Jetty:輕量級、小巧的應用服務器,通常會嵌入到項目中。
  • WildFly:之前被稱作 JBoss,由 Red Hat 開發。支持很多 Java EE 功能。

模版引擎

對模板中表達式進行替換的工具。

  • Apache Velocity:提供 HTML 頁面模板、email 模板和通用開源代碼生成器模板。
  • FreeMarker:通用模板引擎,不需要任何重量級或自己使用的依賴關系。
  • Handlebars.java:使用 Java 編寫的模板引擎,邏輯簡單,支持語義擴展(semantic Mustache)。
  • JavaServer Pages:通用網站模板,支持自定義標簽庫。
  • Thymeleaf:旨在替換 JSP,支持 XML 文件。

測試

測試內容從對象到接口,涵蓋性能測試和基準測試工具。

  • Apache JMeter:功能性測試和性能評測。
  • Arquillian:集成測試和功能行測試平臺,集成 Java EE 容器。
  • AssertJ:支持流式斷言提高測試的可讀性。
  • JMH:JVM 微基準測試工具。
  • JUnit:通用測試框架。
  • Mockito:在自動化單元測試中創建測試對象,為 TDD 或 BDD 提供支持。
  • Selenium:為 Web 應用程序提供可移植軟件測試框架。
  • Selenide:為 Selenium 提供精準的周邊 API,用來編寫穩定且可讀的 UI 測試。
  • TestNG:測試框架。
  • VisualVM:提供可視化方式查看運行中的應用程序信息。

工具類

通用工具類函數庫。

  • Apache Commons:提供各種用途的函數,比如配置、驗證、集合、文件上傳或 XML 處理等。
  • Guava:集合、緩存、支持基本類型、并發函數庫、通用注解、字符串處理、I/O等。
  • javatuples:正如名字表示的那樣,提供 tuple 支持。盡管目前 tuple 的概念還有留有爭議。

網絡爬蟲

用于分析網站內容的函數庫。

  • Apache Nutch:可用于生產環境的高度可擴展、可伸縮的網絡爬蟲。
  • Crawler4j:簡單的輕量級爬蟲。
  • JSoup:刮取、解析、操作和清理 HTML。

Web 框架

用于處理 Web 應用程序不同層次間通訊的框架。

  • Apache Tapestry:基于組件的框架,使用 Java 創建動態、強健的、高度可擴展的 Web 應用程序。
  • Apache Wicket:基于組件的 Web 應用框架,與 Tapestry 類似帶有狀態顯示 GUI。
  • Google Web Toolkit:一組 Web 開發工具集,包含在客戶端將 Java 代碼轉為 JavaScript 的編譯器、XML 解析器、RCP API、JUnit 集成、國際化支持和 GUI 控件。
  • Grails:Groovy 框架,旨在提供一個高效開發環境,使用約定而非配置、沒有 XML 并支持混入(mixin)。
  • Play: 使用約定而非配置,支持代碼熱加載并在瀏覽器中顯示錯誤。
  • PrimeFaces:JSF 框架,提供免費版和帶技術支持的商業版。包含一些前端組件。
  • Spring Boot:微框架,簡化了 Spring 新程序的開發過程。
  • Spring:旨在簡化 Java EE 的開發過程,提供依賴注入相關組件并支持面向切面編程。
  • Vaadin:基于 GWT 構建的事件驅動框架。使用服務端架構,客戶端使用 Ajax。
  • Ninja:Java 全棧 Web 開發框架。非常穩固、快速和高效。
  • Ratpack:一組 Java 開發函數庫,用于構建快速、高效、可擴展且測試完備的 HTTP 應用程序。

社區

活躍的討論區。

有影響的書籍

具有廣泛影響且值得閱讀的 Java 經典書籍。

播客

可以一邊編程一邊聽的東西。

推ter

值得關注的帳號。

  • Adam Bien:自由職業者、作家、JavaONE 明星演講者、顧問、Java Champion。
  • Antonio Goncalves:Java Champion、JUG Leader、Devoxx France、Java EE 6/7、JCP、作家。
  • Arun Gupta:Java Champion、JavaONE 明星演講者、JUG Leader、Devoxx4Kids 成員、Red Hatter。
  • Bruno Borges:Oracle 產品經理、Java Jock。
  • Ed Burns:Oracle 技術團隊顧問。
  • Eugen Paraschiv:Spring 安全課程作者。
  • James Weaver:Java、JavaFX、IoT 開發者、作者和演講者。
  • Java EE:Java EE 推ter 官方賬號。
  • Java Magazine:Java 雜志官方賬號。
  • Java.net:Java.net 官方賬號。
  • Java:Java 推ter 官方賬號。
  • Javin Paul:知名 Java 博客作者。
  • Lukas Eder:Data Geekery(jOOQ)創始人兼 CEO。
  • Mario Fusco:RedHatter、JUG 協調、活躍講師和作者。
  • Mark Reinhold:Oracle 首席架構師、Java 平臺開發組。
  • Martijn Verburg:London JUG co-leader、演講者、作家、Java Champion 等。
  • OpenJDK:OpenJDK 官方賬號。
  • Reza Rahman:Java EE、GlassFish、WebLogic 傳道者、作家、演講者、開源黑客。
  • Simon Maple:Java Champion、virtualJUG 創始人、LJC leader、RebelLabs 作者。
  • Stephen Colebourne: Java Champion、演講者。
  • Tim Boudreau:作家、NetBeans 大牛。
  • Trisha Gee:Java Champion、演講者。

網站

值得閱讀的網站。

參與貢獻

熱烈歡迎參與貢獻此列表!

請參閱 CONTRIBUTING 加入貢獻。

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!