stringtranslate.com

Java (plataforma de software)

TuxGuitar , un programa basado en Java

Java es un conjunto de software y especificaciones informáticas que proporciona una plataforma de software para desarrollar software de aplicación e implementarlo en un entorno informático multiplataforma . Java se utiliza en una amplia variedad de plataformas informáticas, desde dispositivos integrados y teléfonos móviles hasta servidores empresariales y supercomputadoras . Los applets de Java , que son menos comunes que las aplicaciones Java independientes, se ejecutaban comúnmente en entornos seguros y aislados para proporcionar muchas funciones de aplicaciones nativas mediante su integración en páginas HTML .

Escribir en el lenguaje de programación Java es la forma principal de producir código que se implementará como código de bytes en una máquina virtual Java (JVM); los compiladores de código de bytes también están disponibles para otros lenguajes, incluidos Ada , JavaScript , Kotlin (el lenguaje Android preferido de Google), Python y Ruby . Además, se han diseñado varios lenguajes para ejecutarse de forma nativa en la JVM, incluidos Clojure , Groovy y Scala . La sintaxis de Java toma prestado en gran medida de C y C++ , pero las características orientadas a objetos se modelan a partir de Smalltalk y Objective-C . [13] Java evita ciertas construcciones de bajo nivel como punteros y tiene un modelo de memoria muy simple donde los objetos se asignan en el montón (mientras que algunas implementaciones, por ejemplo, todas las actualmente compatibles con Oracle, pueden usar la optimización del análisis de escape para asignar en la pila en su lugar) y todas las variables de los tipos de objetos son referencias . La gestión de la memoria se maneja a través de la recolección automática de basura integrada realizada por la JVM.

Última versión

La última versión es Java 22 lanzada en marzo de 2024, y la última versión de soporte a largo plazo (LTS) es Java 21 lanzada en septiembre de 2023, que es una de las pocas versiones LTS que aún reciben soporte, hasta Java 8 LTS. Como plataforma de código abierto, Java tiene muchos distribuidores, incluidos Amazon , IBM , Azul Systems y AdoptOpenJDK . Las distribuciones incluyen Amazon Corretto, Zulu, AdoptOpenJDK y Liberica. En cuanto a Oracle, distribuye Java 8 y también pone a disposición, por ejemplo, Java 11, ambas también versiones LTS actualmente compatibles. Oracle (y otros) "recomiendan encarecidamente que desinstale versiones anteriores de Java" que Java 8, [14] debido a los graves riesgos debido a problemas de seguridad sin resolver. [15] [16] [17] Dado que Java 9 (así como las versiones 10, 12 a 16 y 18 a 20) ya no reciben soporte, Oracle recomienda a sus usuarios que "realicen inmediatamente la transición" a una versión compatible. Oracle lanzó la última actualización pública gratuita para uso comercial para la versión anterior de Java 8 LTS en enero de 2019 y seguirá brindando soporte para Java 8 con actualizaciones públicas para uso personal de manera indefinida. El soporte extendido de Oracle para Java 6 finalizó en diciembre de 2018. [18]

Plataforma

La plataforma Java es un conjunto de programas que facilitan el desarrollo y la ejecución de programas escritos en el lenguaje de programación Java . Una plataforma Java incluye un motor de ejecución (llamado máquina virtual ), un compilador y un conjunto de bibliotecas ; también puede haber servidores adicionales y bibliotecas alternativas que dependen de los requisitos. Las plataformas Java se han implementado para una amplia variedad de hardware y sistemas operativos con el objetivo de permitir que los programas Java se ejecuten de manera idéntica en todos ellos.

La plataforma Java consta de varios programas, cada uno de los cuales proporciona una parte de sus capacidades generales. Por ejemplo, el compilador de Java , que convierte el código fuente de Java en código de bytes de Java (un lenguaje intermedio para la JVM), se proporciona como parte del Kit de desarrollo de Java (JDK). El entorno de ejecución de Java (JRE), que complementa a la JVM con un compilador justo a tiempo (JIT) , convierte el código de bytes intermedio en código de máquina nativo sobre la marcha. La plataforma Java también incluye un amplio conjunto de bibliotecas.

Los componentes esenciales de la plataforma son el compilador del lenguaje Java, las bibliotecas y el entorno de ejecución en el que el código de bytes intermedio de Java se ejecuta de acuerdo con las reglas establecidas en la especificación de la máquina virtual.

Dominios de aplicación

Diferentes plataformas apuntan a diferentes clases de dispositivos y dominios de aplicaciones :

Java SE

Java Platform, Standard Edition (Java SE) es una plataforma informática para el desarrollo e implementación de código portable para entornos de escritorio y servidor . [19] Java SE antes se conocía como Java 2 Platform, Standard Edition (J2SE).

La plataforma utiliza el lenguaje de programación Java y forma parte de la familia de plataformas de software Java. Java SE define una serie de API de propósito general (como las API de Java para la biblioteca de clases Java ) y también incluye la especificación del lenguaje Java y la especificación de la máquina virtual Java . [20] OpenJDK es la implementación de referencia oficial desde la versión 7. [21] [22] [23]

EE. UU. de Yakarta

Jakarta EE , anteriormente Java Platform, Enterprise Edition (Java EE) y Java 2 Platform, Enterprise Edition (J2EE), es un conjunto de especificaciones que extiende Java SE [24] con especificaciones para características empresariales como computación distribuida y servicios web . [25] Las aplicaciones de Jakarta EE se ejecutan en tiempos de ejecución de referencia , que pueden ser microservicios o servidores de aplicaciones , que manejan transacciones, seguridad, escalabilidad, concurrencia y administración de los componentes que están implementando.

Máquina virtual Java

El corazón de la plataforma Java es la "máquina virtual" que ejecuta programas de código de bytes de Java . Este código de bytes es el mismo sin importar en qué hardware o sistema operativo se esté ejecutando el programa. Sin embargo, las nuevas versiones, como la de Java 10 (y anteriores), han realizado pequeños cambios, lo que significa que el código de bytes en general solo es compatible con versiones posteriores . Hay un compilador JIT (Just In Time) dentro de la Máquina Virtual de Java o JVM. El compilador JIT traduce el código de bytes de Java en instrucciones nativas del procesador en tiempo de ejecución y almacena en caché el código nativo en la memoria durante la ejecución.

El uso de bytecode como lenguaje intermedio permite que los programas Java se ejecuten en cualquier plataforma que tenga una máquina virtual disponible. El uso de un compilador JIT significa que las aplicaciones Java, después de un breve retraso durante la carga y una vez que se han "calentado" al ser compiladas en su totalidad o en su mayor parte con JIT, tienden a ejecutarse tan rápido como los programas nativos. [26] [27] [28] Desde la versión 1.2 de JRE, la implementación de JVM de Sun ha incluido un compilador justo a tiempo en lugar de un intérprete.

Aunque los programas Java son multiplataforma o independientes de la plataforma, el código de las máquinas virtuales Java (JVM) que ejecutan estos programas no lo es. Cada plataforma operativa compatible tiene su propia JVM.

Kit de desarrollo de Java

El Java Development Kit (JDK) es una distribución de tecnología Java de Oracle Corporation . Implementa la especificación del lenguaje Java (JLS) y la especificación de la máquina virtual Java (JVMS) y proporciona la edición estándar (SE) de la interfaz de programación de aplicaciones (API) de Java. Es un derivado del OpenJDK impulsado por la comunidad que Oracle administra. [29] Proporciona software para trabajar con aplicaciones Java. Algunos ejemplos de software incluido son la máquina virtual Java, un compilador, herramientas de monitoreo de rendimiento, un depurador y otras utilidades que Oracle considera útiles para los programadores de Java.

Oracle publica la versión actual del software bajo la licencia Oracle No-Fee Terms and Conditions (NFTC). Oracle publica archivos binarios para la arquitectura x86-64 para sistemas operativos basados ​​en Windows, macOS y Linux, y para la arquitectura aarch64 para macOS y Linux. Las versiones anteriores eran compatibles con el sistema operativo Oracle Solaris y la arquitectura SPARC .

