Skip to content

Commit

Permalink
Merge branch 'RustLangES:main' into main
Browse files Browse the repository at this point in the history
  • Loading branch information
ivanlynch authored Feb 24, 2024
2 parents f58320e + 3a570ac commit ac72279
Show file tree
Hide file tree
Showing 3 changed files with 23 additions and 17 deletions.
8 changes: 5 additions & 3 deletions src/ch04-02-references-and-borrowing.md
Original file line number Diff line number Diff line change
Expand Up @@ -221,7 +221,8 @@ Aquí está el error:
```

Este mensaje de error se refiere a una característica que aún no hemos cubierto:
los tiempos de vida. Discutiremos los tiempos de vida en detalle en el Capítulo 10. Pero, si ignora las partes sobre los tiempos de vida, el mensaje contiene la
los tiempos de vida. Discutiremos los tiempos de vida en detalle en el Capítulo
10. Pero, si ignora las partes sobre los tiempos de vida, el mensaje contiene la
clave para saber por qué este código es un problema:

```text
Expand All @@ -232,8 +233,9 @@ for it to be borrowed from
Se traduciría algo así como:

````text
el tipo de retorno de la función contiene un valor prestado, pero no hay ningún valor
que pueda ser prestado```
el tipo de retorno de la función contiene un valor prestado, pero no hay ningún
valor que pueda ser prestado
```
<span class="filename">Nombre de archivo: src/main.rs</span>
Expand Down
30 changes: 17 additions & 13 deletions src/ch04-03-slices.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,8 @@ fn first_word(s: &String) -> ?

La función `first_word` tiene un `&String` como parámetro. No queremos el
ownership, así que esto está bien. Pero ¿Que deberíamos retornar? Realmente no
tenemos una forma de hablar sobre "una _porción_ de un string". Sin embargo, podríamos
retornar el índice del final de la palabra, indicado por un espacio.
tenemos una forma de hablar sobre "una _porción_ de un string". Sin embargo,
podríamos retornar el índice del final de la palabra, indicado por un espacio.
Probemos eso, como se muestra en Listing 4-7.

<span class="filename">Filename: src/main.rs</span>
Expand All @@ -47,18 +47,20 @@ A continuación, creamos un iterator sobre el array de bytes utilizando el méto
{{#rustdoc_include ../listings/ch04-understanding-ownership/listing-04-07/src/main.rs:iter}}
```

Hablaremos más detalladamente sobre los iterators en [Procesando una serie de elementos con Iteradores][ch13]<!-- ignore -->.
Por ahora, sabemos que `iter` es un método que retorna cada elemento en una
colección y que `enumerate` envuelve el resultado de `iter` y retorna cada
elemento como parte de una tupla. El primer elemento de la tupla que retorna
`enumerate` es el índice, y el segundo elemento es una referencia al elemento.
Hablaremos más detalladamente sobre los iterators en [Procesando una serie de
elementos con Iteradores][ch13]<!-- ignore -->. Por ahora, sabemos que `iter` es
un método que retorna cada elemento en una colección y que `enumerate` envuelve
el resultado de `iter` y retorna cada elemento como parte de una tupla. El
primer elemento de la tupla que retorna `enumerate` es el índice, y el segundo
elemento es una referencia al elemento.
Esto es un poco más conveniente que calcular el índice nosotros mismos.

Debido a que el método `enumerate` retorna una tupla, podemos usar patrones para
desestructurar esa tupla. Hablaremos más sobre los patrones en [Patrones que vinculan valores][ch6]<!-- ignore -->. En el ciclo `for`, especificamos un patrón que tiene `i`
para el índice de la tupla e `&item` para el byte único en la tupla.
Debido a que tomamos una referencia al elemento de `.iter().enumerate()`,
podemos usar`&` en el patrón.
desestructurar esa tupla. Hablaremos más sobre los patrones en
[Patrones que vinculan valores][ch6]<!-- ignore -->. En el ciclo `for`,
especificamos un patrón que tiene `i` para el índice de la tupla e `&item` para
el byte único en la tupla. Debido a que tomamos una referencia al elemento de
`.iter().enumerate()`, podemos usar`&` en el patrón.

Dentro del ciclo `for`, buscamos el byte que representa el espacio usando
la sintaxis literal del byte. Si encontramos un espacio, retornamos su posición.
Expand Down Expand Up @@ -279,7 +281,9 @@ para el tipo del parámetro de`s`</span>
Si tenemos un string slice, podemos pasar directamente ese valor. Si tenemos
un `String`, podemos pasar un slice del `String` o una referencia al `String`.
Esta flexibilidad aprovecha las _deref coercions_, una característica que
veremos en la sección ["Tratando los Smart Pointers como Referencias Regulares con el Trait Deref"][deref-coercions]<!--ignore--> del Capítulo 15.
veremos en la sección
["Tratando los Smart Pointers como Referencias Regulares con el Trait Deref"]<!--ignore-->
del Capítulo 15.

Definir una función para tomar un string slice en lugar de una referencia a un
`String` hace que nuestra API sea más general y útil sin perder ninguna
Expand Down Expand Up @@ -332,4 +336,4 @@ ver cómo agrupar piezas de datos en un `struct`.
[ch13]: ch13-02-iterators.html
[ch6]: ch06-02-match.html#patrones-que-vinculan-valores
[strings]: ch08-02-strings.html#almacenando-texto-codificado-en-utf-8-con-strings
[deref-coercions]: ch15-02-deref.html#implicit-deref-coercions-with-functions-and-methods
["Tratando los Smart Pointers como Referencias Regulares con el Trait Deref"]: ch15-02-deref.html#implicit-deref-coercions-with-functions-and-methods
2 changes: 1 addition & 1 deletion src/ch06-01-defining-an-enum.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ Cualquier dirección IP puede ser una dirección de la versión cuatro o la vers
seis, pero no ambas al mismo tiempo. Esa propiedad de las direcciones IP hace
que la estructura de datos `enum` sea apropiada porque un valor `enum` puede ser
sólo una de sus variantes. Tanto las direcciones de la versión cuatro como la versión seis
siguen siendo fundamentalmente direcciones direcciones IP, por lo que deben ser
siguen siendo fundamentalmente direcciones IP, por lo que deben ser
tratadas como el mismo tipo cuando el código está manejando situaciones que se
aplican a cualquier tipo de dirección IP.

Expand Down

0 comments on commit ac72279

Please sign in to comment.