Movatterモバイル変換


[0]ホーム

URL:


Ir al contenido
WikipediaLa enciclopedia libre
Buscar

ASCII

De Wikipedia, la enciclopedia libre
Para otros usos de este término, véaseASCII (desambiguación).
ASCII

Caracteres ASCII imprimibles, del 32 al 128
IdiomainglésVer y modificar los datos en Wikidata
SiguienteISO/IEC 8859 yISO 646Ver y modificar los datos en Wikidata

ASCII (acrónimoinglés deAmerican Standard Code for Information Interchange —Código Estándar estadounidense para el Intercambio de Información—), pronunciado generalmente[áski][1]: 6  o (rara vez) [ásθi] o [ási], es uncódigo de caracteres basado en elalfabeto latino, tal como se usa en inglés moderno. Fue creado en 1963 por el Comité Estadounidense de Estándares (ASA, conocido desde 1969 como el Instituto Estadounidense de Estándares Nacionales, oANSI) como una evolución de los conjuntos de códigos utilizados entonces entelegrafía. Más tarde, en 1967, se incluyeron las minúsculas, y se redefinieron algunos códigos de control para formar el código conocido comoUS-ASCII.

El código ASCII utiliza 7bits para representar los caracteres, aunque inicialmente empleaba un bit adicional (bit de paridad) que se usaba para detectar errores en la transmisión. A menudo se llama incorrectamente ASCII a varioscódigos de caracteres de 8 bits que extienden el ASCII con caracteres propios de idiomas distintos al inglés, como el estándarISO/IEC 8859-1.[1]

ASCII fue publicado como estándar por primera vez en 1967 y fue actualizado por última vez en 1986. En la actualidad define códigos para 32 caracteres no imprimibles, de los cuales la mayoría soncaracteres de control que tienen efecto sobre cómo se procesa el texto, más otros 95 caracteres imprimibles que les siguen en la numeración (empezando por el carácter espacio).

Casi todos los sistemas informáticos actuales utilizan el código ASCII o una extensión compatible para representar textos y para el control de dispositivos que manejan letras o cualquier símbolo en el teclado.

Vista general

[editar]

Las computadoras únicamente entienden números. El código ASCII es un método de traducción de letras y símbolos a números como ‘a=97’ o ‘/=47’.[2]

Como otros códigos de formato de representación de caracteres, el ASCII es un método para una correspondencia entre cadenas de bits y una serie de símbolos (alfanuméricos y otros), permitiendo de esta forma la comunicación entre dispositivos digitales así como su procesado y almacenamiento. El código de caracteres ASCII[3][4]​ —o una extensión compatible (ver más abajo)— se usa casi en todas las computadoras, especialmente concomputadoras personales yestaciones de trabajo. El nombre más apropiado para este código de caracteres es «US-ASCII».[5]

! " # $ % & ' ( ) * + , - . / 0 1 2 3 4 5 6 7 8 9 : ; < = > ?@ A B C D E F G H I J K L M N O P Q R S T U V W X Y Z [ \ ] ^ _` a b c d e f g h i j k l m n o p q r s t u v w x y z { | } ~

ASCII es, en sentido estricto, un código de sietebits, lo que significa que usa cadenas de bits representables con siete dígitos binarios (que van de 0 a 127 en base decimal) para representar información de caracteres. En el momento en el que se introdujo el código ASCII muchas computadoras trabajaban con grupos de ocho bits (bytes uoctetos), como la unidad mínima de información; donde el octavo bit se usaba habitualmente comobit de paridad con funciones de control de errores en líneas de comunicación u otras funciones específicas del dispositivo. Las máquinas que no usaban la comprobación de paridad asignaban al octavo bit el valor cero en la mayoría de los casos, aunque otros sistemas como las computadorasPrime, que ejecutabanPRIMOS ponían el octavo bit del código ASCII a uno. El código ASCII define una relación entre caracteres específicos y secuencias de bits; además de reservar unos cuantos códigos de control para el procesador de textos, y no define ningún mecanismo para describir la estructura o la apariencia del texto en un documento; estos asuntos están especificados por otros lenguajes como loslenguajes de etiquetas.