La implementación principal de JVMS de Oracle se conoce como HotSpot (máquina virtual) .

Entorno de ejecución de Java

El entorno de ejecución de Java (JRE) lanzado por Oracle es una distribución de software disponible de forma gratuita que contiene una JVM independiente (HotSpot), la biblioteca estándar de Java ( Java Class Library ), una herramienta de configuración y, hasta su discontinuación en JDK 9, un complemento de navegador. Es el entorno Java más común instalado en computadoras personales en el formato portátil y de escritorio . Los teléfonos móviles, incluidos los teléfonos con funciones básicas y los primeros teléfonos inteligentes que se entregan con una JVM, probablemente incluyan una JVM diseñada para ejecutar aplicaciones destinadas a Micro Edition de la plataforma Java. Mientras tanto, la mayoría de los teléfonos inteligentes modernos, tabletas y otras PC de mano que ejecutan aplicaciones Java probablemente lo hagan a través del soporte del sistema operativo Android , que incluye una máquina virtual de código abierto incompatible con la especificación JVM. (En cambio, las herramientas de desarrollo de Android de Google toman como entrada los programas Java y como salida el bytecode Dalvik , que es el formato de entrada nativo para la máquina virtual en los dispositivos Android). La última versión de Critical Path Update de JRE con un Oracle BCL Agreement [30] fue 8u201 y, la última versión de Patch Set Update con la misma licencia fue 8u202. [31] [32] La última implementación de Oracle JRE, independientemente de su esquema de licencias, fue 9.0.4. [33] Desde Java Platform SE 9, toda la plataforma también se agrupó en módulos . [34] La modularización de las implementaciones de Java SE permite a los desarrolladores agrupar sus aplicaciones junto con todos los módulos que utilizan, en lugar de confiar únicamente en la presencia de una implementación de Java SE adecuada en el dispositivo del usuario. [35] [36] [37] [38]

Bibliotecas de clases

En la mayoría de los sistemas operativos (SO) modernos, se proporciona una gran cantidad de código reutilizable para simplificar el trabajo del programador. Este código se proporciona normalmente como un conjunto de bibliotecas cargables dinámicamente que las aplicaciones pueden llamar en tiempo de ejecución. Debido a que la plataforma Java no depende de ningún sistema operativo específico, las aplicaciones no pueden depender de ninguna de las bibliotecas de SO preexistentes. En cambio, la plataforma Java proporciona un conjunto completo de sus propias bibliotecas de clases estándar que contienen muchas de las mismas funciones reutilizables que se encuentran comúnmente en los sistemas operativos modernos. La mayor parte de la biblioteca del sistema también está escrita en Java. Por ejemplo, la biblioteca Swing pinta la interfaz de usuario y maneja los eventos por sí misma, eliminando muchas diferencias sutiles entre la forma en que las diferentes plataformas manejan los componentes.

Las bibliotecas de clases de Java cumplen tres funciones dentro de la plataforma Java. En primer lugar, al igual que otras bibliotecas de código estándar, las bibliotecas de Java proporcionan al programador un conjunto conocido de funciones para realizar tareas comunes, como mantener listas de elementos o realizar análisis complejos de cadenas. En segundo lugar, las bibliotecas de clases proporcionan una interfaz abstracta para tareas que normalmente dependerían en gran medida del hardware y el sistema operativo. Tareas como el acceso a la red y el acceso a archivos suelen estar muy entrelazadas con las implementaciones distintivas de cada plataforma. Las bibliotecas java.nety java.ioimplementan una capa de abstracción en el código nativo del sistema operativo y luego proporcionan una interfaz estándar para que las aplicaciones Java realicen esas tareas. Por último, cuando alguna plataforma subyacente no admite todas las características que espera una aplicación Java, las bibliotecas de clases funcionan para manejar con elegancia los componentes ausentes, ya sea mediante emulación para proporcionar un sustituto o, al menos, proporcionando una forma consistente de verificar la presencia de una característica específica.

Idiomas

La palabra "Java", por sí sola, suele referirse al lenguaje de programación Java que fue diseñado para su uso con la plataforma Java. Los lenguajes de programación suelen quedar fuera del ámbito de aplicación de la frase "plataforma", aunque el lenguaje de programación Java figuraba como parte fundamental de la plataforma Java antes de Java 7. Por tanto, el lenguaje y el entorno de ejecución se consideraban comúnmente una sola unidad. Sin embargo, con la especificación de Java 7 se hizo un esfuerzo para tratar más claramente el lenguaje Java y la máquina virtual Java como entidades separadas, de modo que ya no se los considere una sola unidad. [39]

Terceros han producido muchos compiladores o intérpretes que apuntan a la JVM. Algunos de ellos son para lenguajes existentes, mientras que otros son para extensiones del lenguaje Java. Estos incluyen:

Plataformas similares

El éxito de Java y su concepto de "escribir una vez, ejecutar en cualquier lugar" ha llevado a otros esfuerzos similares, en particular el .NET Framework , que apareció desde 2002 y que incorpora muchos de los aspectos exitosos de Java. .NET se creó desde cero para admitir múltiples lenguajes de programación, mientras que la plataforma Java se creó inicialmente para admitir solo el lenguaje Java, aunque desde entonces se han creado muchos otros lenguajes para JVM. Al igual que Java, los lenguajes .NET se compilan en código de bytes y son ejecutados por Common Language Runtime (CLR), que es similar en propósito a la JVM. Al igual que la JVM, el CLR proporciona administración de memoria a través de la recolección automática de basura y permite que el código de bytes de .NET se ejecute en múltiples sistemas operativos.

.NET incluía un lenguaje similar a Java, primero llamado J++ y luego Visual J#, que era incompatible con la especificación Java. Se discontinuó en 2007 y su soporte finalizó en 2015.

Actuación

La especificación de la JVM otorga mucho margen de maniobra a los implementadores en lo que respecta a los detalles de implementación. Desde Java 1.3, JRE de Oracle contiene una JVM llamada HotSpot. Ha sido diseñada para ser una JVM de alto rendimiento.

Para acelerar la ejecución del código, HotSpot se basa en la compilación en tiempo real. Para acelerar la asignación de objetos y la recolección de basura, HotSpot utiliza un montón generacional.

Montón generacional

El montón de la máquina virtual Java es el área de memoria utilizada por la JVM para la asignación dinámica de memoria . [41]

En HotSpot el montón se divide en generaciones :

La generación permanente (o permgen ) se utilizó para las definiciones de clase y los metadatos asociados antes de Java 8. La generación permanente no formaba parte del montón. [42] [43] La generación permanente se eliminó de Java 8. [44]

Originalmente no existía la generación permanente y los objetos y las clases se almacenaban juntos en la misma área. Pero como la descarga de clases ocurre con mucha menos frecuencia que la recolección de objetos, mover las estructuras de clases a un área específica permitió mejoras significativas en el rendimiento. [42]

Seguridad

El JRE de Java está instalado en una gran cantidad de computadoras. Por lo tanto, los usuarios finales con una versión desactualizada del JRE son vulnerables a muchos ataques conocidos. Esto llevó a la creencia generalizada de que Java es inherentemente inseguro. [45] Desde Java 1.7, el JRE de Oracle para Windows incluye una funcionalidad de actualización automática.

Antes de que se discontinuara el complemento de Java para navegadores, cualquier página web podía ejecutar un subprograma de Java, que proporcionaba una superficie de ataque de fácil acceso para sitios web maliciosos. En 2013, Kaspersky Labs informó que el complemento de Java era el método preferido por los delincuentes informáticos. Los exploits de Java se incluyen en muchos paquetes de exploits que los piratas informáticos implementan en sitios web pirateados. [46] Los subprogramas de Java se eliminaron en Java 11, lanzado el 25 de septiembre de 2018.

Versiones de Java

Historia

James Gosling

