Sophie

Sophie

distrib > Mandriva > 2008.1 > i586 > by-pkgid > 703d980c580707c382b4e43e25965bc5 > files > 10725

php-manual-pt_BR-5.2.4-1mdv2008.1.noarch.rpm

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<HTML
><HEAD
><TITLE
>Números de ponto flutuante</TITLE
><META
NAME="GENERATOR"
CONTENT="Modular DocBook HTML Stylesheet Version 1.79"><LINK
REL="HOME"
TITLE="Manual do PHP"
HREF="index.html"><LINK
REL="UP"
TITLE="Tipos"
HREF="language.types.html"><LINK
REL="PREVIOUS"
TITLE="Inteiros"
HREF="language.types.integer.html"><LINK
REL="NEXT"
TITLE="Strings"
HREF="language.types.string.html"><META
HTTP-EQUIV="Content-type"
CONTENT="text/html; charset=UTF-8"></HEAD
><BODY
CLASS="sect1"
BGCOLOR="#FFFFFF"
TEXT="#000000"
LINK="#0000FF"
VLINK="#840084"
ALINK="#0000FF"
><DIV
CLASS="NAVHEADER"
><TABLE
SUMMARY="Header navigation table"
WIDTH="100%"
BORDER="0"
CELLPADDING="0"
CELLSPACING="0"
><TR
><TH
COLSPAN="3"
ALIGN="center"
>Manual do PHP</TH
></TR
><TR
><TD
WIDTH="10%"
ALIGN="left"
VALIGN="bottom"
><A
HREF="language.types.integer.html"
ACCESSKEY="P"
>Anterior</A
></TD
><TD
WIDTH="80%"
ALIGN="center"
VALIGN="bottom"
>Capítulo 11. Tipos</TD
><TD
WIDTH="10%"
ALIGN="right"
VALIGN="bottom"
><A
HREF="language.types.string.html"
ACCESSKEY="N"
>Próxima</A
></TD
></TR
></TABLE
><HR
ALIGN="LEFT"
WIDTH="100%"></DIV
><DIV
CLASS="sect1"
><H1
CLASS="sect1"
><A
NAME="language.types.float"
>Números de ponto flutuante</A
></H1
><P
>&#13;    Números de ponto flutuante (AKA "floats", "doubles" ou "números reais") podem ser
    especificados utilizando qualquer uma das sintaxes seguintes:
    <DIV
CLASS="informalexample"
><P
></P
><A
NAME="AEN2982"
></A
><TABLE
BORDER="0"
BGCOLOR="#E0E0E0"
CELLPADDING="5"
><TR
><TD
><code><font color="#000000">
<font color="#0000BB">&lt;?php<br />$a </font><font color="#007700">= </font><font color="#0000BB">1.234</font><font color="#007700">; <br /></font><font color="#0000BB">$b </font><font color="#007700">= </font><font color="#0000BB">1.2e3</font><font color="#007700">; <br /></font><font color="#0000BB">$c </font><font color="#007700">= </font><font color="#0000BB">7E-10</font><font color="#007700">;<br /></font><font color="#0000BB">?&gt;</font>
</font>
</code></TD
></TR
></TABLE
><P
></P
></DIV
>
    Formalmente:
    <DIV
CLASS="informalexample"
><P
></P
><A
NAME="AEN2984"
></A
><TABLE
BORDER="0"
BGCOLOR="#E0E0E0"
CELLPADDING="5"
><TR
><TD
><code><font color="#000000">
LNUM&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;[0-9]+<br />DNUM&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;([0-9]*[\.]{LNUM}) | ({LNUM}[\.][0-9]*)<br />EXPONENT_DNUM ( ({LNUM} | {DNUM}) [eE][+-]? {LNUM})</font>
</code></TD
></TR
></TABLE
><P
></P
></DIV
>
    O tamanho de um número de ponto flutuante é dependente de plataforma,
    sendo o máximo de ~1.8e308 com uma precisão de 14
    decimais digitais um valor comum (número de 64 bits no formato IEEE).
   </P
