O tipo Float
Curiosidades
A função "is_numeric" é útil para avaliar se uma string pode ser convertida para float sem precisar ignorar caracteres.
As funções "is_double" e "is_real" são apenas nomes alternativos para a função "is_float". Prefira utilizar "is_float" pois versões futuras de PHP prometem remover "funções apelido".
O casting utilizando (double) ou (real) são formas alternativas para o casting usando (float). Prefira usar (float).
Quando uma expressão matemática envolve um operando float, o resultado é retornado na forma de float. Exemplos:
A função "is_numeric" é útil para avaliar se uma string pode ser convertida para float sem precisar ignorar caracteres.
As funções "is_double" e "is_real" são apenas nomes alternativos para a função "is_float". Prefira utilizar "is_float" pois versões futuras de PHP prometem remover "funções apelido".
O casting utilizando (double) ou (real) são formas alternativas para o casting usando (float). Prefira usar (float).
Quando uma expressão matemática envolve um operando float, o resultado é retornado na forma de float. Exemplos:
$f = 1 + 1.2; // $f é float (2.2) $f = 1 + '1.0'; // $f é float (2.0) $f = 1 + (float)1; // $f é float (2.0)
Artigo muito didático. Excelente para iniciantes em programação entenderem sobre os tipos primitivos da linguagem.
Complementando as infos:
O tamanho máximo de um número de ponto flutuante é dependente de plataforma (S.0. e arquitetura), sendo o máximo de 1.8e308 com uma precisão de 14 decimais (número de 64 bits no formato IEEE).
Isto o torna quase que obrigatório quando se trabalha com números inteiros muito grandes.
Por exemplo, alguns desenvolvedores utilizam um campo Inteiro do MySQL para armazenar CNPJ (eu não aconselho) porém ele ultrapassa o maior valor para o Inteiro no PHP em sistemas de 32 bits. Nesse caso o Float pose ser usado tranquilamente pois seu limite é superior.
Notem que é extremamente importante estar ciente dos problemas de precisão, como foi salientado, principalmente para sistema que calculem taxa de juros por exemplo.
Além da extensão BC (que no Windows é ativada por padrão mas precisa ser ativada no Linux) tem também a extensão GMP que usa a biblioteca GNU MP. Esta última precisa ser ativada tanto em Windos quanto em Linux.
Complementando as infos:
O tamanho máximo de um número de ponto flutuante é dependente de plataforma (S.0. e arquitetura), sendo o máximo de 1.8e308 com uma precisão de 14 decimais (número de 64 bits no formato IEEE).
Isto o torna quase que obrigatório quando se trabalha com números inteiros muito grandes.
Por exemplo, alguns desenvolvedores utilizam um campo Inteiro do MySQL para armazenar CNPJ (eu não aconselho) porém ele ultrapassa o maior valor para o Inteiro no PHP em sistemas de 32 bits. Nesse caso o Float pose ser usado tranquilamente pois seu limite é superior.
echo sprintf("%f",99999999999999 + 9);
Além da extensão BC (que no Windows é ativada por padrão mas precisa ser ativada no Linux) tem também a extensão GMP que usa a biblioteca GNU MP. Esta última precisa ser ativada tanto em Windos quanto em Linux.
08/03/2010 2:49pm
(~14 anos atrás)
Muito bom artigo. Mostra como é importante conhecermos a fundo a linguagem PHP afim de desenvolvermos aplicações consistentes. A conversão automática de um tipo de variável para outro pode ocasionar erros de cálculos difíceis de identificar. Ficar a par destes detalhes nos ajuda a desenvolver com mais qualidade.
18/01/2010 9:19pm
(~15 anos atrás)
$x=14 ou 1110
$y=12 ou 1100
RESULTADOS
EXPRESSÃO BASE 2 BASE 10
~$x 0001 1 (Não entendi porque deu 1)
$x&$y 1100 12 (Não entendi porque deu 12)
$x|$y 1110 14 (Não entendi porque deu 14)
$x^$y 0010 2 (Não entendi porque deu 2)
$x>>2 0011 3 (Não entendi porque deu 3)
$x<<2 111000 56 (Não entendi porque deu 56)
Alguém pode me ajudar?