La plataforma y el lenguaje Java comenzaron como un proyecto interno en Sun Microsystems en diciembre de 1990, proporcionando una alternativa a los lenguajes de programación C++/ C . El ingeniero Patrick Naughton se había sentido cada vez más frustrado con el estado de las interfaces de programación de aplicaciones (API) y herramientas C++ y C de Sun , así como con la forma en que la organización manejaba el proyecto NeWS . Naughton informó a Scott McNealy sobre su plan de dejar Sun y mudarse a NeXT ; McNealy le pidió que fingiera ser Dios y le enviara un correo electrónico explicándole cómo arreglar la empresa. Naughton imaginó la creación de un pequeño equipo que pudiera trabajar de forma autónoma sin la burocracia que estaba paralizando otros proyectos de Sun. McNealy reenvió el mensaje a otras personas importantes de Sun y comenzó el Proyecto Stealth . [47]

El proyecto Stealth pronto cambió su nombre a Green Project , y James Gosling y Mike Sheridan se unieron a Naughton. Junto con otros ingenieros, comenzaron a trabajar en una pequeña oficina en Sand Hill Road en Menlo Park, California . Su objetivo era desarrollar nueva tecnología para programar electrodomésticos inteligentes de próxima generación, que Sun esperaba que ofrecieran nuevas e importantes oportunidades. [48]

El equipo inicialmente consideró usar C++, pero lo rechazó por varias razones. Debido a que estaban desarrollando un sistema integrado con recursos limitados, decidieron que C++ necesitaba demasiada memoria y que su complejidad conducía a errores de desarrollo. La falta de recolección de basura del lenguaje significaba que los programadores tenían que administrar manualmente la memoria del sistema, una tarea desafiante y propensa a errores. El equipo también se preocupaba por la falta de facilidades portables del lenguaje C++ para seguridad, programación distribuida y subprocesamiento . Finalmente, querían una plataforma que pudiera ser fácilmente portada a todo tipo de dispositivos.

Bill Joy había imaginado un nuevo lenguaje que combinaba Mesa y C. En un artículo titulado Further , propuso a Sun que sus ingenieros debían producir un entorno orientado a objetos basado en C++. Inicialmente, Gosling intentó modificar y ampliar C++ (un desarrollo propuesto al que se refirió como "C++ ++ --") pero pronto abandonó esa idea a favor de crear un nuevo lenguaje, al que llamó Oak , en honor al árbol que se encontraba justo afuera de su oficina. [49]

En el verano de 1992, el equipo pudo demostrar partes de la nueva plataforma, incluyendo el Green OS , el lenguaje Oak, las bibliotecas y el hardware. Su primera demostración, el 3 de septiembre de 1992, se centró en la construcción de un dispositivo de asistente digital personal (PDA) llamado Star7 [1] que tenía una interfaz gráfica y un agente inteligente llamado "Duke" para ayudar al usuario. En noviembre de ese año, el Proyecto Green se escindió para convertirse en Firstperson , una subsidiaria de propiedad absoluta de Sun Microsystems, y el equipo se trasladó a Palo Alto, California . [50] El equipo de Firstperson tenía interés en construir dispositivos altamente interactivos, y cuando Time Warner emitió una solicitud de propuesta (RFP) para un decodificador , Firstperson cambió su objetivo y respondió con una propuesta para una plataforma de decodificador. Sin embargo, la industria del cable sintió que su plataforma le daba demasiado control al usuario, por lo que Firstperson perdió su oferta ante SGI . Un acuerdo adicional con The 3DO Company para un decodificador tampoco se materializó. Al no lograr generar interés dentro de la industria de la televisión, la compañía fue reintegrada a Sun.

Java se encuentra con la Web

Juan Gage

En junio y julio de 1994, después de tres días de intercambio de ideas con John Gage (director científico de Sun), Gosling, Joy, Naughton, Wayne Rosing y Eric Schmidt  , el equipo reorientó la plataforma hacia la World Wide Web . Pensaron que con la llegada de navegadores web gráficos como Mosaic, Internet podría evolucionar hacia el mismo medio altamente interactivo que habían imaginado para la televisión por cable. Como prototipo, Naughton escribió un pequeño navegador, WebRunner (nombrado así por la película Blade Runner ), rebautizado como HotJava [48] en 1995.

Sun renombró el lenguaje Oak a Java después de que una búsqueda de marca registrada revelara que Oak Technology usaba el nombre Oak . [51] Sun fijó el precio de las licencias de Java por debajo del costo para ganar participación de mercado. [52] Aunque Java 1.0a estuvo disponible para descarga en 1994, el primer lanzamiento público de Java, Java 1.0a2 con el navegador HotJava, llegó el 23 de mayo de 1995, anunciado por Gage en la conferencia SunWorld . Acompañando el anuncio de Gage, Marc Andreessen , vicepresidente ejecutivo de Netscape Communications Corporation , anunció inesperadamente que los navegadores Netscape incluirían soporte para Java. El 9 de enero de 1996, Sun Microsystems formó el grupo JavaSoft para desarrollar la tecnología. [53]

Si bien los denominados applets de Java para navegadores web ya no son el uso más popular de Java (por ejemplo, ahora se utilizan más en el lado del servidor) o la forma más popular de ejecutar código en el lado del cliente (JavaScript se convirtió en el más popular), aún es posible ejecutar Java (u otros lenguajes JVM como Kotlin) en navegadores web, incluso después de que se haya eliminado el soporte de JVM, utilizando, por ejemplo, TeaVM .

Licencia Pública General GNU

El 13 de noviembre de 2006, Sun Microsystems puso a disposición la mayor parte de su implementación de Java bajo la Licencia Pública General GNU (GPL). [54] [55]

Historial de versiones

El lenguaje Java ha sufrido varios cambios desde el lanzamiento de JDK ( Java Development Kit ) 1.0 el 23 de enero de 1996, así como numerosas adiciones de clases y paquetes a la biblioteca estándar . Desde J2SE 1.4, el Java Community Process (JCP) ha gobernado la evolución del lenguaje Java. El JCP utiliza Java Specification Requests (JSR) para proponer y especificar adiciones y cambios a la plataforma Java. La Java Language Specification (JLS) especifica el lenguaje; los cambios a la JLS se gestionan bajo JSR 901. [56]

Sun lanzó JDK 1.1 el 19 de febrero de 1997. Las principales incorporaciones incluyeron una reestructuración exhaustiva del modelo de eventos Abstract Window Toolkit (AWT), clases internas agregadas al lenguaje, JavaBeans y Java Database Connectivity (JDBC).

J2SE 1.2 (8 de diciembre de 1998) – Nombre en clave Playground . Esta y las versiones posteriores hasta J2SE 5.0 fueron renombradas Java 2 y el nombre de la versión "J2SE" ( Java 2 Platform, Standard Edition ) reemplazó a JDK para distinguir la plataforma base de J2EE ( Java 2 Platform, Enterprise Edition ) y J2ME ( Java 2 Platform, Micro Edition ). Las principales adiciones incluyeron la reflexión , un marco de colecciones , Java IDL (una implementación de lenguaje de descripción de interfaz para interoperabilidad CORBA ) y la integración de la API gráfica Swing en las clases principales. Se lanzó un complemento de Java y la JVM de Sun fue equipada con un compilador JIT por primera vez.

J2SE 1.3 (8 de mayo de 2000) – Nombre en clave Kestrel . Entre los cambios más notables se encuentran la incorporación de HotSpot JVM (HotSpot JVM se lanzó por primera vez en abril de 1999 para J2SE 1.2 JVM), JavaSound, Java Naming and Directory Interface (JNDI) y Java Platform Debugger Architecture (JPDA).

J2SE 1.4 (6 de febrero de 2002) – Nombre en código Merlin . Esta se convirtió en la primera versión de la plataforma Java desarrollada bajo el Java Community Process como JSR 59. [57] Los cambios principales incluyeron expresiones regulares modeladas a partir de Perl , encadenamiento de excepciones , un analizador XML integrado y un procesador XSLT ( JAXP ) y Java Web Start .

J2SE 5.0 (30 de septiembre de 2004) – Nombre en clave Tiger . Originalmente se numeró 1.5, que todavía se usa como el número de versión interna. [58] Desarrollado bajo JSR 176, Tiger agregó varias características nuevas e importantes del lenguaje, incluyendo el bucle for-each , los genéricos , el autoboxing y los argumentos var . [59]

