diff --git a/docs/Tips/tip10.md b/docs/Tips/tip10.md
index bc83195..822f916 100644
--- a/docs/Tips/tip10.md
+++ b/docs/Tips/tip10.md
@@ -1,5 +1,147 @@
---
layout: post
-title: "Tip 10: Comming soon"
+title: "Tip 10: Diferencias entre Const y Readonly"
---
-# Comming soon
+# Diferencias entre Const y Readonly
+🔑 **Introducción**
+Las palabras clave **const** y **readonly** en **C#** tienen como objetivo evitar modificaciones en las variables después de su inicialización, pero su uso y propósito tienen diferencias importantes.
+
+### ✅ **Características Clave**
+🔷 **const**
+1. **Valor fijo en tiempo de compilación:**
+- Su valor debe estar disponible y calculado en tiempo de compilación.
+2. **Declaración obligatoria con un inicializador:**
+- Es obligatorio asignar un valor en su declaración.
+3. **Implícitamente estático:**
+- No necesita ser declarado como ```static```, ya que lo es por defecto.
+4. **Restricciones de tipo:**
+- Solo se permite con tipos primitivos como int, bool, string y double.
+- No admite tipos definidos por el usuario, como clases o structs.
+
+```c#
+const double Pi = 3.14159; // Valor fijo en tiempo de compilación.
+const int MaxConnections = 10; // Implícitamente estático.
+```
+🔷 **readonly**
+1. **Valor fijo en tiempo de ejecución:**
+- Su valor puede ser asignado en la declaración o en el constructor.
+2. **Flexibilidad en tipos:**
+- Puede usarse con cualquier tipo, incluidos tipos por referencia como clases, arrays, y structs.
+3. **Puede ser ```static``` o de instancia:**
+- No es implícitamente estático; debes declararlo explícitamente si deseas ese comportamiento.
+
+```c#
+readonly DateTime CreatedOn = DateTime.Now; // Asignado en tiempo de ejecución.
+readonly string[] Names; // Admite tipos complejos como arrays.
+
+public MyClass(string[] names)
+{
+ Names = names; // Se permite asignar en el constructor.
+}
+```
+
+### 🆚 **Comparativa**
+
+
+
+ Aspecto |
+ const |
+ readonly |
+
+
+
+
+ Inicialización |
+ En tiempo de compilación. |
+ En tiempo de ejecución o constructor. |
+
+
+ Modificación posterior |
+ No se puede modificar. |
+ No se puede modificar tras asignación inicial o en el constructor. |
+
+
+ Alcance de tipos |
+ Solo tipos primitivos (int, bool, string). |
+ Admite cualquier tipo, incluidos objetos y arrays. |
+
+
+ Estático por defecto |
+ Sí, implícitamente estático. |
+ No, debe ser declarado explícitamente si es estático. |
+
+
+ Uso con tipos definidos por el usuario |
+ No |
+ Sí |
+
+
+
+
+### **✅ Ejemplo Comparativo**
+```c#
+using System;
+
+class Program
+{
+ // Constantes
+ const double Pi = 3.14159; // Tiempo de compilación.
+ const string WelcomeMessage = "¡Bienvenido!";
+
+ // Variables readonly
+ readonly DateTime CreatedOn; // Asignado en tiempo de ejecución.
+ readonly string[] Names;
+
+ public Program(string[] names)
+ {
+ CreatedOn = DateTime.Now; // Permitido en el constructor.
+ Names = names; // Arrays también permitidos.
+ }
+
+ static void Main()
+ {
+ Console.WriteLine($"Valor de Pi: {Pi}"); // Siempre fijo.
+ Console.WriteLine($"Mensaje: {WelcomeMessage}");
+
+ var program = new Program(new[] { "Ana", "Luis", "Carlos" });
+ Console.WriteLine($"Creado el: {program.CreatedOn}");
+
+ foreach (var name in program.Names)
+ Console.WriteLine($"Nombre: {name}");
+ }
+}
+```
+
+### **🌟 Ventajas y Casos de Uso**
+
+
+
+ Escenario |
+ Usar const |
+ Usar readonly |
+
+
+
+
+ Valores conocidos y fijos en tiempo de compilación. |
+ ✅ Ejemplo: Pi, velocidad de la luz, etc. |
+ 🚫 No necesario. |
+
+
+ Valores dinámicos que dependen de lógica o tiempo. |
+ 🚫 No se puede usar. |
+ ✅ Ejemplo: Fechas, objetos dinámicos. |
+
+
+ Tipos complejos como clases o arrays. |
+ 🚫 No permitido. |
+ ✅ Admite cualquier tipo. |
+
+
+
+
+### 🚀 **Conclusión**
+- Usa const cuando los valores sean constantes y conocidos en tiempo de compilación.
+- Usa readonly cuando necesites mayor flexibilidad para asignar valores en tiempo de ejecución o usar tipos complejos.
+
+¡Conocer estas diferencias te ayudará a escribir código más claro y eficiente! 🎯