Cerrar menu
Tutoriales En Linea
  • Tutoriales
    • Aprendizaje
    • Video Tutorial
    • Manuales
    • Hagalo usted mismo
    • Explorar todo
  • Adobe
    • After Effects
    • Dreamweaver
    • Premiere Pro CC
    • Photoshop
    • Photoshop Mix
    • Lightroom
    • Illustrator
    • Adobe Muse
    • Creative Cloud
  • Android
    • Developer Android
    • Aplicaciones
    • Android Studio
    • Android Wear
    • Desarrolladores
    • SDK Platform-Tools
    • ADB...depuración Bridge
    • Fastboot
    • Root
    • Recovery
  • Apple
    • iPhone y iPad
    • iPhone
    • iPad
    • Mac OS
    • iCloud
    • iTunes
  • Cursos
    • Actívate
    • Autoempleo
    • Idiomas
    • Curso De HTML
    • Curso de C++
    • Javascript
    • jQuery
    • Matematicas
    • Programacion
    • Python
    • Udacity
    • Diseño Web adaptativo
  • Ciberseguridad
    • Malware
    • Ransomware
    • Virus
    • Troyano
    • Dorkbot
    • Filecoders
    • keylogger
    • Spyware
    • Jackware
    • DDoS
    • HackerOne
    • Interpol
  • Criptomonedas
    • Blockchain
    • Mineria de Criptomonedas
    • Bitcoin (BTC)
    • Bitcoin Cash (BCH)
    • DASH (Dash)
    • Dogecoin (Doge)
    • Ethereum (ETH)
    • Litecoin (LTC)
    • Monero (XMR)
    • Ripple (XRP)
    • Zcash (ZEC)
    • Forex
    • Trading
  • Desarrollo Web
    • Sistema de gestion de contenidos
    • AMP
    • Datalife Engine
    • Blogger
    • WordPress
    • Joomla
    • Bootstrap
    • Plantillas
    • @font-face
    • Schema
    • Website
    • Desarrolladores
    • Lenguaje Web
  • Diseño Web
    • Web Responsive
    • Lenguaje Web
    • Datos estructurados
    • HTML
    • CSS3
    • JavaScript
    • Ajax
    • jQuery
    • PHP
  • Entretenimiento
  • Encuestas
    • GlobalTestMarket
    • Centro de opinion
    • Ipsos i-Say
    • Triaba
    • opinea
    • Toluna
    • YouGov
    • ClixSense
    • ySense
    • Cint
    • Beruby
  • Electricidad
  • Electronica
  • Ganar dinero comprando
    • CashbackDeals
    • Cashback
    • Por ir de compras
    • Aklamio
    • Intercambio de tráfico
    • Justificante de pagos
    • Webs estafas
  • Google
    • Google Pay
    • Adsense
    • Gmail
    • Google Apps
    • Google Chrome
    • Google Cloud Platform
    • Google Consumer Surveys
    • Google Desarrolladores
    • Google Fit
    • Google Maps
    • Google Photos
    • Google Play
    • Google Translation
    • DoubleClick
    • YouTube
    • Chromebooks
  • Marketing
    • SEM
    • SEO
    • Posicionamiento
    • Contenido
    • Publisuites
    • Space Content
    • Coobis
    • Marketing
  • Computadora u ordenador
    • Sistemas operativos
      • Windows
      • Mac OS
      • Android
      • Linux
      • Ubuntu
      • Kali Linux
      • Wifislax
    • hardware
    • Software
    • BIOS
    • Unidad de disco duro
    • Programacion
    • Dispositivos
    • Internet
  • Ofimática
    • Microsoft
    • Suite Ofimatica
    • Access
    • Word
    • Excel
    • Powerpoint
    • Outlook
    • Microsoft Publisher
  • PTC
    • No pierdas tiempo con estas web
  • Redes Sociales
    • Delicious
    • Facebook
    • Instagram
    • linkedin
    • Snapchat
    • TikTok
    • Twitter
    • Pinterest
    • Spotify
    • Vkontakte - VK
    • WhatsApp
  • Smartphone
    • Telefonos
    • Telefonia movil y telecomunicaciones
    • Desbloquear
    • Códigos NCK
    • Liberar
    • Tarjeta SIM
    • Tablet
  • Sitio Web
    • Dominios
    • Hosting
    • Servidores
    • Demo DLE
    • Documentación sobre Datalife Engine
    • Modulos DLE
    • Hack
    • Optimizacion
    • Google Adsense
    • Plantillas
  • Tips
    • Cabello
    • Consejos
    • Cremas
    • Cosmético
    • Cuerpo
    • Dieta
    • Exfoliantes
    • Entrenamiento
    • Ejercicio
    • Estilo
    • Fitness
    • Habitos
    • Hidratante
    • Look
    • Maquillaje
    • Moda
    • Piel Radiante
    • Recetas
    • Ropa
    • Rutina
    • Salud
    • Tratamientos
  • Trabajos
    • Atencion al cliente
    • Asistente virtual
    • Transcripcíon
    • Transcripcíones medica
    • Entrada de datos
    • De edicion y correccion
    • Mystery Shopping
    • Micro trabajos
    • Contabilidad
    • Tutoria y aprendizaje
    • Mas ingresos extras
    • Git
    • GitHub
    • Criptografia
    • Deep Web
    • Hacker
    • FTP
    • Indexar
    • Newsletter
    • Redes y VPN
    • Herramientas online
  • Windows
    • Skype
    • Windows
    • Windows 11
    • Windows 10
    • Windows 8
    • Windows 7
    • Puerta trasera de Windows
    • Microsoft Edge