Java SE 6 (11 de diciembre de 2006) – Nombre en clave Mustang . Se incluía con un gestor de bases de datos y facilitaba el uso de lenguajes de scripting con la JVM (como JavaScript usando el motor Rhino de Mozilla ). A partir de esta versión, Sun reemplazó el nombre "J2SE" con Java SE y eliminó el ".0" del número de versión. [60] Otros cambios importantes incluyen soporte para anotaciones conectables ( JSR 269 ), muchas mejoras de la GUI , incluidas mejoras de la IU nativa para admitir la apariencia de Windows Vista y mejoras en la arquitectura del depurador de la plataforma Java (JPDA) y la interfaz de herramientas JVM para una mejor supervisión y resolución de problemas.

Java SE 7 (28 de julio de 2011) – Nombre en clave Dolphin . Esta versión se desarrolló bajo JSR 336. [61] Añadió muchos cambios pequeños en el lenguaje, incluyendo cadenas en switch, try-with-resources e inferencia de tipos para la creación de instancias genéricas. La JVM se amplió con soporte para lenguajes dinámicos, mientras que la biblioteca de clases se amplió, entre otros, con un marco de unión/bifurcación, [62] una nueva biblioteca de E/S de archivos mejorada y soporte para nuevos protocolos de red como SCTP . La actualización 76 de Java 7 se publicó en enero de 2015, con fecha de vencimiento el 14 de abril de 2015. [63]

En junio de 2016, después de la última actualización pública de Java 7, [64] se anunciaron errores de seguridad " explotables de forma remota " en Java 6, 7 y 8. [16]

Java SE 8 (18 de marzo de 2014) – Nombre en clave Kenai . Los cambios notables incluyen soporte a nivel de lenguaje para expresiones lambda ( closures ) y métodos predeterminados, el entorno de ejecución de JavaScript Project Nashorn, una nueva API de fecha y hora inspirada en Joda Time y la eliminación de PermGen. Esta versión no es compatible oficialmente con la plataforma Windows XP , [65] pero se sabe que funciona allí. Por lo tanto, debido al final del ciclo de vida de Java 7, es la versión recomendada para los usuarios de XP. Anteriormente, solo se había descrito un método de instalación manual no oficial para Windows XP SP3. Se refiere a JDK8, la plataforma de desarrollo para Java que también incluye un entorno de ejecución de Java en pleno funcionamiento . [66] Java 8 es compatible con Windows Server 2008 R2 SP1, Windows Vista SP2 y Windows 7 SP1, Ubuntu 12.04 LTS y superiores (y algunos otros sistemas operativos). [67]

Java SE 9 y 10 tienen requisitos de sistema más altos, es decir, Windows 7 o Server 2012 (y el navegador web mínimo certificado se aumenta a Internet Explorer 11 u otros navegadores web), y Oracle abandonó la compatibilidad de 32 bits para todas las plataformas, es decir, solo las " máquinas virtuales Java (JVM) de 64 bits de Oracle están certificadas". [68]

Java SE 11 LTS se lanzó en septiembre de 2018, la primera versión LTS desde que se adoptó el modelo de lanzamiento rápido a partir de la versión 9. Por primera vez, OpenJDK 11 representa el código fuente completo para la plataforma Java bajo la Licencia Pública General GNU, y si bien Oracle aún lo licencia de manera dual con una licencia propietaria opcional, no hay diferencias de código ni módulos exclusivos de la versión con licencia propietaria. [69] Las características de Java 11 incluyen dos nuevas implementaciones de recolector de basura, Flight Recorder para depurar problemas profundos, un nuevo cliente HTTP que incluye soporte para WebSocket . [70]

Java SE 12 se lanzó en marzo de 2019. [71]

Java SE 13 se lanzó en septiembre de 2019. [72]

Java SE 14 se lanzó en marzo de 2020. [73]

Java SE 15 se lanzó en septiembre de 2020.

Java SE 16 se lanzó en marzo de 2021.

Java SE 17 LTS se lanzó en septiembre de 2021.

Java SE 18 se lanzó en marzo de 2022.

Java SE 19 se lanzó en septiembre de 2022.

Java SE 20 se lanzó en marzo de 2023.

Java SE 21 LTS se lanzó en septiembre de 2023.

Java SE 22 se lanzó en marzo de 2024.

Además de los cambios en el lenguaje, a lo largo de los años se han realizado cambios significativos en la biblioteca de clases de Java, que ha crecido desde unos pocos cientos de clases en JDK 1.0 a más de tres mil en J2SE 5.0. Se han desarrollado API completamente nuevas, como Swing y Java 2D , y muchas de las clases y métodos originales de JDK 1.0 han quedado obsoletos (algunos de ellos "terminalmente obsoletos"), por ejemplo, relacionados con la finalización. [74]

Al menos una API muy poco utilizada (para subprocesos) se ha eliminado de Java 22. [75] [76]

Uso

Uso de escritorio

Un programa Java que se ejecuta en una computadora de escritorio con Windows Vista (compatible con Java 8, pero no oficialmente con versiones posteriores, como Java 11)

Java actual es compatible con Windows 10 de 64 bits (y Server 2016) y versiones posteriores, macOS 13.x de 64 bits y versiones posteriores, y Linux de 64 bits (por ejemplo, Oracle Enterprise Linux). Oracle no admite otros (para compilación, pero es posible que IBM, SAP, etc.) aunque se sabe que funcionan, por ejemplo, AIX, Ubuntu, RHEL y Alphine/ musl . La compatibilidad con Windows de 32 bits está obsoleta desde Java 22 (y la JVM de 32 bits ya no compila sin opciones que no sean las predeterminadas).

Según Oracle, en 2010, el Java Runtime Environment se encontró en más de 850 millones de PC. [77] Microsoft no ha incluido un Java Runtime Environment (JRE) con sus sistemas operativos desde que Sun Microsystems demandó a Microsoft por agregar clases específicas de Windows al entorno de ejecución de Java incluido y por hacer que las nuevas clases estén disponibles a través de Visual J++ . [ cita requerida ] Apple ya no incluye un entorno de ejecución de Java con OS X a partir de la versión 10.7 , pero el sistema solicita al usuario que lo descargue e instale la primera vez que se inicia una aplicación que requiere el JRE. [ cita requerida ] Muchas distribuciones de Linux incluyen el entorno de ejecución OpenJDK como la máquina virtual predeterminada, lo que elimina la necesidad de descargar el Oracle JRE propietario. [78]

Algunas aplicaciones Java se utilizan de forma bastante generalizada en los escritorios, incluidos los entornos de desarrollo integrados NetBeans y Eclipse , y los clientes de uso compartido de archivos como LimeWire y Vuze . Java también se utiliza en el entorno de programación matemática MATLAB , tanto para representar la interfaz de usuario como parte del sistema central. Java proporciona una interfaz de usuario multiplataforma para algunas aplicaciones colaborativas de alta gama, como Lotus Notes .

Oracle planea primero descontinuar el complemento de navegador Java que se puede instalar por separado desde Java Runtime Environment en JDK 9 y luego eliminarlo por completo de una versión futura, lo que obligará a los desarrolladores web a usar una tecnología alternativa. [79]

Mascota

El viejo y sencillo duque

Duke es la mascota de Java . [80]

Cuando Sun anunció que Java SE y Java ME se lanzarían bajo una licencia de software libre (la Licencia Pública General GNU ), lanzaron los gráficos de Duke bajo la licencia BSD libre al mismo tiempo. [81] Se crea una nueva personalidad de Duke cada año. [82] Por ejemplo, en julio de 2011, "Future Tech Duke" incluyó una nariz más grande, un jetpack y alas azules. [83]

Licencias

El código fuente de las implementaciones de Java de Sun (es decir, la implementación de referencia de facto) ha estado disponible durante algún tiempo, pero hasta hace poco, [84] los términos de la licencia restringían severamente lo que se podía hacer con él sin firmar (y generalmente pagar) un contrato con Sun. Por lo tanto, estos términos no satisfacían los requisitos de la Iniciativa de Código Abierto ni de la Free Software Foundation para ser considerados software libre o de código abierto, y por lo tanto, Sun Java era una plataforma propietaria. [85]

