2022-7-13 java 第七组 刘昀航


@

目录


前言

java历史:

—1991 年Sun公司的James Gosling等人开始开发名称为 Oak 的语言。希望用于控制嵌入在有线电视交换盒、PDA等的微处理器
1994年将Oak语言更名为Java
1998年JDK1.2时,更名为Java 2 Platform
分为标准版J2SE,企业版J2EE,微型版J2ME
Java 既安全、可移植,又可跨平台,而且人们发现它能够解决Internet 上的大型应用问题
Internet使Java成为网上最流行的编程语言
Java对Internet的影响也意义深远
B/S的兴起 & C/S的没落

一、一些基本的指令

windows基本操作指令

二、java

1.java的三个版本

JavaSE:做桌面应用程序,java基础
JavaEE: 企业级应用
JavaME: 手机端,,淘汰

2.java特点

Java特点

3.运行一个java程序

public class a1 {

    public static void main(String[] args) {
        System.out.println("hello");
    }

}

步骤:

  1. 打开cmd
  2. 打开对应的文件位置
  3. javac 文件名.java
  4. java 文件名

运行结果:
运行结果

三、java的数据类型

1.java基本数据类型

数据类型 名称 字节数 位数 范围
byte: 字节型 1个字节 8位 [-128,127]
short:: 短整型 2个字节 16位 [-215,215-1]
int: 整形 4个字节 32位 [-231,231-1]
long 长整形 8个字节 64位
float 单精度 4个字节 32位
double 双精度 8个字节 64位

注意:
1.tinyint一般用于性别的数据类型

2.在java语言中整数型字面值默认当做int类型,如果想让整数型字面值被当做long类型,需要在字面值后面添加l/L,一般多用L。

  
在这里插入图片描述

  报错的原因是 自动将字面值当做int类型来处理,而2147483648已经超出了int的范围,所以需要将它标识为其他的能容纳它的类型。

  在这里插入图片描述

2.强制转换的原理

2.强制转换的原理

  以long 类型强制转换为int类型为例,假设有一个long类型的数据是 00000000 00000000 00000000 00000000 00000000 00000000 00000000 01100100,

  将它强转为int,就是直接将long类型的前四个字节砍掉,只拿后面的四个字节。00000000 00000000 00000000 01100100。

  所以,强制类型转换需谨慎,有可能会丢失精度。
在这里插入图片描述

  

  上例:解剖  (计算机存储数据是以二进制补码的形式存储  正数的补码和源码相同,负数的补码 是负数的绝对值对应的二进制码 对位取反再+1)

  2147483648L 的二进制是  00000000 00000000 00000000 00000000 10000000 00000000 00000000 00000000

  强制类型转换后得到的是  10000000 00000000 00000000 00000000  (砍掉前4个字节)

  也就是说  10000000 00000000 00000000 00000000  这是原数据的补码形式  补码求源码

  先减1    01111111 11111111 11111111 11111111

  对位取反  10000000 00000000 00000000 00000000 

  所以源码是 10000000 00000000 00000000 00000000  2147483648

  而补码的符号位是1(首位),则表示该数据是负数,所以原数据是  -2147483648

  2147483648L是long类型,8个字节,符号位是0,所以对于long类型来说2147483648L是正数

  在这里插入图片描述

  按道理说整形字面值赋值给byte,大专小需要强制类型转换,但是编译通过,而128编译报错,说明底层字面值只要在byte范围内是不需要认为强制类型转换的,此时要纠正错误就需要强制类型转换。

  在这里插入图片描述

  具体还原过程以及计算结果

  在这里插入图片描述

  char类型尝试

    常见的一些字符的ASCII码 A–>65,a–>97,数字0–>48(其他数字或字符都是依次递增)
在这里插入图片描述
  
  double和float

    带小数的值默认是double 类型,double类型的字面值赋值给float类型变量,大转小需要强制类型转换,所以编译报错

在这里插入图片描述

    解决办法

      1.强制类型转换为float

      在这里插入图片描述

      2.将字面值标识为float类型

     在这里插入图片描述

3.八种基本数据类型之间的转换规则

 1、八种基本数据类型除了boolean外,其他的都能相互转换。

 2、小容量可以自动向大容量转换,即自动类型转换。容量大小如下

    byte<<short(char)<<int<<long<<float<<double

注意:

  1、不管浮点型占几个字节,其容量都比整形大

  2、char和short表示的种类不同,但是char可以取到更大的正整数

  3、强制类型转换慎用,因为有可能会丢失精度

  4、当一个整数字面值没有超过byte,short,char类型的取值范围时,可以直接复制给byte,short,char类型,此时的转换机制底层帮我们完成了,目的是方便程序员开发

  5、byte,short、char运算时,先转换成int后,再参与运算。

  6、多种数据类型混合运算时,先转换成参与运算中最大的数据类型后,再进行计算。

原创文章,作者:1402239773,如若转载,请注明出处:https://blog.ytso.com/274142.html

(0)
上一篇 2022年7月13日
下一篇 2022年7月13日

相关推荐

发表回复

登录后才能评论