Facebook X (Twitter) Instagram
  • Sobre nosotros
  • Últimos artículos
  • Herramientas SEO
  • Ver mas temas
  • Más sitios que te gustarán
Facebook X (Twitter) Instagram Pinterest Youtube
  • Secciones
    1. Android
    2. Adobe
    3. Bricolaje
    4. Bachillerato
    5. Cursos
    6. Criptomonedas
    7. Criptografia
    1. Diseño Web
    2. Encuestas
    3. Empleo
    4. Electricidad
    5. Electronica
    6. Forex
    7. Fisica
    1. Google
    2. Hardware
    3. Herramientas Ofimaticas
    4. Herramientas
    5. Internet
    6. Idiomas
    7. IPTV
    1. Programacion
    2. Libros
    3. Microsoft
    4. Manuales
    5. Matematica
    6. Newsletter
    7. Optimizacion
    1. Redes Sociales
    2. Software
    3. Seguridad
    4. Telefonia
    5. WebSite
    6. Ver todas las categorias
    7. Post promocionado
  • Smartphone

    Comprendre les Différences entre les Chargeurs USB et les Chargeurs USB-C : Un Guide Complet

    Huawei Smartphones: Las Mejores Ofertas del Black Friday para Aprovechar

    Gadgets imprescindibles para tu configuración de oficina en casa

    ¡Descubre las tendencias más emocionantes en el mundo de los videojuegos!

    Tendencias en sistemas operativos en smartphone

  • Tecnología
    1. Móviles
    2. Ordenadores
    3. Software
    4. Hardware
    5. Seguridad
    6. Ver todo

    Comprendre les Différences entre les Chargeurs USB et les Chargeurs USB-C : Un Guide Complet

    Huawei Smartphones: Las Mejores Ofertas del Black Friday para Aprovechar

    Gadgets imprescindibles para tu configuración de oficina en casa

    ¡Descubre las tendencias más emocionantes en el mundo de los videojuegos!

    Cómo limpiar la unidad C de archivos innecesarios

    Descubre el misterioso mundo del hash de archivos: ¡todo lo que necesitas saber!

    Los componentes fundamentales que todo PC debería tener

    Que es la tecla TAB

    Cifrado | Seguridad Local

    Maximiza tu productividad: Descubre el sistema interactivo que revolucionará la gestión de proyectos en tu empresa

    Cómo limpiar la unidad C de archivos innecesarios

    Como jugar online y resolver un sudoku

    Que es la tecla TAB

    Cómo deshabilitar la desfragmentación de SSD y HDD en Windows 10 y 11

    Benefits Of Vertical Dual Monitors For Coding And Programming

    AMD ha identificado la causa de la quema de los procesadores Ryzen 7000 y ha lanzado un nuevo AGESA para corregir el problema

    Cifrado | Seguridad Local

    Descubre el misterioso mundo del hash de archivos: ¡todo lo que necesitas saber!

    Virus en el sistema DataLife Engine (DLE) y cómo tratarlos

    La ciberseguridad: Vital Para Las Apuestas Online en España

    ¡Descubre las tendencias más emocionantes en el mundo de los videojuegos!

    ¿Aburrido de tu viejo televisor? Descubre las últimas tendencias en televisores

    Generador de Video IA: La Revolución en la Creación Audiovisual

    Los últimos celulares para que estés a la última

  • Estilo de vida
    1. Entrenamiento
    2. Maquillaje
    3. Dieta
    4. Moda
    5. Trucos y tips
    6. Ver todo

    Desarrolla un cuerpo fuerte y saludable

    ¿Qué es la forma física?

    Mejora los resultados de tu entrenamiento de estabilidad y fuerza

    Consejos para maximizar las caminatas diarias

    ¿Por qué es importante preparar la piel antes de maquillarla?

    Consejos para aplicar pestañas postizas

    Consejos para una piel perfecta este invierno

    La nutrición y un cabello saludable

    Cosas que le pasan a tu cuerpo cuando comes salmón todos los días

    Batidos de proteínas pueden ayudar a mejorar sus hábitos alimenticios

    Batidos de proteinas - Una guía para principiantes

    Snacks nutritivos para cada antojo

    Inspiración de traje de otoño

    La dura verdad sobre las modelos de talla grande

    Razones por las que las marcas de moda de lujo son tan caras

    Cuales son las mejores frutas para adelgazar

    Como enseñar a leer y a escribir

    Como generar cuentas Disneyplus

    Calcular porcentajes con la Calculadora de Windows 10

    Bricolaje para la decoración del hogar

    Top 10 de posturas de yoga

    ¿Por qué es importante preparar la piel antes de maquillarla?

    Inspiración de traje de otoño

    Consejos de belleza para lucir fresca en el verano

  • Marketing

    ¿Sirven de algo los diseñadores Web?… ¿y los redactores de contenido?

    ¿Qué es un Link Dofollow?

    ¿Qué es Nofollow?

    ¿Qué es el remarketing?

    ¿Qué es el posicionamiento web (SEO) y lo necesito para mi sitio web?

  • Juegos

    Para qué se pueden usar las Gafas VR PS4

    La nueva generación de realidad virtual de PlayStation®VR2 y PlayStation®5

    Colaboración entre Sony INZONE y EXCEL Esports

    Sony prohíbe cuatro juegos de terceros en Xbox

    Prepárate para el futuro: Project Trinity llega a finales de 2024

  • Herramientas