Aunque varios proyectos de terceros (por ejemplo, GNU Classpath y Apache Harmony ) crearon implementaciones parciales de Java en software libre , el gran tamaño de las bibliotecas de Sun combinado con el uso de métodos de sala limpia significó que sus implementaciones de las bibliotecas de Java (el compilador y la máquina virtual son comparativamente pequeños y están bien definidos) eran incompletas y no totalmente compatibles. Estas implementaciones también tendían a estar mucho menos optimizadas que las de Sun. [ cita requerida ]

Software libre

Jonathan I. Schwartz

Sun anunció en JavaOne 2006 que Java se convertiría en software libre y de código abierto , [86] y el 25 de octubre de 2006, en la conferencia Oracle OpenWorld, Jonathan I. Schwartz dijo que la compañía estaba preparada para anunciar el lanzamiento de la plataforma Java central como software libre y de código abierto dentro de 30 a 60 días. [87]

Sun lanzó la máquina virtual Java HotSpot y el compilador como software libre bajo la Licencia Pública General GNU el 13 de noviembre de 2006, con la promesa de que el resto del JDK (que incluye el JRE) se colocaría bajo la GPL en marzo de 2007 ("excepto unos pocos componentes que Sun no tiene derecho a publicar en forma de código fuente distribuible bajo la GPL"). [88] Según Richard Stallman , esto significaría el fin de la "trampa de Java". [89] Mark Shuttleworth calificó el anuncio de prensa inicial como "un verdadero hito para la comunidad del software libre ". [90]

Sun publicó el código fuente de la biblioteca Class bajo GPL el 8 de mayo de 2007, excepto algunas partes limitadas que fueron licenciadas por Sun de terceros que no querían que su código se publicara bajo una licencia de software libre y de código abierto. [91] Algunas de las partes gravadas resultaron ser partes bastante clave de la plataforma, como la representación de fuentes y la rasterización 2D, pero Sun las publicó como código abierto más tarde (consulte la biblioteca de clases OpenJDK ).

El objetivo de Sun era reemplazar las partes que siguen siendo propietarias y de código cerrado con implementaciones alternativas y hacer que la biblioteca de clases sea completamente libre y de código abierto. Mientras tanto, un proyecto de terceros llamado IcedTea creó un JDK completamente libre y altamente utilizable al reemplazar el código sobrecargado con fragmentos o código de GNU Classpath . Sin embargo, OpenJDK se ha vuelto desde entonces compilable sin las partes sobrecargadas (desde OpenJDK 6 b10 [92] ) y se ha convertido en el entorno de ejecución predeterminado para la mayoría de las distribuciones de Linux. [93] [94] [95] [96]

En junio de 2008, se anunció que IcedTea 6 (como la versión empaquetada de OpenJDK en Fedora 9 ) había pasado las pruebas del Technology Compatibility Kit y puede afirmar que es una implementación de Java 6 totalmente compatible. [97]

Dado que OpenJDK está bajo la licencia GPL, es posible redistribuir una versión personalizada del JRE directamente con aplicaciones de software, [98] [99] en lugar de requerir que el usuario final (o su administrador de sistemas) descargue e instale la versión correcta del Oracle JRE propietario en cada uno de sus sistemas.

Crítica

En la mayoría de los casos, el soporte de Java no es necesario en los navegadores web, y los expertos en seguridad recomiendan que no se ejecute en un navegador a menos que sea absolutamente necesario. [100] Se sugirió [ ¿quién? ] que, si algunos sitios web requieren Java, los usuarios deberían tener una instalación de navegador separada específicamente para esos sitios. [ cita requerida ]

Genéricos

Cuando se añadieron los genéricos a Java 5.0, ya existía un amplio marco de clases (muchas de las cuales ya estaban en desuso ), por lo que se optó por implementar los genéricos mediante el borrado para permitir la compatibilidad con la migración y la reutilización de estas clases existentes. Esto limitó las características que se podían proporcionar con esta adición en comparación con otros lenguajes. [101] [102] La adición de comodines de tipo hizo que Java fuera poco sólido. [103]

Tipos enteros sin signo

Java carece de tipos de enteros sin signo nativos . Los datos sin signo se generan a menudo a partir de programas escritos en C y la falta de estos tipos impide el intercambio directo de datos entre C y Java. Los números grandes sin signo también se utilizan en muchos campos de procesamiento numérico, incluida la criptografía, lo que puede hacer que Java sea menos conveniente para estas tareas. [104] Aunque es posible evitar parcialmente este problema con el código de conversión y el uso de tipos de datos más grandes, hace que el uso de Java sea engorroso para manejar los datos sin signo. Si bien un entero con signo de 32 bits se puede utilizar para almacenar un valor sin signo de 16 bits con relativa facilidad, un valor sin signo de 32 bits requeriría un entero con signo de 64 bits. Además, un valor sin signo de 64 bits no se puede almacenar utilizando ningún tipo de entero en Java porque no existe ningún tipo mayor de 64 bits en el lenguaje Java. Si se abstraen mediante funciones, las llamadas a funciones se vuelven necesarias para muchas operaciones que son nativas de algunos otros lenguajes. Como alternativa, es posible utilizar los enteros con signo de Java para emular enteros sin signo del mismo tamaño, pero esto requiere un conocimiento detallado de operaciones complejas bit a bit. [105]

Aritmética de punto flotante

Si bien la aritmética de punto flotante de Java se basa en gran medida en el estándar IEEE 754 ( estándar para aritmética de punto flotante binario ), ciertas características no son compatibles incluso cuando se utiliza el strictfpmodificador, como los indicadores de excepción y los redondeos dirigidos, capacidades exigidas por el estándar IEEE 754. Además, los tipos de punto flotante de precisión extendida permitidos en 754 y presentes en muchos procesadores no están permitidos en Java. [106] [107]

Actuación

En los primeros días de Java (antes de que se implementara HotSpot VM en Java 1.3 en 2000) hubo algunas críticas sobre el rendimiento. Los benchmarks generalmente informaban que Java era aproximadamente un 50% más lento que C (un lenguaje que se compila en código nativo). [108] [109] [110]

El rendimiento de Java ha mejorado sustancialmente desde las primeras versiones. [26] En algunas pruebas optimizadas, se ha demostrado que el rendimiento de los compiladores JIT en relación con los compiladores nativos es bastante similar. [26] [27] [28]

El bytecode de Java puede ser interpretado en tiempo de ejecución por una máquina virtual, o puede ser compilado en tiempo de carga o tiempo de ejecución en código nativo que se ejecuta directamente en el hardware de la computadora. La interpretación es más lenta que la ejecución nativa, y la compilación en tiempo de carga o tiempo de ejecución tiene una penalización de rendimiento inicial para la compilación. Todas las implementaciones de JVM de alto rendimiento modernas utilizan el enfoque de compilación, por lo que después del tiempo de inicio inicial, el rendimiento es equivalente al código nativo.

Seguridad

La plataforma Java ofrece una arquitectura de seguridad [111] diseñada para permitir que el usuario ejecute código de bytes no confiable en un entorno protegido contra software malicioso o mal escrito. Esta función de "entorno protegido" tiene como objetivo proteger al usuario al restringir el acceso a ciertas funciones y API de la plataforma que podrían ser explotadas por malware , como el acceso al sistema de archivos local, la ejecución de comandos arbitrarios o el acceso a redes de comunicación.

En los últimos años, los investigadores han descubierto numerosos fallos de seguridad en algunas implementaciones de Java ampliamente utilizadas, incluida la de Oracle, que permiten que un código no confiable eluda el mecanismo de sandbox, exponiendo a los usuarios a ataques maliciosos. Estos fallos afectan solo a las aplicaciones Java que ejecutan bytecode arbitrario no confiable, como los complementos de navegadores web que ejecutan applets de Java descargados de sitios web públicos. Las aplicaciones en las que el usuario confía y tiene control total sobre todo el código que se está ejecutando no se ven afectadas.

