ReviewDay1

一. 数据类型

1. 整型

  • int 32 位, 4 字节 (20亿)

  • byte 8 位, 1 字节

  • long 8 字节, short 2字节 (声明long型须加'l'or 'L')

2 浮点类型

  • float 32 位, 4 字节 (声明需要加 'f' or 'F')

  • double 64 位, 8 字节 (小数默认为double)

*正无穷大: Double.POSITIVE_INFINITY

*负无穷大: Double.NEGATIVE_INFINITY

*不是数字: Double.NaN

浮点数=符号位+指数位+尾数位

二进制无法精确表示 1/10 就好像十进制无法精确表示 1/3

如果数值计算中不允许有舍入误差,应用 BigDecimal 类,这不是基本Java类型,而是Java对象。

3 char 类型

  • ' ' 单引号括起来的单个字符

  • \u: 转义序列 \u

注释中的 \u

// \u000A is a newline

注释中的 \u000A 会被替换为一个换行符,从而产生语法错误

4 boolean 类型

  • ture / false

整形值不能和Boolean相互转换

二. 变量与常量

1. 声明: 变量类型 + 变量名

  • 大小写敏感

  • 不能用Java保留字

2. 变量初始化

  • 不能使用未经初始化的变量

  • 必须先用赋值语句对变量显式初始化

变量的声明尽量靠近变量第一次使用的地方

3. 常量

  • 关键字 final 指示常量

final 修饰的变量只能被赋值一次

4.枚举类型

三. 运算符

1. 算术运算符

  • +, -, *, /, %

整数除法只会保留整数部分如: 10/3 = 3

整数被 零除会产生异常, 浮点数被 零除将得到无穷大或 NaN

strictfp 修饰下的main所有指令都将使用严格的浮点计算

  • && 短路与:如果第一个条件为 false,则第二个条件不会判断,最终结果为 false,效率高

  • & 逻辑与:不管第一个条件是否为 false,第二个条件都要判断,效率低

  • || 短路或:如果第一个条件为 true,则第二个条件不会判断,最终结果为 true,效率高

  • | 逻辑或:不管第一个条件是否为 true,第二个条件都要判断,效率低

2. 数学函数与常量

  • Math 类
double x = 4;
Math.sqrt(x); // 数值平方根
double y = Math.pow(x, a); // 幂运算,x的a次幂

Math.floorMod() // 整数余数 %
Math.sin()
Math.cos()
Math.tan()
Math.atan()

Math.PI //最接近 pi 的常量
Math.E //最接近 e 的常量

Math.multiplyExcat(1000000000, 3) //会产生一个异常,而不是像数***算符一样返回错误的值

3. 类型转换

1.自动类型转换

  • 低精度自动向高精度转换,没有精度损失

  • 必要时,低精度会自动转换为高精度的类型

alt

alt

2.强制类型转换


double x = 9.997;
int nx = (int) x; //nx=9  强制类型装换通过截断小数部分将浮点转换为整型

/*
    若要对浮点数四舍五入,以得到最接近整数
    应用 Math.round() 方法
*/

int n = (int) Math.round(x); //round 方法返回的是 long 类型,仍需要 用 (int) 强转为 int 

x += 3.5 如果x是整型,3.5会被强转。即运算符右侧的类型与左侧不同,就会发生强制类型转换

x += 3.5 ==> x = (int) (x + 3.5)

三元运算符 true ? x : y; 类型会被转换为表达式中精度最高的类型

四. 字符串

创建String对象

方式一: 直接赋值

方式二: 调用构造器

*内存分布不一样

alt

1. 子串

substring(index, index)

2. 拼接

  • 可以使用 + 拼接 两个字符串

  • 将多个字符串放在一起,并用一个界定符分隔,可以用静态方法

String.join("/", str1, str2...)

3. 不可变字符串

  • 不能修改字符串中某一个字符

若要修改字符串,可以提取要保留的子串,再与希望替换的字符拼接

4. 判断字符串是否相等

str1.equals(str2) //不能用 == 判断,== 判断的是地址是否相等

equalsIgnroeCase() //忽略大小写

5. 码点与代码单元

  • 代码单元 即在具体编码形式中的最小单位。 比如,UTF-16 中,一个代码单元为 16 位,UTF-8 中一个代码单元为 8 位 一个代码点可能由一个或多个代码单元表示。 在 U+10000 之前的代码点可以由一个 UTF-16 代码单元表示, U+10000 及之后的代码点要由两个 UTF-16 代码单元表示 在Java中,char类型描述了 UTF-16 编码中的一个代码单元。

str.length() //返回utf-16编码表示给定字符串所需要的代码单元数量
str.chartAt(n) //返回位置n的代码单元
  • 码点 即代码点,在 Unicode 代码空间中的一个值,取值 0x0 到 0x10FFFF,代表一个字符。也就是一个编码表中的某个字符对应的代码值一个字符就是一个代码点,一个代码点由一个或多个代码单元组成。 Unicode的码点分为17个代码级别,第一个级别是基本的多语言级别,码点从U+0000——U+FFFF,其余的16个级别从U+10000——U+10FFFF,其中包括一些辅助字符。 基本的多语言级别,每个字符用16位表示代码单元,而辅助字符采用连续的一对连续代码单元进行编码。

str.codePointCount(0, str.length()) //返回字符串的实际长度,即码点数量 
str.codePointAt(n) //返回给定位置开始的码点

6. API

java.lang.String

  • char charAt()

  • int codePoint(int index)

  • int compareTo(other)

    按照字典顺序,如果字符串位于other之前,返回负数;之后返回正数;相等则返回零

  • int indexOf(str)

  • int lastIndexOf(str)

  • ......

6. 构建字符串

  • StringBuilder( ) //不是线程安全的
  • StringBuffer( ) //线程安全的

alt alt

五. 输入与输出

1. 读取输入

  • 标准输入流 :System.in (即控制台窗口)

    Scanner = new Scanner(System.in)

  • API:
    • String nextLine()

      读取下一行内容,允许空格,读到回车终止

    • String next()

      读取输入的下一个单词,以空格作为分隔符

    • int nextInt()

    • double nextDouble()

    • boolean hasNext()

    • boolean hasNextInt()

    • boolean hasNextDouble()

Scanner 类不适合从控制台读取密码,可以用Console实现 char[] passwd = System.console().readPassword("Password: ");

2. 输出

  • System.out.println()
  • System.out.println()
  • 格式化输出 System.out.printf("hello, %s. Next year, you will be %d", name, age)

3. 文件输入与输出

读取文件

  • Scanner in = new Scanner(Path.of("myfile.txt"), StandardCharsets.UTF_8)

    API:根据给定路径名构造一个Path

写入文件

  • PrintWriter out = new PrintWriter("myfile.txt", StandardCharsets.UTF_8)

    构造器中需要提供文件名和字符编码

注释:

用命令行启动程序时可以使用shell的重定向语法将文件关联到 System.in 和 System.out

java Project < inputFile.txt > outputFile.txt

*除了scanner, 还可以用 IO 流来处理文件