Historia

[editar]
La carta de Código ASCII 1968 de los EE. UU. fue estructurada con dos columnas de caracteres de control, una columna con caracteres especiales, una columna con números, y cuatro columnas de letras

El código ASCII se desarrolló en el ámbito de latelegrafía y se usó por primera vez comercialmente como un código de teleimpresión impulsado por los servicios de datos deBell. Bell había planeado usar un código de seis bits, derivado deFieldata, que añadía puntuación y letras minúsculas al más antiguo código de teleimpresiónBaudot, pero se les convenció para que se unieran al subcomité de la Agencia de Estándares Estadounidense (ASA), que había empezado a desarrollar el código ASCII. Baudot ayudó en la automatización del envío y recepción de mensajes telegráficos, y tomó muchas características delcódigo Morse; sin embargo, a diferencia del código Morse, Baudot usó códigos de longitud constante. Comparado con los primeros códigos telegráficos, el código propuesto por Bell y ASA resultó en una reorganización más conveniente para ordenar listas (especialmente porque estaba ordenado alfabéticamente) y añadió características como la 'secuencia de escape'.

La Agencia de Estándares Estadounidense (ASA), que se convertiría más tarde en el Instituto Nacional Estadounidense de Estándares (ANSI), publicó por primera vez el código ASCII en 1963. El ASCII publicado en 1963 tenía una flecha apuntando hacia arriba (↑) en lugar del circunflejo (^) y una flecha apuntando hacia la izquierda en lugar del guion bajo (_). La versión de 1967 añadió las letras minúsculas, cambió los nombres de algunos códigos de control y cambió de lugar los dos códigos de control ACK y ESC de la zona de letras minúsculas a la zona de códigos de control.

ASCII fue actualizado en consecuencia y publicado como ANSI X3.4-1968, ANSI X3.4-1977, y finalmente ANSI X3.4-1986.Otros órganos de estandarización han publicado códigos de caracteres que son idénticos a ASCII. Estos códigos de caracteres reciben a menudo el nombre de ASCII, a pesar de que ASCII se define estrictamente solamente por los estándares ASA/ANSI:

  • La Asociación Europea de Fabricantes de Computadores (ECMA) publicó ediciones de su clon de ASCII, ECMA-6 en 1965, 1967, 1970, 1973, 1983, y 1991. La edición de 1991 es idéntica a ANSI X3.4-1986.[6]
  • La Organización Internacional de Estandarización (ISO) publicó su versión, ISO 646 (más tarde ISO/IEC 646) en 1967, 1972, 1983 y 1991. En particular, ISO 646:1972 estableció un conjunto de versiones específicas para cada país donde los caracteres de puntuación fueron reemplazados con caracteres no ingleses. ISO/IEC 646:1991 LaInternational Reference Version es la misma que en el ANSI X3.4-1986.
  • La Unión Internacional de Telecomunicaciones (ITU) publicó su versión de ANSI X3.4-1986, Recomendación ITU T.50, en 1992. A principios de la década de 1970 publicó una versión como Recomendación CCITT V.3.
  • DIN publicó una versión de ASCII como el estándar DIN 66003 en 1974.
  • El Grupo de Trabajo en Ingeniería de Internet (IETF) publicó una versión en 1969 comoRFC 20, y estableció la versión estándar para Internet, basada en ANSI X3.4-1986, con la publicación deRFC 1345 en 1992.
  • La versión deIBM de ANSI X3.4-1986 se publicó en la literatura técnica de IBM comopágina de códigos 367.

El código ASCII también está incluido enUnicode, constituyendo los primeros 128 caracteres (o los 'más bajos').

Los caracteres de control ASCII