El 31 de agosto de 2012, se descubrió que Java 6 y 7 (ambos con soporte en ese entonces) en Microsoft Windows, OS X y Linux tenían una falla de seguridad grave que permitía que se realizara una explotación remota simplemente cargando una página web maliciosa. [112] Más tarde se descubrió que Java 5 también tenía fallas. [113]

El 10 de enero de 2013, tres especialistas en informática se manifestaron en contra de Java, diciendo a Reuters que no era seguro y que la gente debería desactivar Java. Jaime Blasco, director de laboratorios de AlienVault Labs, afirmó que "Java es un desastre. No es seguro. Hay que desactivarlo". [114] Esta vulnerabilidad afecta a Java 7 y no está claro si afecta a Java 6 , por lo que se sugiere que los consumidores lo desactiven. [115] [116] Las alertas de seguridad de Oracle anuncian calendarios de parches críticos relacionados con la seguridad de Java. [117]

El 14 de enero de 2013, los expertos en seguridad dijeron que la actualización aún no protegía a las PC de los ataques. [118] Este agujero de explotación provocó una respuesta del Departamento de Seguridad Nacional de los Estados Unidos alentando a los usuarios a deshabilitar o desinstalar Java. [17] Apple incluyó a Java en la lista negra de forma limitada para todas las computadoras que ejecutan su sistema operativo OS X a través de un programa de protección antivirus. [119]

En 2014, y en respuesta a los problemas de seguridad y vulnerabilidad de Java que surgieron recientemente, el blogger de seguridad Brian Krebs pidió a los usuarios que eliminaran al menos el complemento de Java para el navegador y también todo el software. "Espero que haya un mundo sin el complemento de Java (y no tener que recordarles a los lectores las actualizaciones trimestrales de parches), pero probablemente pasarán años antes de que las diversas versiones de este complemento se eliminen de los sistemas de los usuarios finales en todo el mundo". [120] "Aunque alguna vez fue prometedor, ha dejado de ser útil en el navegador y se ha convertido en una pesadilla que deleita a los cibercriminales a expensas de los usuarios de computadoras". [121] "Creo que todos deberían desinstalar Java de todos sus PC y Mac, y luego pensar detenidamente si necesitan volver a agregarlo. Si usted es un usuario doméstico típico, probablemente pueda prescindir de él. Si es un usuario comercial, es posible que no tenga otra opción". [122]

Programas publicitarios

El entorno de ejecución Java distribuido por Oracle tiene un historial de incluir software patrocinado que se instala de forma predeterminada durante la instalación y durante las actualizaciones que se lanzan aproximadamente cada mes. Esto incluye la " barra de herramientas Ask.com " que redirigirá las búsquedas del navegador a anuncios y "McAfee Security Scan Plus". [123] Estas ofertas se pueden bloquear mediante una configuración en el Panel de control de Java, aunque esto no es obvio. Esta configuración se encuentra en la pestaña "Avanzado" del Panel de control de Java, bajo el encabezado "Varios", donde la opción está etiquetada como una opción para suprimir las "ofertas de patrocinadores".

Actualizar sistema

Java aún no ha lanzado un actualizador automático que no requiera la intervención del usuario ni derechos administrativos [124], a diferencia de Google Chrome [125] y Flash Player. [126]

Véase también

