Compare commits

...

2 Commits

Author SHA1 Message Date
5f2912f76a es blog: finish zig 9 2024-08-20 15:22:54 -05:00
42b22f674f es blog: rewrite zig 06 2024-08-20 12:01:06 -05:00
23 changed files with 144 additions and 118 deletions

View File

@ -16,7 +16,7 @@ export default defineConfig({
markdown: { markdown: {
shikiConfig: { shikiConfig: {
themes: { themes: {
light: "catppuccin-latte", light: "light-plus",
dark: "dark-plus" dark: "dark-plus"
}, },
transformers: [ transformers: [

Binary file not shown.

Before

Width:  |  Height:  |  Size: 16 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 15 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 4.9 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 18 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 19 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 5.6 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 5.8 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 5.2 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 15 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 8.6 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 21 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 8.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.6 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.2 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 4.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 6.4 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.1 KiB

View File

@ -13,159 +13,148 @@ image:
En el artículo anterior escribimos nuestro primer programa: En el artículo anterior escribimos nuestro primer programa:
Hola mundo. En este artículos vamos a modificar el mensaje Hola mundo. En este artículos vamos a modificar el mensaje
y aprender el primer concepto: Strings y aprender un primer concepto llamado Strings.
Como siempre, vamos a trabajar en el archivo `src/main.zig`
del proyecto que creamos anteriormente.
## Hola mundo modificado
En el programa que escribimos hay un monton de palabras,
y seguramente no las entiendas. Ahora mismo, lo que vamos a
hacer es modificar el texto que aparece.
Primero, observemos el código:
![Codigo](/img/blog/es/tutorial/1x/014.jpg)
Lo que nos importa ahora mismo es la frase `Hola mundo`.
Hay algunas particularidades:
- La frase tiene un color rojizo, mientras que
otras palabras tienen otros colores
- La frase inicia con una comilla doble `"`,
y acaba con otra.
- Hay dos caracteres: `\` y `n` que no aparecen
al ejecutar el programa.
Toda la frase es algo llamado un string. Un string
es una secuencia de letras (caracteres) que unidas
forman un texto.
Los strings se utilizan para representar texto.
Ahora lo vas a modificar.
En el código, reemplaza `Hola` por `Adios`, y
ejecuta el programa. Veras que ahora el mensaje
que sale es `Adios mundo!`
```zig
const std = @import("std");
pub fn main() !void {
std.debug.print("Adios mundo!\n", .{}); // [!code focus]
}
```
![Codigo](/img/blog/es/tutorial/1x/015.jpg)
## Modificando "Hola mundo"
Entra a la página web ## Strings
[https://zig.fly.dev/p/xNluereqmgW](https://zig.fly.dev/p/xNluereqmgW),
donde se encuentra el programa "Hola mundo". Esta vez vamos a modificar
el mensaje.
El resto de las palabras son magia negra. Te habras dado cuenta que Los strings tienen algunas reglas:
hay palabras en español: Hola y mundo.
![Zig online](/img/blog/es/tutorial/009-zig.jpg) Para que sea fácil diferenciarlos, los strings
automáticamente se marcan de color rojizo.
Hay varias cosas que notar: Un string siempre inicia con una comilla doble `"`,
y termina con otra. Las comillas marcan el inicio
y fin del string.
- Estan pintadas de color amarillo Si colocas una comilla dentro de un string, lo que
- Tienen comillas dobles `"` al inicio y al final pasará es que el string terminará antes. Eso lo podrás
ver por el color:
Dentro de estas comillas `"` podemos escribir el texto que querramos. ![Codigo](/img/blog/es/tutorial/1x/016.jpg)
Por ejemplo, si reemplazas `Hola` por `Adios` y ejecutas el programa, En la imagen superior puedes notar que `Juan` está
se imprimirá `Adios mundo!` de color azúl, no rojo.
![Zig online](/img/blog/es/tutorial/010-zig.jpg)
![Zig online](/img/blog/es/tutorial/011-zig.jpg)
Y también, si reemplazas `mundo` por otra palabra, se imprimirá
lo que escribiste.
Tambien puedes agregar otro texto en ambos lados. Por ejemplo:
![Zig online](/img/blog/es/tutorial/012-zig.jpg)
## Strings / cadenas de caracteres Dentro de un string puede ir (casi) cualquier texto,
con tal que esté dentro de la misma linea. Si
la linea termina antes que el string, tendrás un error.
Los strings (cadenas de caracteres en inglés) son la forma ![Codigo](/img/blog/es/tutorial/1x/017.jpg)
en la que almacenamos texto.
Un string empieza con una comilla doble `"`, el contenido Si quieres un texto con una linea nueva se utiliza
del string, y termina con una comilla doble `"`. una combinación especial de caracteres: `\n`.
Estos 2 caracteres cuando estan juntos se traducen
a una nueva linea:
Unos ejemplos de strings son: `"hola"`, `"adios"`,
`"multiples palabras"`, `"123456"`.
En el programa de arriba hay 2 strings: ```zig
const std = @import("std");
![Zig online](/img/blog/es/tutorial/013-zig.jpg) pub fn main() !void {
std.debug.print("En la calle hay\nuna moto y un auto", .{}); // [!code focus]
}
```
Estos strings son lo que se muestra en pantalla al ![Codigo](/img/blog/es/tutorial/1x/018.jpg)
ejecutar el programa.
Los strings tienen algunas características:
- En el código, los strings tienen otro color para que
sea más fácil identificarlos.
- No puede haber comillas dentro de un string.
El string termina cuando aparece la primera comilla.
Por ejemplo:
![Zig online](/img/blog/es/tutorial/014-zig.jpg)
Aquí el string termina despues del `Hola `, la palabra
`familia` no es parte del string. Puedes ver que el
color amarillo del string termina en la segunda comilla,
y la palabra familia está de color blanco.
- No puede haber nuevas lineas en un string. Esto es un error:
![Zig online](/img/blog/es/tutorial/015-zig.jpg)
Sin embargo, hay ocasiones donde queremos tener varias lineas
en un string. Para esto se utilizan 2 caracteres especiales:
`\n`. Estos nos permiten "señalar" que ahí va una linea nueva.
![Zig online](/img/blog/es/tutorial/016-zig.jpg)
Estos caracteres especiales se conocen como "caracteres de escape".
Hay varios de ellos, pero no los veremos por ahora.
Esto último es llamado un "caracter de escape". Hay varios
de ellos, pero los veremos más adelante.
## Impresión ## Impresión
Imprimir es mostrar información a través de la pantalla. Esta Imprimir es que nuestro programa muestre un texto en pantalla.
información puede ser palabras, letras, números, símbolos, etc. Todas las veces que hemos ejecutado nuestro programa, y
aparecío un texto, hemos estado imprimiendo.
Para imprimir en Zig se escribe lo siguiente: Zig tiene una instrucción para imprimir texto: `std.debug.print`, que hemos estado utilizando.
![Zig online](/img/blog/es/tutorial/017-zig.jpg) Esta instrucción tiene 3 partes:
`std.debug.print` es una invocación que imprime lo que tenga - 1: La instrucción en sí
dentro. Para poner algo dentro, se utilizan parentesis `()`. - 2: El texto (string) a imprimir
- 3: Un dato adicional misterioso
Dentro de los paréntesis va el string que queremos imprimir ![Codigo](/img/blog/es/tutorial/1x/019.jpg)
y una secuencia misteriosa, así: `("Tu mensaje", .{})`.
Y finalmente, muy importante, todas las invocaciones Dentro del string (2) podemos poner lo que querramos.
terminan con un punto y coma `;`. Si la invocación Pero el resto tiene que estar igual, los parentesis,
no termina con su punto y coma tendrás un error misterioso. comas, llaves y punto y coma.
Por ejemplo, para imprimir un nuevo texto `Me gusta Zig` Adicionalmente, todas las instrucciones terminan
se escribiriá el código así: con un punto y coma `;`. Este señala que la instrucción
terminó, y esta lista para ejecutarse.
`std.debug.print("Me gusta Zig", .{});` En nuestro programa podemos tener varias intrucciones,
cada una imprimiendo algo nuevo:
Podemos tener varias invocaciones a la vez, y ejecutarlas en ```zig
siempre que la invocación esté bien escrita. const std = @import("std");
![Zig online](/img/blog/es/tutorial/018-zig.jpg) pub fn main() !void {
std.debug.print("Hola\n", .{}); // [!code focus:3]
std.debug.print("Soy fernando\n", .{});
std.debug.print("Adios\n", .{});
}
```
Y al ejecutar el programa se imprimiran los mensajes en orden. ![Codigo](/img/blog/es/tutorial/1x/020.jpg)
![Zig online](/img/blog/es/tutorial/019-zig.jpg) Cada instrucción se coloca en una linea nueva.
## Nuevas lineas ## Siguiente
Notarás que el mensaje se imprimió junto: `Mi primera impresiónMe gusta Zig`. En el siguiente artículo continuaremos trabajando
con impresiones, y aprenderemos qué es ese dato
Este es un buen momento para presentar un concepto muy importante: adicional misterioso.
la computadora hace lo que le pides, no lo que quieres.
El código que ejecutamos no le pide a la computadora que imprima
una nueva linea `\n`. Así que la computadora no la imprime.
Para tener una nueva linea hay que incluirla en los strings, y con
eso al ejecutar estará cada linea separada:
![Zig online](/img/blog/es/tutorial/020-zig.jpg)
![Zig online](/img/blog/es/tutorial/021-zig.jpg)
## Glosario
No es necesario que memorices o entiendas estas palabras.
- String: "cadena de caracteres"
- `const`: abreviatura de "constante", que no cambia
- `std`: abreviatura de "estandar"
- `import`: "importar"
- `pub`: abreviatura de "público", que es accesible
- `fn`: abreviatura de "función". en este artículo les llamé
invocaciones
- `void`: "vacio"
- `main`: "principal"
- `debug`: el debugging es un proceso mediante el cual
se eliminan errores (tambien conocidos como "bugs")
- `print`: "imprimir"

View File

@ -189,4 +189,41 @@ agruparlas con paréntesis.
## Números racionales (float) ## Números racionales (float)
Hemos visto números enteros, pero también podemos
utilizar números reales. Estos se llaman `float`
y vienen del ingles
["floating point number"](https://es.wikipedia.org/wiki/Coma_flotante).
La mayor diferencia es que los `float` permiten usar
decimales, mientras que los `int` no.
Para imprimir un float tambien se usa el formato `{d}`.
```zig
const std = @import("std");
pub fn main() !void {
const ratio_de_cambio = 1.1005; // [!code focus:2]
std.debug.print("El ratio es {d}", .{ratio_de_cambio});
}
```
También puedes utilizar las operaciones matemáticas con
los `float`.
```zig
const std = @import("std");
pub fn main() !void {
const r1 = 4.5 + 3.2; // [!code focus:5]
const r2 = 3.3 - 1.1;
const r3 = -55 * 0.2;
const r4 = 33.33 / 3.3;
std.debug.print("{d} {d} {d} {d}", .{r1, r2, r3, r4});
}
```