[editar]
Véase también:Carácter de control

El código ASCII reserva los primeros 32 códigos (numerados del 0 al 31 en decimal) paracaracteres de control: códigos no pensados originalmente para representar información imprimible, sino para controlar dispositivos (comoimpresoras) que usaban ASCII. Por ejemplo, el carácter 10 representa la función «nueva línea» (line feed), que hace que una impresora avance el papel, y el carácter 27 representala tecla «escape» que a menudo se encuentra en la esquina superior izquierda de losteclados comunes.

El código 127 (los siete bits a uno), otro carácter especial, equivale a «suprimir» («delete»). Aunque esta función se asemeja a otros caracteres de control, los diseñadores de ASCII idearon este código para poder «borrar» una sección depapel perforado (un medio de almacenamiento popular hasta la década de 1980) mediante la perforación de todos los agujeros posibles de una posición de carácter concreta, reemplazando cualquier información previa. Dado que el código 0 era ignorado, fue posible dejar huecos (regiones de agujeros) y más tarde hacer correcciones.

Muchos de los caracteres de control ASCII servían para marcar paquetes de datos, o para controlar protocolos de transmisión de datos (por ejemplo ENQuiry, con el significado: ¿hay alguna estación por ahí?, ACKnowledge: recibido o Start Of Header: inicio de cabecera, Start of TeXt: inicio de texto, End of TeXt: final de texto, etc.). ESCape y SUBstitute permitían a un protocolo de comunicaciones, por ejemplo, marcar datos binarios para que contuviesen códigos con el mismo código que el carácter de protocolo, y que el receptor pudiese interpretarlos como datos en lugar de como caracteres propios del protocolo. Los diseñadores del código ASCII idearon los caracteres de separación para su uso en sistemas de cintas magnéticas.

Dos de los caracteres de control de dispositivos, comúnmente llamadosXON yXOFF generalmente ejercían funciones de caracteres decontrol de flujo para controlar el flujo hacia un dispositivo lento (como una impresora) desde un dispositivo rápido (como una computadora), de forma que los datos no saturasen la capacidad de recepción del dispositivo lento y se perdiesen.

Los primeros usuarios de ASCII adoptaron algunos de los códigos de control para representar «metainformación» como final-de-línea, principio/final de un elemento de datos, etc. Estas asignaciones a menudo entraban en conflicto, así que parte del esfuerzo de convertir datos de un formato a otro comporta hacer las conversiones correctas de metainformación. Por ejemplo, el carácter que representa el final-de-línea en ficheros de texto varía con elsistema operativo. Cuando se copian archivos de un sistema a otro, el sistema de conversión debe reconocer estos caracteres como marcas de final-de-línea y actuar en consecuencia.

Actualmente los usuarios de ASCII usan menos los caracteres de control, (con algunas excepciones como «retorno de carro» o «nueva línea»). Los lenguajes modernos de etiquetas, los protocolos modernos de comunicación, el paso de dispositivos basados en texto a basados en gráficos, el declive de las teleimpresoras, las tarjetas perforadas y los papeles continuos han dejado obsoleta la mayoría de caracteres de control.

