j | |
---|---|
Semántica | funcional |
clase de idioma | lenguaje de programación , lenguaje de programación funcional , lenguaje de programación dinámico , lenguaje de nivel de función [d] , lenguaje de programación vectorial [d] , lenguaje de programación tácito [d] , lenguaje de programación orientado a objetos , lenguaje de programación multiparadigma y lenguaje de programación interpretado |
tipo de ejecución | Interprete |
Apareció en | 1990 |
Autor | Kenneth Iverson y Roger Hui |
Desarrollador | Kenneth Iverson [1] y Roger High [d] [1] |
extensión de archivo | .ijs |
Liberar | J903 (16 de diciembre de 2021 ) |
Versión de prueba | J904 (diciembre de 2021 ) |
sistema de tipos | dinámica |
sido influenciado | Liga Premier , FP , Florida |
influenciado | k |
Licencia | GNU GPL |
Sitio web | jsoftware.com |
J es un lenguaje de programación vectorial funcional , un dialecto de APL , que, a diferencia del prototipo, no requiere un diseño de teclado especial para ingresar símbolos matemáticos (solo usa caracteres ASCII ).
Desarrollado a principios de la década de 1990 por el creador de APL, Kenneth y Roger Hui , usando ideas lenguajes combinatoria FP FL de John . Sus características principales son un enfoque en las instrucciones MIMD , un enfoque funcional ( las variables se excluyen por completo, en lugar de ellas operan el mecanismo de cambio de nombre y los combinadores ).
Combina varias ideas y paradigmas , siendo un lenguaje puramente funcional : la única forma de pasar un valor es recibirlo como resultado de una llamada de función y pasarlo a la función como parámetro. Muy centrado en el tratamiento de datos.
El único intérprete de J completo desarrollado fue non- free en el período 1994-2010 , el 6 de marzo de 2011, los códigos fuente de la 7ª versión estaban abiertos bajo la licencia GPL3 [2] .
Para describir elementos de programación, J usa terminología gramatical del lenguaje natural, por ejemplo, el término "verbo" se usa en el sentido correspondiente a "función" u "operador" en C.
Correspondencia de los términos del lenguaje J con los términos del lenguaje C:
Término del lenguaje J | Término C |
---|---|
Verbo | Función u operador |
Sustantivo | Un objeto |
verbo que une | Asignación |
signo de puntuación | Separador |
Adverbio | (#definir macro) |
Unión | (#definir macro) |
Cada palabra en una oración J tiene una parte del discurso, el equivalente de un tipo en C. Es un verbo, sustantivo, verbo de enlace, adverbio, conjunción o signo de puntuación. Las partes principales del discurso son sustantivo, verbo, adverbio y conjunción. Todos los nombres que creará el programador y todos los nombres definidos en el lenguaje J (a excepción de los verbos de enlace (=. y =:) y los signos de puntuación) se referirán a una de las partes principales del discurso. Una entidad es un objeto cuyo tipo es una de las partes principales del discurso. En otras palabras, una entidad es un adverbio, un sustantivo, un verbo o una conjunción. A las entidades se les puede dar un nombre, pero la mayoría de ellas no tienen nombre y aparecen en medio de una expresión y desaparecen inmediatamente después, al igual que los resultados intermedios de evaluar una expresión C.
El sustantivo contiene datos, el verbo actúa sobre uno o dos sustantivos para producir un sustantivo como resultado. Un adverbio opera sobre un verbo o sustantivo para producir una esencia, una conjunción opera sobre dos sustantivos o verbos para producir una esencia. Los adverbios y las conjunciones se llaman modificadores. En C, los modificadores se pueden considerar como una macro de preprocesador que acepta nombres de funciones y contiene código que llama al código de función.
Los signos de puntuación en el idioma J se componen de los caracteres () ' y el carácter de final de línea, así como el delimitador NB. y algunas palabras especiales como si. y casos No hay más caracteres de puntuación en el lenguaje J. Incluso los caracteres [ ] , . " ; { } son verbos, y los corchetes [ ] y { } son independientes y se usan solos, no en pares.
La unidad ejecutable de J es una oración, que corresponde a una expresión C. Los delimitadores de oraciones J son el carácter de fin de línea (LF) y palabras de control como si. La oración incluye todos los caracteres entre los separadores, y dado que el carácter LF es el separador, las oraciones J deben caber en la misma línea. No hay forma de dividir una oración en dos líneas.
Todos los comentarios comienzan con NB. y terminar al final de la línea. El comentario se ignora durante la ejecución de la propuesta. En el lenguaje J se distinguen los siguientes tipos de lexemas :
La relación entre los lexemas y las partes del discurso se ilustra en el diagrama de la fig. — lexemas de la lengua J y partes del discurso.
Las palabras en una oración del lenguaje J se dividen en identificadores , primitivas, números, puntuación y constantes de caracteres. Las palabras están separadas por espacios y tabulaciones. Los caracteres "." y ":" significado especial.
Los nombres (identificadores) en el lenguaje J son similares a los del lenguaje C. Comienzan con una letra latina, permiten guiones bajos, distinguen entre mayúsculas y minúsculas y consisten solo en caracteres alfanuméricos y el carácter de guión bajo. Los nombres que terminan en un guión bajo y que contienen dos guiones bajos se tratan de manera especial, esto se debe al concepto de configuración regional.
Los caracteres gráficos ASCII (como "+") se denominan primitivos u operadores.
Cada símbolo gráfico puede formar una nueva primitiva agregando "." o ": ". Dado que todas las primitivas son palabras reservadas , en los nombres "." y ":" no están permitidos. Las primitivas no necesitan estar separadas por espacios. La parte gramatical de cada primitiva es constante para el lenguaje J. Ejemplos:
++. +: { {: {:: yo. Yo para. Seleccione. caso. final.No hay una tabla de precedencia de acciones en J. Todos los verbos del lenguaje J tienen la misma precedencia y asociatividad correcta . Se pueden utilizar paréntesis para determinar el orden. Los paréntesis en el lenguaje J se entienden exactamente como en matemáticas.
En el caso de que el verbo de la izquierda tenga un sustantivo, se evalúa como diádico. Si no está presente, el verbo se evalúa como un verbo monádico con un solo operando a la derecha. Necesita saber la parte del discurso de un personaje para comprender el orden de evaluación, por ejemplo, en una oración
resultado=. nombre1 verbo2 5necesito saber si es un name1verbo o un sustantivo. En el caso de que sea un verbo, el orden de cálculo es name1(verb2(5)), y si es un sustantivo, verb2 es diádico y el resultado (name1 verb2 5).
Todas las conjunciones y adverbios tienen prioridad sobre los verbos y se dejan asociativos .
En el lenguaje J, varios números adyacentes se tratan como una matriz unidimensional. En el caso de que se trate de varios sustantivos separados, se deben usar paréntesis.
J permite construir múltiples árboles de sintaxis para la misma línea de código. Es decir, las descripciones del lenguaje no son completas, no hay una especificación exhaustiva. El lenguaje J es sensible al contexto , y los medios estándar para describirlo (por ejemplo, una gramática en la forma Backus-Nauer ) no son adecuados. El concepto de árbol de sintaxis abstracta incluso pierde su significado, ya que es correcto solo en el campo de los lenguajes libres de contexto.
Lenguajes de programación | |
---|---|
|