Referencias

  1. ^ "JavaSoft lanza Java 1.0" (Nota de prensa). Archivado desde el original el 5 de febrero de 2008 . Consultado el 9 de febrero de 2016 .
  2. ^ Ortíz, C. Enrique; Giguère, Éric (2001). Perfil de dispositivo de información móvil para Java 2 Micro Edition: Guía del desarrollador (PDF) . John Wiley e hijos . ISBN  978-0471034650. Recuperado el 30 de mayo de 2012 .
  3. ^ "Notas de la versión de Java™ SE Development Kit 23, 23.0.1". Oracle Corporation . Consultado el 16 de octubre de 2024 .
  4. ^ "Notas de la versión de Java™ SE Development Kit 21, 21.0.5". Oracle Corporation . Consultado el 16 de octubre de 2024 .
  5. ^ "Notas de la versión de Java™ SE Development Kit 17, 17.0.13". Oracle Corporation . Consultado el 16 de octubre de 2024 .
  6. ^ "Notas de la versión de Java™ SE Development Kit 11, 11.0.25". Oracle Corporation . Consultado el 16 de octubre de 2024 .
  7. ^ "Notas de la versión de Java™ SE Development Kit 8, Update 431". Oracle Corporation . Consultado el 16 de octubre de 2024 .
  8. ^ "Grupo HotSpot". Openjdk.java.net . Consultado el 9 de febrero de 2016 .
  9. ^ ab "Contenido de las configuraciones de sistemas certificados de Oracle JDK 8 y JRE 8". Oracle.com . 8 de abril de 2014 . Consultado el 9 de febrero de 2016 .
  10. ^ "Configuraciones regionales compatibles con Java SE 7". Oracle.com . Consultado el 9 de febrero de 2016 .
  11. ^ "OpenJDK: GPLv2 + Classpath Exception". Openjdk.java.net. 1 de abril de 1989. Consultado el 9 de febrero de 2016 .
  12. ^ "BCL para Java SE". Oracle.com. 2 de abril de 2013. Consultado el 9 de febrero de 2016 .
  13. ^ Naughton, Patrick. "Java fue fuertemente influenciado por Objective-C". Escuela Virtual . Archivado desde el original el 13 de agosto de 2012.
  14. ^ "¿Por qué debería desinstalar versiones anteriores de Java de mi sistema?". www.java.com . Archivado desde el original el 12 de febrero de 2018. Consultado el 6 de febrero de 2018 .
  15. ^ "¿Por qué debería desinstalar versiones anteriores de Java de mi sistema?". Oracle . Consultado el 9 de septiembre de 2016 .
  16. ^ ab "Actualización del parche crítico de Oracle: julio de 2016". www.oracle.com .
  17. ^ ab Whittaker, Zack (11 de enero de 2013). "Seguridad Nacional advierte que se debe desactivar Java en medio de una falla de día cero". ZDNet . Consultado el 9 de febrero de 2016 .
  18. ^ Alexander, Christopher. "Java SE 6 Advanced". www.oracle.com . Consultado el 20 de mayo de 2018 .
  19. ^ "Descripción general de Java SE". Oracle Corporation . Consultado el 26 de febrero de 2017 .
  20. ^ "Contenido de la versión Java SE 6". Oracle Corporation y/o sus filiales . Consultado el 1 de enero de 2013 .
  21. ^ Pasando a OpenJDK como la implementación de referencia oficial de Java SE 7
  22. ^ Implementaciones de referencia de la plataforma Java, edición estándar 7
  23. ^ "Implementaciones de referencia de la plataforma Java, edición estándar 8". Archivado desde el original el 21 de noviembre de 2015.
  24. ^ "Diferencias entre Java EE y Java SE - Your First Cup: An Introduction to the Java EE Platform". Docs.oracle.com. 1 de abril de 2012. Consultado el 18 de julio de 2012 .
  25. ^ "Descripción general de Java EE". Oracle Corporation . Consultado el 26 de febrero de 2017 .
  26. ^ abc Lewis, JP; Neumann, Ulrich. "Rendimiento de Java frente a C++". Laboratorio de Tecnología Inmersiva y Gráfica, Universidad del Sur de California .
  27. ^ ab "El punto de referencia de Java más rápido que C++". Kano.net. 14 de noviembre de 2003. Consultado el 9 de febrero de 2016 .
  28. ^ ab FreeTTS – Un estudio de caso de rendimiento Archivado el 25 de marzo de 2009 en Wayback Machine , Willie Walker, Paul Lamere, Philip Kwok
  29. ^ "Preguntas frecuentes sobre OpenJDK". OpenJDK . Archivado desde el original el 7 de diciembre de 2021 . Consultado el 23 de octubre de 2021 .
  30. ^ "BCL para Java SE". Archivado desde el original el 14 de agosto de 2022 . Consultado el 14 de agosto de 2022 .
  31. ^ "Explicación de las versiones de CPU y PSU de Java". Archivado desde el original el 3 de noviembre de 2014.
  32. ^ "Copia archivada". Archivado desde el original el 14 de agosto de 2022 . Consultado el 14 de agosto de 2022 .{{cite web}}: CS1 maint: copia archivada como título ( enlace )
  33. ^ "Copia archivada". Archivado desde el original el 10 de agosto de 2022 . Consultado el 14 de agosto de 2022 .{{cite web}}: CS1 maint: copia archivada como título ( enlace )
  34. ^ "Comprensión de los módulos de Java 9". Archivado desde el original el 14 de agosto de 2022 . Consultado el 14 de agosto de 2022 .
  35. ^ "Módulos Java".
  36. ^ "Cambios estructurales de Java 9 en el JDK y JRE". 30 de octubre de 2017.
  37. ^ "Desarrollador de IBM".
  38. ^ "Guía sobre la modularidad de Java 9 | Baeldung". 18 de abril de 2018.
  39. ^ "Capítulo 1. Introducción". docs.oracle.com .
  40. ^ www.beanshell.org
  41. ^ "Preguntas frecuentes sobre la recolección de basura en la máquina virtual de Java de Hotspot". Sun Microsystems . 6 de febrero de 2003 . Consultado el 7 de febrero de 2009 .
  42. ^ ab Masamitsu, Jon (28 de noviembre de 2006). «Presentando a la Generación Permanente». Archivado desde el original el 25 de agosto de 2016. Consultado el 7 de febrero de 2009 .
  43. ^ Nutter, Charles (11 de septiembre de 2008). "A First Taste of InvokeDynamic" (Una primera muestra de InvokeDynamic) . Consultado el 7 de febrero de 2009 .
  44. ^ "JEP 122: Eliminar la generación permanente". Oracle Corporation . 4 de diciembre de 2012 . Consultado el 23 de marzo de 2014 .
  45. ^ "¿Qué es Java? ¿Es inseguro y debería usarlo?". Lifehacker.com. 14 de enero de 2013. Consultado el 26 de junio de 2015 .
  46. ^ "¿Existe alguna protección contra los exploits de Java? | Kaspersky Lab". Kaspersky.com. 9 de septiembre de 2013. Archivado desde el original el 4 de abril de 2015. Consultado el 26 de junio de 2015 .
  47. ^ Southwick, Karen (1999). High Noon: la historia interna de Scott McNealy y el ascenso de Sun Microsystems . Nueva York [ua]: Wiley. págs. 120–122. ISBN 0471297135.
  48. ^ ab Byous, Jon (abril de 2003). «Tecnología Java: los primeros años». Sun Microsystems . Archivado desde el original el 30 de mayo de 2008. Consultado el 2 de agosto de 2009 .
  49. ^ Southwick, Karen (1999). High Noon: la historia interna de Scott McNealy y el ascenso de Sun Microsystems . Nueva York [ua]: Wiley. p. 124. ISBN 0471297135.
  50. ^ Walrath, Kathy (21 de diciembre de 2001). «Prólogo». Sun Microsystems . Consultado el 2 de agosto de 2009 .
  51. ^ Murphy, Kieron (4 de octubre de 1996). "Entonces, ¿por qué decidieron llamarlo Java?". JavaWorld . Consultado el 15 de julio de 2020 ."Los abogados nos habían dicho que no podíamos utilizar el nombre "OAK" porque [ya era una marca registrada de] Oak Technologies", dijo Frank Yellin, un ingeniero senior de Sun. "Por eso se llevó a cabo una sesión de intercambio de ideas para encontrar ideas para un nuevo nombre".
  52. ^ Bank, David (1 de diciembre de 1995). "The Java Saga". Wired . Consultado el 4 de octubre de 2022 ."El precio es inferior al de nuestro coste", afirma Schmidt. "Esto supone una pérdida de dinero en el negocio de las licencias en el futuro previsible. Es una inversión estratégica en cuota de mercado".
  53. ^ "Sun Microsystems anuncia la creación de JavaSoft" (Nota de prensa). Sun Microsystems. 9 de enero de 1996. Archivado desde el original el 10 de febrero de 2008.
  54. ^ "Sun abre Java". Sun Microsystems. 13 de noviembre de 2006. Archivado desde el original el 13 de mayo de 2008.
  55. ^ O'Hair, Kelly (diciembre de 2010). "Se eliminó la lógica de los complementos binarios de OpenJDK7 y OpenJDK6". Oracle Corporation . Consultado el 25 de noviembre de 2011 .
  56. ^ "Programa Java Community Process(SM) - JSRs: Java Specification Requests - detail JSR# 63" (El programa Java Community Process(SM) - JSR: solicitudes de especificación de Java - detalle JSR n.° 63). Jcp.org . Consultado el 9 de febrero de 2016 .
  57. ^ "Programa Java Community Process(SM) - JSRs: Java Specification Requests - detail JSR# 59" (El programa Java Community Process(SM) - JSR: solicitudes de especificación de Java - detalle JSR n.° 59). Jcp.org . Consultado el 9 de febrero de 2016 .
  58. ^ "¿Versión 1.5.0 o 5.0?". Java.sun.com . Consultado el 9 de febrero de 2016 .
  59. ^ "Programa Java Community Process(SM) - JSRs: Java Specification Requests - detail JSR# 176" (El programa Java Community Process(SM) - JSR: solicitudes de especificación de Java - detalle JSR n.° 176). Jcp.org . Consultado el 9 de febrero de 2016 .
  60. ^ "Java Naming". Java.com . Oracle . Consultado el 25 de agosto de 2011 .
  61. ^ "Programa Java Community Process(SM) - JSRs: Java Specification Requests - detail JSR# 336" (El programa Java Community Process(SM) - JSR: solicitudes de especificación de Java - detalle JSR# 336). Jcp.org . Consultado el 9 de febrero de 2016 .
  62. ^ Lea, Doug (13 de septiembre de 2004). "JSRs: Java Specification Requests: JSR 166: Concurrency Utilities". Proceso de la comunidad Java . Oracle Corp.
  63. ^ "Notas de la versión de Java™ SE Development Kit 7 Update 76". Oracle.com . Consultado el 9 de febrero de 2016 .
  64. ^ "Lanzamientos de Java 7 y Java 8 por fecha". www.java.com .
  65. ^ "Windows XP y Java". Java.com. 8 de abril de 2014. Consultado el 9 de febrero de 2016 .
  66. ^ "java - instalación de JDK8 en Windows XP - error advapi32.dll". Desbordamiento de pila .
  67. ^ "Configuraciones de sistemas certificadas para Oracle JDK 8 y JRE 8". www.oracle.com .
  68. ^ "Configuraciones de sistemas certificados de Oracle JDK 10". www.oracle.com . Consultado el 27 de marzo de 2018. Solo se admite el modo X.org. El modo Wayland no es compatible.
  69. ^ "Hoja de ruta de soporte de Oracle Java SE". Oracle Corporation . 25 de septiembre de 2018 . Consultado el 25 de septiembre de 2018 .
  70. ^ "JDK 11". Oracle Corporation . 25 de septiembre de 2018 . Consultado el 26 de septiembre de 2018 .
  71. ^ "JDK 12". OpenJDK . Consultado el 22 de marzo de 2019 .
  72. ^ "JDK 13". OpenJDK . Consultado el 17 de septiembre de 2019 .
  73. ^ "JDK 14". OpenJDK . Consultado el 25 de marzo de 2020 .
  74. ^ "Lista de elementos obsoletos (Java SE 22)". cr.openjdk.org . Consultado el 16 de abril de 2024 .
  75. ^ "Eliminar Thread.countStackFrames". bugs.openjdk.org . Consultado el 16 de abril de 2024 .
  76. ^ "Java SE 22 (JSR 397)". cr.openjdk.org . Consultado el 16 de abril de 2024 .
  77. ^ "¿Qué es la tecnología Java y por qué la necesito?". Archivado desde el original el 25 de septiembre de 2010. Consultado el 15 de diciembre de 2011. Java se ejecuta en más de 850 millones de computadoras personales en todo el mundo y en miles de millones de dispositivos en todo el mundo, incluidos dispositivos móviles y de televisión.
  78. ^ "Java - Wiki del proyecto Fedora". fedoraproject.org .
  79. ^ Tema, Dalibor (27 de enero de 2016). "Pasando a una web sin complementos". Oracle.
  80. ^ "Duke, la mascota de Java". Oracle . Consultado el 18 de marzo de 2019 .
  81. ^ "duke: Project Home Page". Sun Microsystems . Archivado desde el original el 18 de junio de 2007. Consultado el 18 de marzo de 2007 .
  82. ^ "Duke, la mascota de Java".
  83. ^ "Future Tech Duke (The Java Source)". Tori Wieldt. Archivado desde el original el 20 de agosto de 2011. Consultado el 17 de agosto de 2011 .
  84. ^ Smith, Donald (11 de septiembre de 2018). "Versiones de Oracle JDK para Java 11 y versiones posteriores".
  85. ^ Stallman, Richard (24 de mayo de 2006). "El curioso incidente del sol en la noche". Groklaw .
  86. ^ Schwartz, Jonathan. "?". Blog de Jonathan Schwartz . Sun Microsystems. Archivado desde el original el 15 de julio de 2006.
  87. ^ "Oracle OpenWorld: UnBreakable Linux / 5015.2 no está en el horizonte | Blog de Formtek". Formtek.com. 26 de octubre de 2006. Consultado el 9 de febrero de 2016 .
  88. ^ "Oracle y Sun Microsystems | Adquisiciones estratégicas | Oracle". Sun.com . Consultado el 9 de febrero de 2016 .
  89. ^ "Libre pero encadenado – La trampa de Java – Proyecto GNU – Free Software Foundation". Gnu.org. 12 de abril de 2004. Consultado el 9 de febrero de 2016 .
  90. ^ "Sun 'libera' Java al mundo". BBC News . 13 de noviembre de 2006 . Consultado el 6 de mayo de 2010 .
  91. ^ "¡Open JDK ya está aquí!". Sun Microsystems. 8 de mayo de 2007. Consultado el 9 de mayo de 2007 .
  92. ^ Wielaard, Mark (30 de mayo de 2007). "OpenJDK6 b10 source posted" (Publicado el código fuente de OpenJDK6 b10) . Consultado el 12 de julio de 2008 .
  93. ^ "Java de Red Hat".
  94. ^ "Java de Fedora".
  95. ^ "Java Debian".
  96. ^ "Ubuntu Java".
  97. ^ Sharples, Rich (19 de junio de 2008). "Java es finalmente libre y abierto". Archivado desde el original el 20 de junio de 2008.
  98. ^ libgdx (9 de diciembre de 2013). "Bundling a jre · libgdx/libgdx Wiki · GitHub". Github.com . Consultado el 9 de febrero de 2016 .
  99. ^ "Pregunta sobre la inclusión de paquetes de OpenJDK personalizados". Java-Gaming.org. Archivado desde el original el 4 de marzo de 2016. Consultado el 9 de febrero de 2016 .
  100. ^ Cluley, Graham (15 de enero de 2013). ""A menos que sea absolutamente necesario ejecutar Java en navegadores web, deshabilítelo", dice el equipo CERT patrocinado por el DHS – Naked Security". Nakedsecurity.sophos.com . Consultado el 9 de febrero de 2016 .
  101. ^ "Generics in Java". Object Computing, Inc. Archivado desde el original el 2 de enero de 2007. Consultado el 9 de diciembre de 2006 .
  102. ^ "What's Wrong With Java: Type Erasure". 6 de diciembre de 2006. Archivado desde el original el 22 de julio de 2012. Consultado el 9 de diciembre de 2006 .
  103. ^ "Los sistemas de tipos de Java y Scala son incorrectos" (PDF) .
  104. ^ "Las bibliotecas de Java deberían proporcionar compatibilidad con la aritmética de enteros sin signo". Base de datos de errores, Sun Developer Network . Oracle . Consultado el 18 de enero de 2011 .
  105. ^ Owens, Sean R. (5 de noviembre de 2009). "Java y unsigned int, unsigned short, unsigned byte, unsigned long, etc. (o más bien, la falta de ellos)". darksleep.com . Consultado el 9 de octubre de 2010 .
  106. ^ Kahan, W.; Darcy, Joseph D. (1 de marzo de 1998). "Cómo el punto flotante de Java perjudica a todos en todas partes" (PDF) . Consultado el 9 de diciembre de 2006 .
  107. ^ "Tipos, valores y variables". Sun Microsystems . Consultado el 9 de diciembre de 2006 .
  108. ^ "¿Cuáles son los lenguajes de programación más rápidos?". Juego de referencias de lenguajes informáticos . Archivado desde el original el 14 de agosto de 2011.
  109. ^ "velocidad ÷ velocidad de C++ GNU g++". Juego de puntos de referencia de lenguajes informáticos . Archivado desde el original el 26 de septiembre de 2011.
  110. ^ "Rendimiento de C++ vs Java; ¡empate! | Blog de Christian Felde". Blog.cfelde.com. 27 de junio de 2010. Consultado el 9 de febrero de 2016 .
  111. ^ "Arquitectura de seguridad de Java: contenido". Docs.oracle.com. 2 de octubre de 1998. Consultado el 9 de febrero de 2016 .
  112. ^ Horowitz, Michael (31 de agosto de 2012). «Fallos de seguridad en Java: bla, bla, bla | Computerworld». Blogs.computerworld.com. Archivado desde el original el 24 de julio de 2014. Consultado el 9 de febrero de 2016 .
  113. ^ Brook, Chris. "La primera parada para las noticias de seguridad". Threatpost. Archivado desde el original el 8 de marzo de 2013. Consultado el 9 de febrero de 2016 .
  114. ^ "Por qué y cómo deshabilitar Java en su computadora ahora - Tecnología y ciencia - Innovación". NBC News. 12 de enero de 2013. Archivado desde el original el 21 de febrero de 2014. Consultado el 9 de febrero de 2016 .
  115. ^ "El Departamento de Seguridad Nacional de Estados Unidos pide a los usuarios de computadoras que desactiven Java". Forbes.com . Consultado el 9 de febrero de 2016 .
  116. ^ Brook, Chris. "La primera parada para las noticias de seguridad". Threatpost. Archivado desde el original el 9 de abril de 2013. Consultado el 9 de febrero de 2016 .
  117. ^ "Actualizaciones de parches críticos y alertas de seguridad". Oracle.com . Consultado el 9 de febrero de 2016 .
  118. ^ Finkle, Jim (14 de enero de 2013). "El parche de emergencia para Java no soluciona los problemas de cibercrimen, advierten los expertos". Independent.ie . Consultado el 9 de febrero de 2016 .
  119. ^ Kelly, Meghan (14 de enero de 2013). "Oracle publica una solución para un exploit de Java después de que el DHS advirtiera sobre sus vulnerabilidades". VentureBeat . Consultado el 9 de febrero de 2016 .
  120. ^ Krebs, Brian (16 de febrero de 2016). "Adiós al complemento Java de Oracle". KrebsOnSecurity .
  121. ^ Gonsalves, Antone (5 de septiembre de 2012). "Java ya no es necesario. Desconecta el complemento". ReadWrite . Wearable World.
  122. ^ "Java: ¿debería eliminarse?". The Guardian . 8 de febrero de 2013.
  123. ^ Bott, Ed. "Una mirada detallada a cómo Oracle instala software engañoso con actualizaciones de Java". ZDNet.com . ZDNet . Consultado el 14 de diciembre de 2014 .
  124. ^ "Windows 7: ¿Cómo actualizo Java desde una cuenta que no es de administrador?". Superusuario .
  125. ^ "Actualizar Google Chrome - Computadora - Ayuda de Google Chrome". support.google.com .
  126. ^ "Boletín de seguridad de Adobe". helpx.adobe.com .

Enlaces externos

Escuche este artículo ( 42 minutos )
Icono de Wikipedia hablado
Este archivo de audio se creó a partir de una revisión de este artículo con fecha del 19 de agosto de 2013 y no refleja ediciones posteriores. ( 19-08-2013 )