BinarioDecimalHexAbreviaturaReprATNombre/Significado
0000 0000000NUL^@Carácter Nulo
0000 0001101SOH^AInicio de Encabezado
0000 0010202STX^BInicio de Texto
0000 0011303ETX^CFin de Texto
0000 0100404EOT^DFin de Transmisión
0000 0101505ENQ^EConsulta
0000 0110606ACK^FAcuse de recibo
0000 0111707BEL^GTimbre
0000 1000808BS^HRetroceso
0000 1001909HT^ITabulación horizontal
0000 1010100ALF^JSalto de línea
0000 1011110BVT^KTabulación Vertical
0000 1100120CFF^LAvance de página
0000 1101130DCR^MRetorno de carro
0000 1110140ESO^NDesactivarmayúsculas
0000 1111150FSI^OActivar mayúsculas
0001 00001610DLE^PEscape vínculo de datos
0001 00011711DC1^QControl de dispositivo 1 (XON)
0001 00101812DC2^RControl de dispositivo 2
0001 00111913DC3^SControl de dispositivo 3 (XOFF)
0001 01002014DC4^TControl de dispositivo 4
0001 01012115NAK^UAcuse de recibo negativo
0001 01102216SYN^VSíncronía en espera
0001 01112317ETB^WFin del bloque de transmisión
0001 10002418CAN^XCancelar
0001 10012519EM^YFin del medio
0001 1010261ASUB^ZSubstitución
0001 1011271BESC^[ o ESCEscape
0001 1100281CFS^\Separador de archivo
0001 1101291DGS^]Separador de grupo
0001 1110301ERS^^Separador de registro
0001 1111311FUS^_Separador de unidad
0111 11111277FDEL^? o DELSuprimir

Caracteres imprimibles ASCII

[editar]

El carácter 'espacio', designa al espacio entre palabras, y se produce normalmente por la barra espaciadora de un teclado. Los códigos del 32 al 126 se conocen como caracteres imprimibles, y representan letras, dígitos, signos de puntuación y varios símbolos.

