Saltar al contenido principal
Versión: 20

Null e indefinido

Null e Indefinido son tipos de datos que manejan los casos en los que no se conoce el valor de una expresión.

Null

Null es un tipo de datos especial con un solo valor posible: null. Este valor es devuelto por una expresión que no contiene ningún valor. Al intentar leer una propiedad de un valor null se produce un error.

En el lenguaje 4D y para los atributos de los campos de los objetos, los valores nulos se gestionan a través de la función Null. Esta función puede utilizarse con las siguientes expresiones para definir o comparar el valor nulo:

  • atributos de objetos
  • elementos de colecciones
  • variables de tipo objeto, colección, puntero, imagen o variant (ver también Null como valor predeterminado.

Indefinido

Indefinido no es realmente un tipo de datos. Denota una variable que aún no ha sido definida. La evaluación de una propiedad de objeto también puede producir un valor indefinido. La lectura de una propiedad de valor indefinido devuelve undefined.

Una variable variant tiene indefinido como valor por defecto.

Un campo no puede ser indefinido (el comando Undefined siempre devuelve False para un campo).

Normalmente, al intentar leer o asignar expresiones indefinidas, 4D generará errores, excepto en los siguientes casos:

  • Asignar un valor indefinido a variables (excepto arrays) tiene el mismo efecto que llamar a CLEAR VARIABLE con ellas:
     var $o : Object
var $val : Integer
$val:=10 //$val=10
$val:=$o.a //$o. es indefinido (no hay error) y la asignación de este valor borra la variable
//$val=0
  • La asignación de un valor indefinido a una propiedad de objeto existente reinicializa o borra su valor, dependiendo de su tipo:
    • Objeto, colección, puntero: Null
    • Imagen: imagen vacía
    • Booleano: False
    • Cadena: ""
    • Número: 0
    • Fecha: !00-00-00! Date: !00-00-00! if "Use date type instead of ISO date format in objects" setting is enabled, otherwise ""
    • Hora: 0 (número de ms)
    • Indefinido, Null: sin cambios
     var $o : Object
$o:=New object("a";2)
$o.a:=$o.b //$o.a=0
  • La asignación de un valor indefinido a una propiedad de objeto no existente no hace nada.

  • Un valor indefinido pasado como parámetro a un método proyecto se convierte automáticamente en 0 o "" según el tipo de parámetro declarado.

     var $o : Object
mymethod($o.a) //Pasar un parámetro indefinido

//En el método mymethod
#Declare ($myText : Text) //El tipo de parámetro es texto
// $myText contiene ""
  • Una expresión de condición se convierte automáticamente en falsa cuando se evalúa a indefinido con las palabras clave If y Case of:
     var $o : Object
If($o.a) // false
End if
Case of
:($o.a) // false
End case
tip

Cuando se esperan expresiones de un tipo determinado en su código 4D, puede asegurarse de que tienen el tipo correcto incluso cuando se evalúan como indefinidas, rodeándolas con el comando de transformación 4D apropiado: String, Num, Date, Time, Bool. Estos comandos devuelven un valor vacío del tipo especificado cuando la expresión se evalúa como indefinida. Por ejemplo:

 $myString:=Lowercase(String($o.a.b)) //asegurarse de obtener un valor de cadena aunque sea indefinido
//para evitar errores en el código

Operadores Null

OperaciónSintaxisDevuelveExpressionValor
IgualNull = NullBooleana.nullProp = b.nullPropTrue
Null = UndefinedBooleana.nullProp = b.undefinedPropTrue
Null = valor escalarBooleana.nullProp = 42False
DesigualdadNull # NullBooleana.nullProp # b.nullPropFalse
Null # UndefinedBooleana.nullProp # b.undefinedPropFalse
Null # valor escalarBooleana.nullProp # 42True

valores escalares son valores de tipo Cadena, Fecha, Hora, Booleano, Número o Blob. Cuando se declaran, su valor por defecto no es ni indefinido ni null. Otros tipos (Puntero, Imagen, Objeto, Colección) tienen un valor por defecto indefinido o null. Ej:

var $object : Object
var $text : Text

//$object = null
//$text = ""
info

Las comparaciones con los operadores Mayor que (>), Menor que (<), Mayor o igual que (>=) y Menor o igual que (<=) no se admiten con valores Null y devuelven un error.

Operadores indefinidos

OperaciónSintaxisDevuelveExpressionValor
IgualIndefinido = IndefinidoBooleana.undefinedProp = b.undefinedPropTrue
Undefined = NullBooleana.undefinedProp = c.nullPropTrue
Undefined = otros valoresBooleana.undefinedProp = 42False
DesigualdadUndefined # UndefinedBooleana.undefinedProp # b.undefinedPropFalse
Undefined # NullBooleana.undefinedProp # b.nullPropFalse
Undefined # otros valoresBooleana.undefinedProp # 42True
Mayor queUndefined > string, Date, Time, Boolean, numberBooleana.undefinedProp > "abc"False
Menor queUndefined < string, Date, Time, Boolean, numberBooleana.undefinedProp < "abc"False
Mayor o igual queUndefined >= string, Date, Time, Boolean, numberBooleana.undefinedProp >= "abc"False
Menor o igual queUndefined <= string, Date, Time, Boolean, numberBooleana.undefinedProp <= "abc"False

otros valores son expresiones de todo tipo con un valor ni Undefined ni Null.

info

Las comparaciones de valores Undefined con valores Pointer, Picture, Blob, Object, Collection, Undefined o Null mediante los operadores Mayor que (>), Menor que (<), Mayor o igual que (>=) y Menor o igual que (<=) no son compatibles y devuelven un error.

Ejemplos

Aquí están los diferentes resultados del comando Undefined así como del comando Null con las propiedades de los objetos, dependiendo del contexto:

var $vEmp : Object
var $result : Boolean
$vEmp:=New object
$vEmp.name:="Smith"

$vEmp.children:=Null

$result:=Undefined($vEmp.name) //False
$result:=($vEmp.name=Null) //False

$result:=Undefined($vEmp.children) //False
$result:=($vEmp.children=Null) //True

$result:=Undefined($vEmp.parent) //True
$result:=($vEmp.parent=Null) //True

Ejemplos de resultados de comparación con valores indefinidos y null:

var $result : Boolean
var $vObj : Object
var $vVar : Variant

$vObj:=New object
$vObj.null:=Null
//note que $vVar no está asignado

$result:=($vObj.undefined=42) //False
$result:=($vObj.undefined=$vObj.null) //True
$result:=($vObj.undefined=$vVar) //True

$result:=($vObj.undefined#$vObj.null) //False
$result:=($vObj.undefined#42) //True
$result:=($vObj.undefined#$vVar) //False

$result:=($vObj.undefined>"hello") //False
$result:=($vObj.undefined>$vVar) //Error
$result:=($vObj.undefined>$vObj.null) //Error
$result:=($vVar < 42) //False