✒️ABAP Las subrutinas
ABAP Las subrutinas
1. ¿Qué son las subrutinas?
Subrutinas
Son secciones de código que pueden ser utilizadas más de una vez dentro de un mismo programa y también pueden ser utilizadas por otros programas que las referencien.
La idea de pasar el código de los programas a subrutinas, es para que los programas sean más fáciles de leer y de mantener.
Modularizar
Se llama así a la acción de pasar el código de un programa a subrutinas, para mejorar la lectura y el mantenimiento del mismo.
Lo ideal es que una su rutina no tenga más de 50 líneas de código.
La modularización ayuda a encontrar más fácilmente los errores en los programas. Esto se debe que al de debuggear un programa solo nos preocupamos que el resultado de una subrutina sea el esperado sin entrar en detalle de cómo se llega a ese resultado.
En ABAP una su rutina se declara con la palabra reservada PERFORM seguida del nombre de la subrutina
El nombre que se le asigne a una su rutina debe ser lo más representativo posible del resultado que produce la subrutina.
La longitud del nombre de una subrutina no puede exceder los 30 caracteres.
2. Los tipos de subrutina
Existen dos tipos de subrutinas:
- Internas: cuando la subrutina se encuentra dentro del mismo programa que la llama o en un include de subrutinas, el cuál se encuentra declarado en el programa del control.
- Externas: cuando la subrutina se encuentra en un programa distinto al que la llama. Para llamar a una subrutina externa de otro programa se debe escribir la sentencia PERFORM de la siguiente forma:
PERFORM <nombre_subrutina> IN PROGRAM <nombre_programa_subrutina>.
3. El paso de parámetros a subrutinas
Podemos pasar datos entre el programa principal y una subrutina a través de parámetros.
Los parámetros de una subrutina pueden ser de tres tipos:
- De entrada: cuando se utilizan para pasar datos del programa principal a la subrutina.
- De salida: cuando se utilizan para pasar datos de la subrutina al programa principal.
- De entrada y salida: cuando se utilizan para pasar datos de la subrutina al programa principal y viceversa.
Para pasar los parámetros en las subrutinas vamos a utilizar tres palabras reservadas que son las siguientes:
- USING para declarar parámetros de entrada que serán utilizados en la subrutina.
- CHANGING para declarar parámetros de entrada/salida que serán utilizados en la subrutina.
- TABLES para declarar parámetros de entrada/salida que son tablas, las cuales serán utilizadas en la subrutina.
Las palabras reservadas que acabamos de mencionar deben ser escritas en el orden que mostramos a continuación:
PERFORM <nombre_subrutina> TABLES <tabla_interna>
USING <parámetro_de_entrada>
CHANGING <parámetro_de_entrada_y_salida>.
A los parámetros definidos dentro del programa principal, en la declaración de la subrutina, a la derecha de la palabra PERFORM se les llama parámetros actuales.
A los parámetros que se especifican en la definición de la subrutina, a la derecha de la palabra FORM se los llama parámetros formales.
En el bloque FORM-ENDFORM debemos especificar el tipo de los parámetros formales.
De esta manera nos aseguramos que solo se pasen parámetros del tipo que corresponde a la subrutina.
Cuando una subrutina es llamada, los parámetros deben ser pasados en el mismo orden en el que fueron declarados, por lo tanto, se debe respetar esta misma secuencia en el bloque FORM-ENDFORM
Existen tres formas de pasar parámetros:
- Paso por valor: durante la llamada a la subrutina, los parámetros formales son creados como copias de los parámetros actuales. Los cambios en los parámetros formales no afectan a los parámetros actuales. Se usa la palabra reservada value, se encierra entre paréntesis el parámetro.
- Paso por referencia: durante la llamada a subrutina, solo la dirección de los parámetros actuales se transfieren a los parámetros formales. Dentro de subrutina, se trabaja con el campo del programa que hace la llamada. Si cambiamos los parámetros formales, el contenido del campo del programa que hace la llamada también cambia.
- Paso por valor y resultado: durante la llamada de subrutina, los parámetros formales son creados como copias de los parámetros actuales. Los cambios en los parámetros formales son copiados a los parámetros actuales al final de subrutina.
4. Las declaraciones de datos globales y locales
Cuando declaramos datos en un programa ABAP, es decir variables, estructuras, tablas internas u otros tipos de datos, podemos hacerlo de dos formas diferentes: globalmente y localmente.
Las declaraciones que se realizan luego de la ejecución de la sentencia REPORT y antes de la declaración del evento START-OF-SELECTION, son llamadas declaraciones globales, lo cual significa que estas declaraciones pueden ser utilizadas en cualquier lugar del programa y con esto nos referimos a que pueden ser utilizadas tanto en el programa principal como en cualquiera de subrutinas que el programa contenga.
Las declaraciones globales de datos tienen una ventaja y una desventaja.
- Como ventaja podemos decir que se facilita el armado del programa ya que no tenemos que estar pensando en dónde particularmente va a ser utilizada una declaración de datos, sino que simplemente la declaramos globalmente y la utilizamos en donde corresponda.
- Como desventaja podemos decir que al realizar todas las declaraciones de datos en forma global no estamos generando un código ABAP tan eficiente en cuanto a la modularización, lo cual en algún punto puede complicar el mantenimiento futuro del programa.
Otra posibilidad con la que contamos consiste en realizar declaraciones locales, es decir, dentro de una subrutina podríamos declarar exclusivamente los datos que vamos a utilizar, de modo de modularizar lo más posible el código y consumir de menor cantidad de recursos de sistema, evitando declarar globalmente datos que solo serán utilizados localmente y de esta forma hacemos más eficiente el uso de la memoria de un programa ABAP.
Cuando declaramos una variable global, entonces vamos a comenzar con vg_ seguido el nombre de la variable y cuando declaramos una variable local, entonces vamos a comenzar con vl_ seguido del nombre de la variable.
 
 
 
Agradecimiento:
Ha agradecido este aporte: Octavio Pasciucco
Sobre el autor
Publicación académica de Alexis Jesus Perez Ramirez, en su ámbito de estudios para la Carrera Consultor ABAP.
Alexis Jesus Perez Ramirez
Profesión: Licenciado en Computación - Venezuela - Legajo: LK96B
✒️Autor de: 69 Publicaciones Académicas
🎓Egresado del módulo:
Disponibilidad Laboral: FullTime
Presentación:
Licenciado en computación egresado de la ucv, con amplia experiencia en base de datos, análisis de sistemas y programación; tanto en ambiente web, cliente/servidor como en computación central.
Certificación Académica de Alexis Perez