Curso gratuito de PHP. Regístrate para hacer un seguimiento de tu progreso →

PHP: Casos límite

En esta lección implementaremos la función mysubstr(), que extrae una subcadena de una cadena de longitud especificada.

Recibe dos argumentos:

  • La cadena
  • La longitud

Esta función devuelve la subcadena comenzando desde el primer carácter:

<?php

function mysubstr($str, $length)
{
    $index = 0;
    $result = '';
    while ($index < $length) {
        $currentChar = $str[$index];
        $result = "{$result}{$currentChar}";
        $index = $index + 1;
    }

    return $result;
}

$str = 'Si miro hacia atrás, estoy perdido';

mysubstr($str, 1); // 'i'
mysubstr($str, 7); // 'Si miro'

https://replit.com/@hexlet/php-basics-edge-cases-mysubstr

Parece que todo está bien. Pero nuestra función contiene muchos errores porque no tiene en cuenta los llamados casos límite. La función funciona correctamente solo con argumentos normales. Pero no sabemos cómo se comportará si le pasamos estas longitudes:

  • 0
  • Un número negativo
  • Un número que excede la longitud real de la cadena

La función mysubstr() no está diseñada para manejar estos casos. Podríamos pensar que no es un problema: la función funciona en condiciones normales y simplemente no debemos pasarle "argumentos incorrectos".

En un mundo ideal, sí, pero en el mundo real, tu código se ejecutará en diferentes situaciones, con diferentes combinaciones de condiciones y datos. No se puede estar seguro de que los argumentos siempre serán correctos, por lo que debemos tener en cuenta todos los casos, dentro de los límites de la lógica.

Los casos límite son la causa más común de errores lógicos en los programas. Los programadores a menudo olvidan tener en cuenta algo. Estos errores a menudo no se manifiestan de inmediato y pueden no causar problemas visibles durante mucho tiempo. El programa sigue funcionando, pero en algún momento se descubre que hay errores en los resultados.

A menudo, la causa radica en la débil tipificación de PHP. La capacidad para manejar este tipo de errores viene con la experiencia, a través de problemas constantes del tipo "¡Ups, olvidé verificar si la cadena está vacía!".

Imaginemos una función extendida mysubstr(). Recibe tres argumentos:

  • La cadena
  • El índice
  • La longitud de la subcadena a extraer

Veamos ejemplos de llamadas:

<?php

$str = 'Si miro hacia atrás, estoy perdido';
mysubstr($str, 0, 1); // 'i'
mysubstr($str, 3, 6); // 'i miro'

Discutamos qué podría salir mal. ¿Qué casos límite debemos tener en cuenta?

  • Longitud negativa de la subcadena a extraer
  • Índice negativo especificado
  • El índice especificado está fuera de los límites de toda la cadena
  • La longitud de la subcadena, sumada al índice especificado, está fuera de los límites de toda la cadena

En la implementación de la función, cada caso límite será un fragmento de código separado, probablemente implementado con if.

Para escribir la función mysubstr() y protegernos de estos casos, debemos escribir una función separada que verifique la corrección de los argumentos. Abordaremos esto en la tarea de esta lección.

Tarea

Implementa la función predicado isArgumentsForSubstrCorrect, que recibe tres argumentos:

  1. La cadena
  2. El índice desde el cual comenzar la extracción
  3. La longitud de la subcadena a extraer

La función devuelve false si se cumple al menos una de las siguientes condiciones:

  • Longitud negativa de la subcadena a extraer
  • Índice negativo especificado
  • El índice especificado está fuera de los límites de toda la cadena
  • La longitud de la subcadena, sumada al índice especificado, está fuera de los límites de toda la cadena

De lo contrario, la función devuelve true.

No olvides que los índices comienzan en 0, por lo que el índice del último elemento es "longitud de la cadena menos 1".

Ejemplo de llamada:

<?php

$str = 'Sansa Stark';
isArgumentsForSubstrCorrect($str, -1, 3);  // false
isArgumentsForSubstrCorrect($str, 4, 100); // false
isArgumentsForSubstrCorrect($str, 10, 10); // false
isArgumentsForSubstrCorrect($str, 11, 1);  // false
isArgumentsForSubstrCorrect($str, 3, 3);   // true
isArgumentsForSubstrCorrect($str, 0, 5);   // true
¿El ejercicio no pasa la prueba, qué debo hacer? 😶

Si te quedaste atascado, es el momento perfecto para hacer una pregunta en las "Discusiones".
* Asegúrate de incluir la salida de las pruebas. Sin ella, es casi imposible entender qué está mal, incluso si muestras tu código. Los programadores tienen dificultades para ejecutar el código en su mente, pero casi siempre es posible entender a dónde mirar a partir del error que recibiste.

Mi código funciona en mi entorno, pero no aquí 🤨

Las pruebas están diseñadas de manera que verifican la solución de diferentes maneras y con diferentes datos. A menudo, una solución funciona con ciertos datos de entrada pero no con otros. Para entender este punto, revisa la pestaña "Pruebas" y presta atención a los mensajes de error, que suelen contener pistas.

Mi código es diferente a la solución del profesor 🤔

Esto es normal 🙆. En programación, una tarea puede tener muchas soluciones diferentes. Si tu código pasa la prueba, cumple con los requisitos de la tarea.

En raras ocasiones, la solución puede estar ajustada para pasar las pruebas, pero esto suele ser evidente.

Leí la lección, pero no entendí nada 🙄

Crear materiales de aprendizaje comprensibles para todos es bastante difícil. Hacemos nuestro mejor esfuerzo, pero siempre hay margen para mejorar. Si encuentras material que no entiendes, describe el problema en las "Discusiones". Es ideal si puedes formular los aspectos que no entiendes en forma de preguntas. Por lo general, necesitamos unos días para hacer mejoras.

Por cierto, tú también puedes contribuir a mejorar los cursos: en la parte inferior hay un enlace al código fuente de las lecciones, que se puede modificar directamente en el navegador.


¿Encontraste un error? ¿Quieres añadir algo? Las solicitudes de extracción son bienvenidas. https://codica.la/errores
Si te encuentras con dificultades y no sabes qué hacer, pregunta en nuestra gran y amigable comunidad