Búsqueda extendida

Escriba arriba y presione Enter para buscar.

¡Bienvenido de nuevo!

Inicie sesión o Regístrate ahora

VK

o con Email

¿Has olvidado tu contraseña?

Noticias » Curso De C++ - Capitulo 19

Curso De C++ - Capitulo 19


0 Mayo 17, 2015
Compartir

Compartir
Twitter Pinterest LinkedIn Tumblr WhatsApp Email

 

Ejemplos capítulo 18 y 19

Ejemplo 19.1

Siguiendo con el problema de trabajar con enteros grandes, y aprovechando que ya sabemos manejar operadores de bits, veamos otra alternativa a la de los ejemplos del capítulo 9.

Hay una solución intermedia, que consiste en usar codificación BCD. No aprovecha tanto la capacidad de almacenamiento como la forma binaria pura y dificulta un poco más las operaciones para hacer las sumas, pero como contrapartida es mucho más fácil mostrar los resultados.

Nota: la codificación BCD (Binary-Coded Decimal) consiste en usar cuatro bits para cada dígito decimal, concretamente, los códigos 0000 al 1001, es decir, del 0 al 9. Como usamos cuatro bits por dígito, en un byte podemos almacenar dos dígitos BCD. 
De este modo, en un byte podemos almacenar los números desde 0 a 99.

