O tipo Float
Conversão para Float
Tecnicamente, a conversão de um valor para float ocorre convertendo-se o valor para integer e depois para float. A excessão ocorre apenas na conversão de string para float.
A conversão pode ser feita de duas maneiras:
1 - utilizando a função floatval;
2 - utilizando casting com uma das seguintes notações: (float), (double) ou (real).
Exemplos:
Int
Um valor inteiro convertido para real continua com o mesmo valor numérico, mas com a representação real.
Bool
O valor true é convertido para o real 1.0, enquanto o valor false é convertido para o real 0.0.
Array
Vetores vazios são convertidos para o real 0.0, enquanto os vetores não vazios são convertidos para o real 1.0.
String
A conversão de uma string para float é semelhante a que ocorre para o tipo integer. Tenta-se obter a maior porção da string (a partir do primeiro caractere da esquerda) que represente uma forma de criar um valor real na forma decimal. Isso também vale para a notação com expoente 10. Caso nenhuma porção possa ser convertida, então o valor é avaliado como zero. Veja alguns exemplos:
Object
Objetos não podem ser convertidos para real.
Tecnicamente, a conversão de um valor para float ocorre convertendo-se o valor para integer e depois para float. A excessão ocorre apenas na conversão de string para float.
A conversão pode ser feita de duas maneiras:
1 - utilizando a função floatval;
2 - utilizando casting com uma das seguintes notações: (float), (double) ou (real).
Exemplos:
$f = floatval('1'); $f = (float)'1'; $f = (double)'1'; $f = (real)'1';
Int
Um valor inteiro convertido para real continua com o mesmo valor numérico, mas com a representação real.
Bool
O valor true é convertido para o real 1.0, enquanto o valor false é convertido para o real 0.0.
Array
Vetores vazios são convertidos para o real 0.0, enquanto os vetores não vazios são convertidos para o real 1.0.
String
A conversão de uma string para float é semelhante a que ocorre para o tipo integer. Tenta-se obter a maior porção da string (a partir do primeiro caractere da esquerda) que represente uma forma de criar um valor real na forma decimal. Isso também vale para a notação com expoente 10. Caso nenhuma porção possa ser convertida, então o valor é avaliado como zero. Veja alguns exemplos:
$f = floatval("1.1a"); // $f = 1.1; $f = floatval("1.a"); // $f = 1.0; $f = floatval(".1a"); // $f = 0.1; $f = floatval("5e2"); // $f = 500.0; $f = floatval("1.1e1"); // $f = 11; $f = floatval("1.1e01"); // $f = 11; $f = floatval("-23.4e-1x"); // $f = -0.234; $f = floatval("3 4 5"); // $f = 3.0; $f = floatval("x1"); // $f = 0;
Object
Objetos não podem ser convertidos para real.
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?