X-Git-Url: https://git.llucax.com/z.facultad/75.00/informe.git/blobdiff_plain/1c1c1fec4cad2318bd82688f8bdb7ed3ba48ccec..61d1b9d0e3488b1c428b945e5b53fdc36c5ededb:/informe.rst?ds=sidebyside diff --git a/informe.rst b/informe.rst index 416c113..4762710 100644 --- a/informe.rst +++ b/informe.rst @@ -123,13 +123,18 @@ El Lenguaje de Programación D ESTADO: TERMINADO D_ es un lenguaje de programación joven. Nació en 1999 y el 2 de enero -de 2007 salió su `versión 1.0`_. A pesar de alcanzar una versión que podría -suponerse estable, D_ conserva algunas falencias y sigue siendo activamente -desarrollado (incluyendo nuevas características en prácticamente todas la -versiones nuevas, muchas de ellas, además, moviéndose en direcciones muy -experimentales) . Su creador, `Walter Bright`_, desarrollador principal de -Zortech C++, uno de los primeros compilador de C++ que compilaba a código -nativo, dice bien claro como nace el lenguaje, citando en su sitio web: +de 2007 salió su `versión 1.0`_. Poco tiempo después se continúo el +desarrollo del lenguaje en la `versión 2.0`_, aún inestable y en la +cual se está experimentando principalmente sobre *const-correctness* +(ya sea como una forma de programación por contratos como para mejorar +las oportunidades de optimización del compilador, en especial con +código multi-hilo), reflexión y características para soportar mejor +programación funcional (como *clausuras* completas) y programación +genérica. + +Su creador, `Walter Bright`_, desarrollador principal de Zortech C++, +uno de los primeros compilador de C++ que compilaba a código nativo, +dice bien claro como nace el lenguaje, citando en su sitio web: It seems to me that most of the "new" programming languages fall into one of two categories: Those from academia with radical new @@ -138,7 +143,8 @@ nativo, dice bien claro como nace el lenguaje, citando en su sitio web: experience implementing compilers. .. _D: http://www.digitalmars.com/d/ -.. _`versión 1.0`: http://www.digitalmars.com/d/changelog2.html#new1_00 +.. _`versión 1.0`: http://www.digitalmars.com/d/1.0/changelog.html +.. _`versión 2.0`: http://www.digitalmars.com/d/changelog.html .. _`Walter Bright`: http://www.walterbright.com/ Lo que podría traducirse como: @@ -166,7 +172,7 @@ un "C++ mejor", ya que el objetivo del lenguaje es muy similar a C++, pero implementa muchas características que jamás pudieron entrar en el estándar de C++ y lo hace de una forma mucho más limpia, ya que no debe lidiar con problemas de compatibilidad hacia atrás, y cuenta -se con la experiencia del camino recorrido por C++, pudiendo extraer de +con la experiencia del camino recorrido por C++, pudiendo extraer de él los mejores conceptos pero evitando sus mayores problemas también. Una de las características que nunca pudo entrar en el estándar de C++ @@ -182,51 +188,47 @@ Objetivo La recolección de basura en D_ es un problema prácticamente nuevo. Si bien pueden considerarse válidos todos los modelos propuestos para recolección de basura en C, estos son muy restrictivos y poco eficientes, por lo -promiscuo que este lenguaje. - -Por otro lado, la recolección de basura en C y C++ está prácticamente -restringida a implementaciones a nivel de bibliotecas, ya que la inclusión -de un recolector de basura en el estándar de C/C++ es algo que no va a -pasar por largo tiempo. Entonces quedan dos caminos posibles: - -1. Quedarse con las limitaciones de un recolector de basura a nivel de - bibliotecas, lo que es muy restrictivo. -2. Construir una solución a nivel de compilador que no cumpla con el - estándar y que no pasará de ser una curiosidad académica. - -La primera opción está ya bastante desarrollada y es casi un sinónimo de un -recolector de basura conservativo. La segunda, no es un objetivo viable para -una Tesis de Ingeniería, donde se pretende llegar a un resultado lo más -práctico posible (hacer un aporte más ingenieril que científico). - -Por lo tanto el objetivo es abordar la segunda opción sobre un lenguaje que -es propenso a absorver nuevas ideas y cambios. Un lenguaje que es además, -mucho más rico sintáctica y semánticamente, sin perder utilidad práctica ni -eficiencia para cumplir las tareas para las cuales C y C++ fueron -diseñados. - -Se propone entonces en este trabajo, desarrollar un recolector de basura -para un lenguaje de programación imperativo compilado, con tipado estático -y enlazable con C (siendo esto último probablemente uno de los desafíos más -importantes), agregando soporte al lenguaje o al compilador (de ser -necesario) y utlizando las características avanzadas que el lenguaje -provee. +promiscuo que este lenguaje. Por otro lado D_ provee muchas construcciones +de alto nivel, lo que hace que la necesidad de utilizar construcciones de +bajo nivel sea muy escasa, por lo tanto brinda un campo importante a +explorar en cuanto a mejoras para el recolector de basura. + +Por lo tanto el objetivo del presente trabajo puede resumirse en los +siguientes puntos: + +- Investigar y analizar la viabilidad de mejoras al recolector de + basura de D_, tanto mejoras menores dentro de las limitaciones actuales + del lenguaje (incluyendo pero no limitado a mejoras en el algoritmo + actual de recolección y soluciones en *espacio de usuario* -como + biblioteca-), como proponiendo mejoras al lenguaje que permitan la + implementación recolectores más precisos y eficientes. +- Elegir un conjunto de las mejores soluciones halladas e implementarlas. + Las soluciones que necesiten modificaciones en el lenguaje serán + implementadas modificando el compilador libre de D_ GDC_, que + también será utilizado como plataforma principal de desarrollo y + prueba (debido a la disponibilidad completa del código fuente y + la libertad de usarlo y modificarlo libremente). De todas formas, + siempre se priorizarán las modificaciones al *frontend* [#frontend]_ + sobre las modificaciones al *backend*, permitiendo así que las mejoras + puedan ser probadas eventualmente en otros compiladores que utilicen + el *frontend* publicado por DigitalMars_, como DMD_. +- Realizar pruebas sobre aplicaciones lo más variadas y reales posible + sobre todas las soluciones implementadas, de manera de determinar de + forma fehaciente las ventajas de unas y otras en cuanto a latencia, + consumo de memoria, consumo de procesador, tiempos de pausa, etc. +- Presentar las conclusiones obtenidas del análisis y las pruebas + realizadas, tanto en el ámbito académico de la facultad como a la + comunidad de D_ (con el objetivo de sumar lo construido en este trabajo + al lenguaje). + +.. [#frontend] El *frontend* es el módulo del compilador que realiza el + análisis sintáctico y semántico del lenguaje. GDC_ utiliza como + *frontend* el que provee libremente DigitalMars_. +.. [#backend] El *backend* es el módulo del compilador que emite + el código binario (o *assembly*, o el lenguaje que produzca el + compilador como resultado final). GDC utiliza el *backend* del GCC_ + (*GNU Compiler Collection*), uno de los compiladores más populares. -.. INTRODUCCION .............................................................. - -Alcance -------- -.. Alcance de la tesis, qué se pretende hacer - ESTADO: TERMINADO, EN REVISION - -En esta tesis se plantea desarrollar un recolector de basura para el -lenguaje de programación D, utilizando como plataforma el compilador GDC_. -El objetivo es conseguir un recolector de basura eficiente, en tiempo y -espacio, aunque priorizando lo primero. Como objetivo secundario se propone -obtener una recolector configurable, para poder elegir los parámetros que -mejor se ajusten al problema particular. - -.. _GDC: http://dgcc.sourceforge.net/ .. INTRODUCCION ..............................................................