En nuestra cadena de 32 caracteres podemos almacenar 64 dígitos, lo cual no está nada mal.

En este caso, nos vuelve a convenir usar un almacenamiento del tipo Big-Endian, sobre todo por coherencia, ya que cada byte contiene dos dígitos, también hay que decidir uno de los modos de almacenamiento para cada uno, y lo tradicional es Big-Endian.

Una curiosidad de esta codificación es que siempre almacenaremos un número par de dígitos. Para almacenar un número como 123 usaremos dos bytes, uno con el valor 0x01 y otro con 0x23. Deberemos tener esto en cuenta a la hora de trabajar con el acarreo, si es necesario aumentar el número de dígitos. Por ejemplo 999+1 no implica aumentar el número de dígitos, pero 9999+1, sí.

// Sumar números enteros sin signo almacenados en formato BCD
// Agosto de 2009 Con Clase, Salvador Pozo
#include <iostream>

using namespace std;

const unsigned int cax = 32;
typedef unsigned char numero[cax];

bool Sumar(numero, numero, numero);
void MostrarBCD(numero);

int main() {
    numero n1={
        0x00,0x00,0x00,0x00,
        0x00,0x00,0x00,0x00,
        0x00,0x00,0x00,0x00,
        0x00,0x00,0x00,0x00,
        0x00,0x00,0x00,0x00,
        0x00,0x00,0x00,0x00,
        0x00,0x00,0x00,0x00,
        0x00,0x00,0x10,0x00 };
    numero n2={
        0x00,0x00,0x00,0x00,
        0x00,0x00,0x00,0x00,
        0x00,0x00,0x00,0x00,
        0x00,0x00,0x00,0x00,
        0x00,0x00,0x00,0x00,
        0x00,0x00,0x00,0x00,
        0x00,0x00,0x00,0x00,
        0x00,0x09,0x98,0x12 };
    numero suma;

    Sumar(n1, n2, suma);
    MostrarBCD(n1);
    cout << " + ";
    MostrarBCD(n2);
    cout << " = ";
    MostrarBCD(suma);
    cout << endl;
    return 0;
}


bool Sumar(numero n1, numero n2, numero r) {
    int acarreo = 0;
    int c;

    for(int i = cax-1; i >= 0; i--) {
        // Sumar digito de menor peso:
        c = acarreo+(n1[i] & 0x0f) + (n2[i] & 0x0f);
        if(c > 9) { c-=10; acarreo=1; }
        else acarreo=0;
        r[i] = c;
        // Sumar digito de mayor peso:
        c = acarreo+((n1[i] >> 4) & 0x0f) + ((n2[i] >> 4) & 0x0f);
        if(c > 9) { c-=10; acarreo=1; }
        else acarreo=0;
        r[i] |= (c << 4);
    }
    return !acarreo;
}

void MostrarBCD(numero n) {
    char c;
    bool cero=true;

    for(unsigned int i = 0; i < cax; i++) {
        c = '0' + ((n[i] >> 4) & 0x0f);
        if(c != '0') cero=false;
        if(!cero) cout << c;
        c = '0' + (n[i] & 0x0f);
        if(c != '0') cero=false;
        if(!cero) cout << c;
    }
} 

Ejecutar este código en codepad.

El método para extraer cada uno de los dígitos almacenados en un byte es el siguiente.