El ASCII de siete bits proporciona siete caracteres «nacionales» y, si la combinación concreta de hardware y software lo permite, puede utilizar combinaciones de teclas para simular otros caracteres internacionales: en estos casos un backspace puede preceder a un acento abierto o grave (en los estándares británico y estadounidense, pero solo en estos estándares, se llama también «opening single quotation mark», unatilde o una «marca de respiración».

!"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{}|~

BinarioDecHexRepresentación
0010 00003220espacio ( )
0010 00013321!
0010 00103422"
0010 00113523#
0010 01003624$
0010 01013725%
0010 01103826&
0010 01113927'
0010 10004028(
0010 10014129)
0010 1010422A*
0010 1011432B+
0010 1100442C,
0010 1101452D-
0010 1110462E.
0010 1111472F/
0011 000048300
0011 000149311
0011 001050322
0011 001151333
0011 010052344
0011 010153355
0011 011054366
0011 011155377
0011 100056388
0011 100157399
0011 1010583A:
0011 1011593B;
0011 1100603C<
0011 1101613D=
0011 1110623E>
0011 1111633F?
 
BinarioDecHexRepresentación
0100 00006440@
0100 00016541A
0100 00106642B
0100 00116743C
0100 01006844D
0100 01016945E
0100 01107046F
0100 01117147G
0100 10007248H
0100 10017349I
0100 1010744AJ
0100 1011754BK
0100 1100764CL
0100 1101774DM
0100 1110784EN
0100 1111794FO
0101 00008050P
0101 00018151Q
0101 00108252R
0101 00118353S
0101 01008454T
0101 01018555U
0101 01108656V
0101 01118757W
0101 10008858X
0101 10018959Y
0101 1010905AZ
0101 1011915B[
0101 1100925C\
0101 1101935D]
0101 1110945E^
0101 1111955F_
 
BinarioDecHexRepresentación
0110 00009660`
0110 00019761a
0110 00109862b
0110 00119963c
0110 010010064d
0110 010110165e
0110 011010266f
0110 011110367g
0110 100010468h
0110 100110569i
0110 10101066Aj
0110 10111076Bk
0110 11001086Cl
0110 11011096Dm
0110 11101106En
0110 11111116Fo
0111 000011270p
0111 000111371q
0111 001011472r
0111 001111573s
0111 010011674t
0111 010111775u
0111 011011876v
0111 011111977w
0111 100012078x
0111 100112179y
0111 10101227Az
0111 10111237B{
0111 11001247C|
0111 11011257D}
0111 11101267E~

Rasgos estructurales

[editar]
  • Los dígitos del 0 al 9 se representan con sus valores prefijados con el valor 0011 en binario (esto significa que la conversiónBCD-ASCII es una simple cuestión de tomar cada unidad bcd y prefijarla con 0011).
  • Las cadenas de bits de las letras minúsculas y mayúsculas solo difieren en un bit, simplificando de esta forma la conversión de uno a otro grupo.

Otros nombres para ASCII

[editar]

LaRFC 1345 (publicada en junio de 1992) y elregistro IANA de códigos de caracteres, reconocen los siguientes nombres alternativos para ASCII para su uso en Internet.

  • ANSI_X3.4-1968 (nombre canónico)
  • ANSI_X3.4-1986
  • ASCII
  • US-ASCII (nombre MIME recomendado)
  • us
  • ISO646-US
  • ISO_646.irv:1991
  • iso-ir-6
  • IBM367
  • cp367
  • csASCII

De estos, solo los nombres «US-ASCII» y «ASCII» se usan ampliamente. A menudo se encuentran en el parámetro de «código de caracteres» opcional en la cabecera Content-Type de algunos mensajesMIME, en el elemento equivalente «meta» de algunos documentosHTML, y en la parte de declaración de codificación de carácter de la cabecera de algunos documentosXML.

Variantes de ASCII

[editar]

A medida que la tecnología informática se difundió a lo largo del mundo, se desarrollaron diferentes estándares y las empresas desarrollaron muchas variaciones del código ASCII para facilitar la escritura de lenguas diferentes al inglés que usaran alfabetos latinos. Se pueden encontrar algunas de esas variaciones clasificadas como «ASCII Extendido», aunque en ocasiones el término se aplica erróneamente para cubrir todas las variantes, incluso las que no preservan el conjunto de códigos de caracteres original ASCII de siete bits.

LaISO 646 (1972), el primer intento de remediar el sesgo pro-inglés de la codificación de caracteres, creó problemas de compatibilidad, pues también era un código de caracteres de 7 bits. No especificó códigos adicionales, así que reasignó algunos específicamente para los nuevos lenguajes. De esta forma se volvió imposible saber en qué variante se encontraba codificado el texto, consecuentemente, los procesadores de texto podían tratar una sola variante.

La tecnología mejoró y aportó medios para representar la información codificada en el octavo bit de cada byte, liberando este bit, lo que añadió otros 128 códigos de carácter adicionales que quedaron disponibles para nuevas asignaciones. Por ejemplo,IBM desarrolló páginas de código de 8 bits, como lapágina de códigos 437, que reemplazaba los caracteres de control con símbolos gráficos como sonrisas, y asignó otros caracteres gráficos adicionales a los 128 bytes superiores de la página de códigos.

Algunos sistemas operativos comoDOS, podían trabajar con esas páginas de código, y los fabricantes decomputadoras personales incluyeron soporte para dichas páginas en su hardware.

Los estándares de ocho bits comoISO 8859 yMac OS Roman fueron desarrollados como verdaderas extensiones de ASCII, dejando los primeros 127 caracteres intactos y añadiendo únicamente valores adicionales por encima de los 7-bits. Esto permitió la representación de un abanico mayor de lenguajes, pero estos estándares continuaron sufriendo incompatibilidades y limitaciones. Todavía hoy,ISO-8859-1 y su varianteWindows-1252 (a veces llamada erróneamente ISO-8859-1) y el código ASCII original de 7 bits son los códigos de carácter más comúnmente utilizados.

Unicode yConjunto de Caracteres Universal (UCS) ISO/IEC 10646 definen un conjunto de caracteres mucho mayor, y sus diferentes formas de codificación han empezado a reemplazar ISO 8859 y ASCII rápidamente en muchos entornos. Mientras que ASCII básicamente usa códigos de 7-bits, Unicode y UCS usan «code points» o apuntadores relativamente abstractos: números positivos (incluyendo el cero) que asignan secuencias de 8 o más bits a caracteres. Para permitir la compatibilidad, Unicode y UCS asignan los primeros 128 apuntadores a los mismos caracteres que el código ASCII. De esta forma se puede pensar en ASCII como un subconjunto muy pequeño de Unicode y UCS. La popular codificaciónUTF-8 recomienda el uso de uno a cuatro valores de 8 bits para cada apuntador, donde los primeros 128 valores apuntan a los mismos caracteres que ASCII. Otras codificaciones de caracteres comoUTF-16 se parece a ASCII en cómo representan los primeros 128 caracteres de Unicode, pero tienden a usar 16 a 32 bits por carácter, así que requieren de una conversión adecuada para que haya compatibilidad entre ambos códigos de carácter.

La palabraASCIIbético (o, más habitualmente, la palabra «inglesa»ASCIIbetical) describe la ordenación según el orden de los códigos ASCII en lugar del orden alfabético.[7]

La abreviatura ASCIIZ o ASCIZ se refiere a una cadena de caracteres terminada en cero (del inglészero).Es muy normal que el código ASCII sea integrado en otros sistemas de codificación más sofisticados y por esto debe tenerse claro cual es papel del código ASCII en la tabla o mapa de caracteres de una computadora.

Arte ASCII

[editar]
Imagen deleón creada con arte ascii.
Artículo principal: Arte ASCII

El código de caracteres ASCII es el soporte de una disciplina artística minoritaria, elarte ASCII, que consiste en la composición de imágenes mediante caracteres imprimibles ASCII. El efecto resultante ha sido comparado con elpuntillismo, pues las imágenes producidas con esta técnica generalmente se aprecian con más detalle al ser vistas a distancia. El arte ASCII empezó siendo un arte experimental, pero pronto se popularizó como recurso para representar imágenes en soportes incapaces de procesar gráficos, comoteletipos,terminales,correos electrónicos o algunas impresoras.

Aunque se puede componer arte ASCII manualmente mediante un editor de textos, también se pueden convertir automáticamente imágenes y videos en ASCII mediante software, como la librería Aalib (de licencia libre), que ha alcanzado cierta popularidad. Aalib está soportada por algunos programas de diseño gráfico, juegos y reproductores de vídeo.

Véase también

[editar]

Variantes ASCII de computadoras específicas

[editar]

Notas y referencias

[editar]
  1. abMackenzie, Charles E. (1980).«Coded Character Sets, History and Development».The Systems Programming Series (1 edición) (Addison-Wesley Publishing Co. Inc.). pp. 6, 16 211, 215, 217, 220, 223, 228, 236–238, 243–245, 247–253, 423, 425–428, 435–439.ISBN 0-201-14460-3.LCCN 77090165. [1]
  2. Nombres de Dominio Internacionalizados - Glosario,Internet Corporation for Assigned Names and Numbers (ICANN). Consultado el 19 de noviembre de 2008.
  3. Organización Internacional para la Estandarización (1 de diciembre de 1975).El conjunto de caracteres de ISO 646.Internet Assigned Numbers Authority Registry. Accedido el 7 de agosto de 2005.
  4. Organización Internacional para la Estandarización (1 de diciembre de 1975).Internet Assigned Numbers Authority Registry.Versión estadounidense. Accedido el 7 de agosto de 2005.
  5. Internet Assigned Numbers Authority (28 de enero de 2005).Códigos de caracteres. Accedido el 7 de agosto de 2005.
  6. ECMA International (diciembre de 1991).Standard ECMA-6: 7-bit Coded Character Set, 6th edition Accedido el 17 de diciembre de 2005.
  7. Jargon File.ASCIIbetical. Accedido el 17 de diciembre de 2005.

Referencias generales

[editar]

Enlaces externos

[editar]
Control de autoridades

Obtenido de «https://es.wikipedia.org/w/index.php?title=ASCII&oldid=172030837»
Categorías:
Categorías ocultas:

[8]ページ先頭

©2009-2026 Movatter.jp