Java 基本数据类型

jkog3302 8年前
   <p>Java中有以下几种基本数据类型,这些类型都是值类型。</p>    <table>     <thead>      <tr>       <th>类型</th>       <th>值范围</th>       <th>大小</th>       <th>范围</th>      </tr>     </thead>     <tbody>      <tr>       <td>boolean</td>       <td>true或false</td>       <td>1位</td>       <td> </td>      </tr>      <tr>       <td>char</td>       <td>Unicode字符</td>       <td>16位</td>       <td>'\u0000'~'\uFFFF'</td>      </tr>      <tr>       <td>byte</td>       <td>有符号整数</td>       <td>8位</td>       <td>-128~127</td>      </tr>      <tr>       <td>short</td>       <td>有符号整数</td>       <td>16位</td>       <td>-32768~32767</td>      </tr>      <tr>       <td>int</td>       <td>有符号整数</td>       <td>32位</td>       <td>-2^31~2^31-1</td>      </tr>      <tr>       <td>long</td>       <td>有符号整数</td>       <td>64位</td>       <td>-2^63~2^63-1</td>      </tr>      <tr>       <td>float</td>       <td>IEEE 754浮点数</td>       <td>32位</td>       <td>1.4E-45~3.4028235e+38</td>      </tr>      <tr>       <td>double</td>       <td>IEEE 754浮点数</td>       <td>64位</td>       <td>4.9E-324~1.7976931348623157E+308</td>      </tr>     </tbody>    </table>    <h2>布尔类型</h2>    <p>boolean是布尔类型,用来表示逻辑真值,只有两个值,真和假。而且不能和其他基本类型进行类型转换,主要作用是在条件和判断语句中作为判断条件。</p>    <p>各种基本类型的值可以直接出现在程序中,这样的值叫做 <strong>字面量</strong> 。对于布尔类型来说,字面量只有 true 和 false 两个。</p>    <pre>  <code class="language-java">boolean condition = true;    if(condition)  {  ...  }</code></pre>    <h2>字符类型</h2>    <p>char也就是字符类型,用来表示一个Unicode字符。除了可以使用普通字符外,还可以使用各种转义字符以及Unicode转义序列与一些非打印字符。字符类型的字面量,必须使用单引号 ' 包裹起来。</p>    <pre>  <code class="language-java">char c = 'A';  char tab = '\t';  char nul = '\000';</code></pre>    <table>     <thead>      <tr>       <th>转义字符</th>       <th>含义</th>      </tr>     </thead>     <tbody>      <tr>       <td>\b</td>       <td>退格符</td>      </tr>      <tr>       <td>\t</td>       <td>水平制表符</td>      </tr>      <tr>       <td>\n</td>       <td>换行符</td>      </tr>      <tr>       <td>\f</td>       <td>换页符</td>      </tr>      <tr>       <td>\r</td>       <td>回车符</td>      </tr>      <tr>       <td>\"</td>       <td>双引号</td>      </tr>      <tr>       <td>\'</td>       <td>单引号</td>      </tr>      <tr>       <td>\\</td>       <td>反斜杠</td>      </tr>      <tr>       <td>\xxx</td>       <td>Latin-1字符,其中xxx是八进制数</td>      </tr>      <tr>       <td>\uxxxx</td>       <td>Unicode字符,其中xxxx是十六进制数</td>      </tr>     </tbody>    </table>    <p>char类型和其他数字类型可以互相转换。但是转换之后的意义可能会发生变化。另外需要说一点,在Java中,对于Unicode转义序列的处理和其他语言有些不同。在Java源代码中的任意位置,都可以使用Unicode转义序列,甚至是关键字都可以。</p>    <h2>整数类型</h2>    <p>Java中有 byte 、 short 、 int 、 long 四中整数类型,它们的主要区别在于表示范围的不同。由于现在计算机性能和存储空间都有了极大的增长,所以 byte 和 short 两种类型已经很少用了,一般情况下都使用 int 类型,只有当 int 类型不够的时候才使用 long 类型。</p>    <p>有过C语言学习经验的同学可能知道C语言中有一个 unsigned 关键字,表示无符号类型,但是在Java中没有这个关键字。这就意味着,Java中的所有整数,都是有符号整数。</p>    <pre>  <code class="language-java">byte b = 10;  short s = 50000;  int i = 12345678;  long l = 1234567890;</code></pre>    <table>     <thead>      <tr>       <th>整数字面量</th>       <th>含义</th>      </tr>     </thead>     <tbody>      <tr>       <td>5000</td>       <td>普通数字,看做 int 字面量</td>      </tr>      <tr>       <td>5000L</td>       <td>后缀 l 或 L , long 字面量</td>      </tr>      <tr>       <td>0b0001</td>       <td>前缀 0b ,二进制数字,即十进制的1</td>      </tr>      <tr>       <td>0007</td>       <td>前缀 0 ,八进制数字,即十进制的1</td>      </tr>      <tr>       <td>0xff</td>       <td>前缀 0x 或 0X ,十六进制数字,即十进制的255</td>      </tr>     </tbody>    </table>    <p>另外,在整数字面量中还可以使用下划线增强可读性,下划线会被程序忽略,不影响数字的值。由于八进制数字以0作为前缀,容易引起混淆,因此在程序中应避免使用。</p>    <p>在Java中使用整数类型,应注意其范围,避免产生溢出等情况。如果数据溢出,就会出现回绕情况。例如</p>    <pre>  <code class="language-java">byte a = 127;  byte b = 1;  byte sum = (byte)(a + b); //结果为-128,发生回绕</code></pre>    <h2>浮点数类型</h2>    <p>浮点数即小数,由于在计算机中存储的时候位数是固定的,而小数点会发生移动,因此得名浮点数。在Java中有 float 和 double 两种类型。 float 是单精度浮点数,有至少6位有效数字。 double 是双精度浮点数,至少有15位有效数字。</p>    <pre>  <code class="language-java">float f = 12.34F;  double d = 123.456;  d = 1.23E5;</code></pre>    <p>需要注意默认情况下浮点数被认为是 double 型字面量,如果想要使用 float 型字面量,需要添加 f 或 F 后缀。另外,还可以使用科学计数法表示浮点数。</p>    <p>注意,由于二进制数和十进制数无法进行精确转换,所以Java中的float和double都是近似的,在进行计算的时候需要格外小心,避免产生无法预料的后果。</p>    <h2>类型转换</h2>    <p>除了布尔类型之外,其余所有的基本类型之间都可以进行互相转换。在转换的时候需要注意数字的范围,如果由小范围向大范围转换,数字精度不会丢失,这样的转换就可以直接进行,称作隐式转换。如果由大范围向小范围转换,数字精度会丢失,这样的转换默认情况下不允许进行。这种情况下需要使用强制类型转换,在要转换的数字前面添加一对括号和要转换的类型,这叫做显式转换。</p>    <pre>  <code class="language-java">byte small = 12;  int big = 300;  big = small; //小范围向大范围转换  small = (byte) big; //大范围向小范围转换,需要强制类型转换</code></pre>    <p>浮点数转换成整数的时候,小数部分会被直接截取。</p>    <pre>  <code class="language-java">int i = 10;  double d = 12.34;  i = (int) d; //现在是12,小数部分被丢弃</code></pre>    <p> </p>    <p>来自:http://www.jianshu.com/p/1097f44781f0</p>    <p> </p>