Para el de menor peso se usan los cuatro bits de la derecha, de modo que basta con hacer una operación AND de bits con la máscara 00001111, es decir, el valor 0x0f.

Nota: llamámos máscara a un valor binario que al combinarlo mediante una operación AND con otro, deja sólo los bits que queremos preservar, enmascarando el resto. En el valor usado como máscara, los bits con valor "1" preservan el valor de los bits, y los bits con valor "0" no, ya que cualquier bit AND "0" da como resultado "0" y cualquier bit AND "1" no cambia de valor. 

Para el de mayor peso hacemos una rotación de cuatro bits a la derecha y después, enmascaramos el valor resultante con 0x0f.

En rigor, para este segundo caso no es necesario enmascarar el resultado, ya que las rotaciones de bits a la derecha introducen ceros por la izquierda.

Para volver a "empaquetar" los dós dígitos en un valor byte hacemos el proceso contrario. Rotamos a la izquierda el dígito de mayor peso cuatro bits y lo combinamos con el de menor peso usando el operador de bits OR.

Ejemplo 19.2

Veamos otro ejemplo de aplicación de operadores de bits.
Probablemente hayas oido hablar de algo llamado CRC. Seguramente en mensajes de error Error de CRC, al copiar ficheros, etc.
El CRC es una función que se aplica a un conjunto de datos de longitud indeterminada y produce un valor de longitud fija. Se usa para detectar errores durante la tansmisión o el almacenamiento de datos.

La mecánica es sencilla:

1-El emisor de un mensaje (o fichero) calcula su CRC y lo añade al mensaje.
2-El receptor lee el mesaje (o fichero) y también calcula su CRC.
3-El receptor posee ahora dos valores de CRC, el que ha recibido con el mensaje, y el que ha calculado. Si ambos son iguales significa que el mensaje no ha sido alterado durante la transmisión. Si son diferentes, es que ha habido un error.

El algoritmo para calcular el CRC ite una entrada de tipo stream, es decir, se puede ir calculando el CRC a medida que los datos se generan o se reciben.

Si te interesa la parte teórica del CRC, mira este enlace.

El algoritmo consiste en:
- Elegimos el valor del polinomio adecuado, dependerá del tamaño del CRC.
- Partimos de un valor de CRC semilla, normalmente 0xFFFF.
- Bucle: - Para cada bit del valor de entrada (empezando por la izquierda). - Si es "1" el nuevo valor del CRC será el resultado de aplicar la operación OR exclusivo entre el valor
anterior del CRC y el polinomio. - Cerrar el bucle. 

Se suelen usar tres valores diferentes para los polinomios, que han demostrado que restringen al máximo la probabilidad de no detectar errores. Elegirnemos el adecuado en función del tamaño del CRC o de los datos.

-CRC-12: X12+X11+X3+X2+X+1
-CRC-16: X16+X15+X2+1
-CRC-CCITT: X16+X12+X5+1

El CRC-12 se utiliza cuando la longitud del carácter es de 6 bits, mientras que los otros dos se utilizan con caracteres de 8 bits.

// Calculo de CRC
// (C) 2009 Con Clase
// Salvador Pozo
#include <iostream>

using namespace std;

const unsigned int CCITT_POLYNOM = 0x1021;
typedef unsigned short int WORD;
typedef unsigned char BYTE;

WORD CalcCRC(WORD uCRC, BYTE bData);

int main() {
    WORD uCRC = 0xffff;

    char cadena[] = "Cadena de prueba para calculo de CRC";

    for(int i = 0; cadena[i]; i++) 
        uCRC = CalcCRC(uCRC, (BYTE)cadena[i]);
    cout << "CRC: " << hex << uCRC << endl;
    return 0;  
}

