Saltar para o conteúdo principal
Versão: 20

Null e indefinido

Nulo e Indefinido são tipos de dados que tratam de casos em que o valor de uma expressão não é conhecido.

Null

Null é um tipo de dados especial com um único valor possível: null. Este valor é devolvido por uma expressão que não contém nenhum valor. Tentar ler uma propriedade de um valor null retorna um erro.

Na linguagem 4D e para os atributos dos campos dos objetos, os valores nulos são gerenciados através da função Null. Esta função pode ser usada com as expressões abaixo para definir ou comparar o valor nulo:

  • atributos de objetos
  • elementos da coleção
  • variáveis do objeto, coleção, ponteiro, imagem ou tipo variante (ver também Null como valor padrão.

Indefinido

Indefinido não é realmente um tipo de dados. Denota uma variável que ainda não foi definida. Evaluating an object property can also produce an undefined value. Reading a property of an undefined value returns undefined.

A variant variable has undefined as default value.

Um campo não pode ser indefinido (o comando Undefined sempre devolve False para um campo).

Typically when trying to read or assign undefined expressions, 4D will generate errors, except in the following cases:

  • Atribuir um valor indefinido a variáveis (exceto arrays) tem o mesmo efeito que chamar CLEAR VARIABLE com elas:
     C_OBJECT($o)
C_LONGINT($val)
$val:=10 //$val=10
$val:=$o. //$o.a é indefinido (sem erro), e atribuir este valor limpa a variável
//$val=0
  • A atribuição de um valor indefinido a um objecto existente reinicia ou limpa o seu valor, dependendo do seu tipo:
    • Objecto, colecção, ponteiro: Null
    • Imagem: Imagem vazia
    • Booleano: Falso
    • String: ""
    • Número: 0
    • Data: !00-00-00-00! se a configuração "Usar tipo de data em vez de formato de data ISO nos objetos" estiver habilitada, caso contrário ""
    • Hora: 0 (número de ms)
    • Indefinido, Null: sem mudança
     C_OBJECT($o)
$o:=New object("a";2)
$o.a:=$o.b //$o.a=0
  • Atribuir um valor indefinido a uma propriedade objecto não existente não faz nada.

  • Um valor indefinido passado como parâmetro para um método de projecto é automaticamente convertido em 0 ou "" de acordo com o tipo de parâmetro declarado.

     C_OBJECT($o)
meumétodo($o. ) //passa um parâmetro indefinido

//In mymethod
C_TEXT($1) //parameter type é texto
// $1 contém ""
  • Uma expressão de condição é automaticamente convertida em falsa quando se avalia para indefinida com as palavras-chave If e Case:
     C_OBJECT($o)
If($o.a) // false
End if
Case of
:($o.a) // false
End case
tip

Quando expressões de um certo tipo são esperadas em seu código 4D, pode garantir que tenha o tipo correto mesmo quando são avaliadas como indefinidas, cercando-as com o comando de transformação 4D apropriado: String, Num, Date, Time, Bool. Estes comandos devolvem um valor vazio de tipo especificado quando a expressão é avaliada como indefinida. Por exemplo:

 $myString:=Caixa minúscula(String($o.a.b))) // certifique-se de obter um valor de string mesmo que não esteja definido
// para evitar erros no código

Operadores Null

OperaçãoSintaxeRetornaExpressionValor
IgualNull = NullParâmetrosa.nullProp = b.nullPropTrue
Null = UndefinedParâmetrosa.nullProp = b.undefinedPropTrue
Null = valor escalarParâmetrosa.nullProp = 42False
DesigualdadeNull # NullParâmetrosa.nullProp # b.nullPropFalse
Null # UndefinedParâmetrosa.nullProp # b.undefinedPropFalse
Null # valor escalarParâmetrosa.nullProp # 42True

Os valores escalares são valores do tipo string, Date, Time, Boolean, number, ou Blob. Quando declarado, o seu valor por padrão não é indefinido nem nulo. Outros tipos (Ponteiro, Imagem, Objecto, Colecção) têm valor por defeito indefinido ou nulo. Ex:

var $object : Object
var $text : Text

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

Comparações com os operadores Maior que (>), Menor que (<), Maior ou igual a (>=), e Menor ou igual a (<=) não são suportados com valores Nulos e devolvem um erro.

Operadores indefinidos

OperaçãoSintaxeRetornaExpressionValor
IgualUndefined = UndefinedParâmetrosa.undefinedProp = b.undefinedPropTrue
Undefined = NullParâmetrosa.undefinedProp = c.nullPropTrue
Undefined = outros valoresParâmetrosa.undefinedProp = 42False
DesigualdadeUndefined # UndefinedParâmetrosa.undefinedProp # b.undefinedPropFalse
Undefined # NullParâmetrosa.undefinedProp # b.nullPropFalse
Undefined # outros valoresParâmetrosa.undefinedProp # 42True
Maior queUndefined > string, Date, Time, numberParâmetrosa.undefinedProp > "abc"False
Menor queUndefined < string, Date, Time, numberParâmetrosa.undefinedProp < "abc"False
Maior ou igual aUndefined >= string, Date, Time, numberParâmetrosa.undefinedProp >= "abc"False
Menor que ou igual aUndefined <= string, Date, Time, numberParâmetrosa.undefinedProp <= "abc"False

outros valores são expressões de qualquer tipo com um valor nem Indefinido nem Null.

info

Comparisons of Undefined values with Pointer, Picture, Boolean, Blob, Object, Collection, Undefined or Null values using Greater than (>), Less than (<), Greater than or equal to (>=), and Less than or equal to (<=) operators are not supported and return an error.

Exemplos

Aquí estão os diferentes resultados do comando Undefined assim como do comando Null com as propriedades dos objetos, dependendo do contexto:

C_OBJECT($vEmp)
$vEmp:=New object
$vEmp.name:="Smith"
$vEmp.children:=Null

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

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

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

Exemplos de resultados de comparação com valores indefinidos e nulos:

var $result : Booleano
var $vObj : Objecto
var $vVar : Variante

$vObj:=Novo objecto
$vObj.null:=Nulo
// nota que $vVar não está atribuído

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

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

$result:=($vObj.indefinido>"olá") //Falso
$result:=($vObj.indefinido>$vVar) //Error
$result:=($vObj.indefinido>$vObj.nulo) //Error
$result:=($vVar < 42) //Falso