><DIV
CLASS="warning"
><P
></P
><TABLE
CLASS="warning"
BORDER="1"
WIDTH="100%"
><TR
><TD
ALIGN="CENTER"
><B
><A
NAME="warn.float-precision"
></A
>Precisão de números de ponto flutuante</B
></TD
></TR
><TR
><TD
ALIGN="LEFT"
><P
>&#13;     É sabido que frações simples como
     <TT
CLASS="literal"
>0.1</TT
> ou <TT
CLASS="literal"
>0.7</TT
> não podem ser
     convertidos em sua representação binária interna sem uma
     pequena perda de precisão. Isto pode causar erros confusos: por
     exemplo, <TT
CLASS="literal"
>floor((0.1+0.7)*10)</TT
> irá retornar
     <TT
CLASS="literal"
>7</TT
> em vez do esperado
     <TT
CLASS="literal"
>8</TT
>, como resultado da representação interna
     realmente ser algo como <TT
CLASS="literal"
>7.9999999999...</TT
>.
    </P
><P
>&#13;     Isto está relacionado ao fato de que é impossível expressar,
     exatamente, algumas frações em notação decimal com um número finito
     de dígitos. Por exemplo, <TT
CLASS="literal"
>1/3</TT
> na forma decimal
     se torna <TT
CLASS="literal"
>0.3333333. . .</TT
>.
    </P
><P
>&#13;     Então, nunca confie em resultados com números de ponto flutuante até a última casa e
     nunca compare números de ponto flutuante em igualdades. Se você realmente
     precisar de alta precisão, você pode utilizar as <A
HREF="ref.bc.html"
>funções matemáticas de precisão arbitrária</A
>
     ou as funções relacionadas ao <A
HREF="ref.gmp.html"
>gmp</A
>.
    </P
></TD
></TR
></TABLE
></DIV
><DIV
CLASS="sect2"
><H2
CLASS="sect2"
><A
NAME="language.types.float.casting"
>Convertendo para float</A
></H2
><P
>&#13;     Para informações em como e quando strings são convertidas para floats,
     veja a seção entitulada <A
HREF="language.types.string.html#language.types.string.conversion"
>Conversão de
     Strings para números</A
>. Para valores de outros tipos, a conversão
     é a mesma se o valor puder ser convertido para inteiro
     e então para float. Veja a seção <A
HREF="language.types.integer.html#language.types.integer.casting"
>Convertendo
     para inteiro</A
> para mais informações.
    </P
></DIV
></DIV
><DIV
CLASS="NAVFOOTER"
><HR
ALIGN="LEFT"
WIDTH="100%"><TABLE
SUMMARY="Footer navigation table"
WIDTH="100%"
BORDER="0"
CELLPADDING="0"
CELLSPACING="0"
><TR
><TD
WIDTH="33%"
ALIGN="left"
VALIGN="top"
><A
HREF="language.types.integer.html"
ACCESSKEY="P"
>Anterior</A
></TD
><TD
WIDTH="34%"
ALIGN="center"
VALIGN="top"
><A
HREF="index.html"
ACCESSKEY="H"
>Principal</A
></TD
><TD
WIDTH="33%"
ALIGN="right"
VALIGN="top"
><A
HREF="language.types.string.html"
ACCESSKEY="N"
>Próxima</A
></TD
></TR
><TR
><TD
WIDTH="33%"
ALIGN="left"
VALIGN="top"
>Inteiros</TD
><TD
WIDTH="34%"
ALIGN="center"
VALIGN="top"
><A
HREF="language.types.html"
ACCESSKEY="U"
>Acima</A
></TD
><TD
WIDTH="33%"
ALIGN="right"
VALIGN="top"
>Strings</TD
></TR
></TABLE
></DIV
></BODY
></HTML
>