WORD CalcCRC(WORD uCRC, BYTE bData) {
   int i;
   BYTE bD = bData;
   for(i = 0; i < 8; i++) {
        uCRC <<= 1;
        if(bD & 0x0080) uCRC = CCITT_POLYNOM;
        bD <<= 1;
   }
   return uCRC;
} 
Ejecutar este código en codepad.
Este programa ilustra el uso de typedef para la definición de tipos como WORD o BYTE.
En la función CalcCRC se usa aritmética de bits, en desplazamientos y en la función XOR.
 
Ejemplo 19.3

Retomemos el ejemplo del capítulo 16 sobre la codificación de colores. En esa ocasión usamos una unión para acceder a las componentes de color empaquetadas en un entero largo sin signo. Veamos ahora cómo podemos usar operadores de bits para lo mismo:

// Codificación de colores
// aritmética de bits
// (C) 2009 Con Clase
// Salvador Pozo
#include <iostream>

using namespace std;

typedef unsigned long int color ;
typedef unsigned char BYTE;

inline BYTE ObtenerValorRojo(color);
inline BYTE ObtenerValorVerde(color);
inline BYTE ObtenerValorAzul(color);
inline BYTE ObtenerValorAlfa(color);
inline color ModificarValorRojo(color, BYTE);
inline color ModificarValorVerde(color, BYTE);
inline color ModificarValorAzul(color, BYTE);
inline color ModificarValorAlfa(color, BYTE);

int main() {
    color c1 = 0x80fedc12;

    cout << "Color: " << dec << c1 << " - " << hex << c1 << endl;
    cout << "Rojo:  " << dec << (int)ObtenerValorRojo(c1) << " - " << hex << (int)ObtenerValorRojo(c1) << endl;
    cout << "Verde: " << dec << (int)ObtenerValorVerde(c1) << " - " << hex << (int)ObtenerValorVerde(c1) << endl;
    cout << "Azul:  " << dec << (int)ObtenerValorAzul(c1) << " - " << hex << (int)ObtenerValorAzul(c1) << endl;
    cout << "Alfa:  " << dec << (int)ObtenerValorAlfa(c1) << " - " << hex << (int)ObtenerValorAlfa(c1) << endl;

    c1 = ModificarValorRojo(c1, 0x42);
    c1 = ModificarValorVerde(c1, 0xde);
    cout << "Color: " << dec << c1 << " - " << hex << c1 << endl;
    cout << "Rojo:  " << dec << (int)ObtenerValorRojo(c1) << " - " << hex << (int)ObtenerValorRojo(c1) << endl;
    cout << "Verde: " << dec << (int)ObtenerValorVerde(c1) << " - " << hex << (int)ObtenerValorVerde(c1) << endl;
    cout << "Azul:  " << dec << (int)ObtenerValorAzul(c1) << " - " << hex << (int)ObtenerValorAzul(c1) << endl;
    cout << "Alfa:  " << dec << (int)ObtenerValorAlfa(c1) << " - " << hex << (int)ObtenerValorAlfa(c1) << endl;

    return 0;
}

inline BYTE ObtenerValorRojo(color c) {
   return (BYTE)(c);
}

inline BYTE ObtenerValorVerde(color c) {
   return (BYTE)(c >> 8);
}

inline BYTE ObtenerValorAzul(color c) {
    return (BYTE)(c >> 16);
}

inline BYTE ObtenerValorAlfa(color c) {
    return (BYTE)(c >> 24);
}

inline color ModificarValorRojo(color c, BYTE r) {
   return (c & 0xffffff00) | (color)r;
}

inline color ModificarValorVerde(color c, BYTE g) {
   return (c & 0xffff00ff) | (color)(g << 8);
}

inline color ModificarValorAzul(color c, BYTE b) {
   return (c & 0xff00ffff) | (color)(b << 16);
}

inline color ModificarValorAlfa(color c, BYTE a) {
   return (c & 0x00ffffff) | (color)(a << 24);
} 
Ejecutar este código en codepad.

Para extraer una de las componentes de color, rotamos a la derecha tantos bits como sean necesarios y retornamos el byte de menor peso. Esto lo podemos hacer, como en este ejemplo, mediante un casting o aplicando la máscara 0x000000ff mediante el operador AND (&).

Para modificar una de las componentes, el proceso es el contrario. Primero eliminamos la componente original, aplicando la máscara adecuada, por ejemplo, para el color verde es 0xffff00ff, después rotamos el valor de la nueva componente a la izquierda tantos bits como sea necesario. Finalmente, unimos ambos valores usando el operador OR (|).
Ir al Principio
Síguenos en
Google News Flipboard
  • 100
  • 1
  • 2
  • 3
  • 4
  • 5
Curso De C++ - Capitulo 19
Curso De C++ - Capitulo 20
omegayalfa
omegayalfa
  • Website
  • Facebook
  • Twitter
  • LinkedIn
  • Pinterest
  • Instagram

Sobre mi: ¡Aprende los trucos de tutoriales online y cursos gratis con Tutoriales En Linea! Con manuales paso a paso para desarrollar tu conocimiento, Tutoriales En Linea te ayudará a mejorar tus habilidades y lograr tus metas.
Un tutorial está diseñado con pasos secuenciales que aumentan gradualmente el entendimiento. Por lo tanto, es importante que se sigan los pasos en su orden lógico para que el comprenda todos los elementos. Para optimizar los resultados, se recomienda seguir de forma profesional las instrucciones del tutorial.

Artículos Relacionados


Curso De C++ - Capitulo 18

Curso De C++ - Capitulo 18

Curso De C++ - Capitulo 19

Curso De C++ - Capitulo 19

Curso De C++ - Capitulo 20

Curso De C++ - Capitulo 20


Comentarios



Información
s que no esten registrados no pueden dejar comentarios, te invitamos a que te registre!

Destacados

Lista IPTV con canales para colombia

Mayo 23 43 791

Como instalar SS IPTV en una Smart Tv Samsung

Ene 22 10 380

Como podemos conseguir proxies

Jun 21 11 616

Historia de los sistemas operativos

Mayo 16 31 052

Lo mas leidos

Herramientas SEO para posicionamiento de nuestra web 2024

Por 17-06-24

Herramienta online de generador de datos estructurados

Por Tutoriales En Linea 17-06-24

Las 7 mejores páginas para descargar películas en .torrent en español

Por 26-09-24

Etiquetas

cursos online y gratuitos




Sobre nosotros

Tutoriales En Linea

¡Bienvenidos a Tutoriales En Línea, el sitio web perfecto para encontrar todas las herramientas necesarias para mejorar tus habilidades de forma gratuita! En Tutoriales En Linea se encuentran tutoriales, cursos online y aprendizaje de calidad, muy útiles para desarrollar tus capacidades... Leer mas...

Tiene una pregunta? ar...

Enlaces

  • Sobre nosotros
  • Ultimos tutoriales
  • Publicar tutorial
  • Ver mas temas
  • Ultimos comentarios
  • ¿Preguntas Frecuentes?
  • Derechos de autor
  • Politica de cookies
  • Nuestro equipo
  • Normas

Herramientas online

  • Buscador de recetas
  • Prueba de diseño web
  • Codificar en binarios, hexadecimales...
  • Cual es mi IP
  • Test de velocidad
  • Editor HTML
  • Test de escritura
  • Test de nutricion
  • Descargar Videos
  • Generador de datos estructurados

Recursos

  • Analisis de tus problemas de SEO
  • Herramientas SEO
  • Generar palabras claves
  • Referencia de CSS3
  • Convertir HTML a XML
  • Acortador de URL
  • Selector de colores
  • Contador de palabras
  • Comprimir imagenes
  • Conversor a URI de datos
  • Suscribirse
Facebook Twitter Instagram Pinterest Linkedin Youtube
  • Anunciarse
  • Socios externos
  • Política de privacidad
  • Términos y Condiciones
  • Sobre nosotros
  • ar
© Tutoriales En Linea. Reservados todos los derechos, queda prohibida la reproducción parcial o total sin previa autorización.