20165203《Java程序设计》第二周Java学习总结

时间:2023-02-26 17:02:18

教材学习内容总结


第二章

(一)标识符

注意:

  • 标识符由字母、下画线、美元符号和数字组成,长度不受限制。
  • 标识符第一个字符不能是数学字符。
  • 标识符不能是关键字。
  • 标识符不能是true、false和null。
  • 标识符中的字母区分大小写。

(二)基本数据类型(重点)

- [四大类型]

逻辑类型:boolean(与C语言不同)

整数类型:byte、short、int、long

字符类型:char

浮点类型:float、double

- [相关内容解析]

数据类型关键字 常量 变量 字节内存 数据范围
boolean true、false 使用boolean来声明
int 123,6000,077,0x3ABC 使用int来声明 4 -2^31~(2^31-1)
byte 一定范围内的int型常量 用byte来声明 1 -128~127
short 一定范围内的int型常量 使用short来声明 2 -2^15~2^15-1
long 用后缀L来表示,108L,07123L 使用long来声明 8 -2^63~2^63-1
char 用单引号括起来的Unicode表中的字符,'A','b' 使用char来声明 2(无符号位,且无负数char) 0~65535
数据类型 常量 变量 数据所分配字节 数据精度
float 用后缀f或F,不能省略,453.5439f,21379.987F 用float来声明 4 8位有效数字
double 可以有后缀d或D,但可以省略,2389.539d,2318908.987 用double来声明 8 16位有效数字

(三)数组

1.声明数组

一维数组:float boy [ ];

二维数组:char cat [ ][ ];

2.为数组分配元素

数组名=new 数组元素的类型[数组元素的个数]

boy = new float[4];

或 float boy[] = new float [4];

二维数组:

int mytwo[][];

mytwo = new int [3][4];

或 int mytwo [][] = new int [3][4];

3.数组元素的使用

索引从0开始:

4.length的使用

一维数组:“数组名.length"的值是数组中元素的个数

二维数组:“数组名.length”的值是它含有的一维数组的个数。

例如:float a[ ] = new float [12];

int b[][] = new int [3][6];

则a.length为12,b.length为3;

5.数组的初始化

float boy[] = {21.3f,23.89f,2.0f,2.3f,778.98f};

int a[][] = {{1},{1,1},{1,2,1},{1,3,3,1},{1,4,6,4,1}};

6.数组的引用(元素的首地址)

两个相同类型的数组如果有相同的引用,他们就会有完全相同的元素。


public class Example2_4 {
public static void main(String args[ ]) {
int a[] = {1,2,3,4};
int b[] = {100,200,300};
System.out.println("数组a的元素个数="+a.length);
System.out.println("数组b的元素个数="+b.length);
System.out.println("数组a的引用="+a);
System.out.println("数组b的引用="+b);
a=b;
System.out.println("数组a的元素个数="+a.length);
System.out.println("数组b的元素个数="+b.length);
System.out.println("a[0]="+a[0]+",a[1]="+a[1]+",a[2]="+a[2]);
System.out.print("b[0]="+b[0]+",b[1]="+b[1]+",b[2]="+b[2]);
}
}

(三)运算符与表达式

运算符 结合方向 注意
+ - 从左到右 优先级弱于乘除
* / % 从左到右 优先级强于加减
++x(--x) 先使x的值加1,再使用x的值 x++(x--) 先使用x的值,再使x的值加1

- 算术混合运算的精度
排序:byte short char int long fioat double

用法规则:

1.表达式中++有++double型数据++,就按double计算

2.表达式++最高精度是float型数据++,就按float型计算

3.表达式中++最高精度是long型整数++,就按long型计算

4.表达式中++最高精度低于int型整数++,就按int型计算

易错点:允许把不超过byte、short、char的取值范围的算术表达式的值赋给byte、short、char型变量

- 关系运算符

运算符 备注
> = 优先级强于==和!=
== != 优先级弱于以上

#### - 逻辑运算符 和 位运算符

逻辑运算符 备注
&& || ! 连接表达式时,表达式的结果必须为true或false
位运算符 备注
& | ~ ^ 注意逆运算仍然是^
易错点:注意逻辑运算符的短路性。

- 语句方面

  • Swith语句中“表达式”的值可以为byte、short、int、char型

  • case常量也是byte、short、int、char型,而且要互不相同

  • 循环语句:注意与break和continue的结合性

  • for语句与数组:

    形式:for(声明循环变量:数组名字) {

    p

    }

    注意:“声明环境变量”必须是变量声明,不可以是使用已经声明过的变量。

- 关于类的调用方法:

因为还没有具体接触,谈一些自己的理解:

调用next类的话,是为了读取用户输入的值。

调用hasNext类的话,是为了判断值是否超出范围。

教材学习中的问题和解决过程

在学习应用举例时,对于比较排序法和折半查找法有所忘记,我细查了一下。

折半查找法

比较排序法

在课下,我还想把具体C语言中学到的查找方法和排序方法总结一下。

代码调试中的问题和解决过程

Q1:出现了

20165203《Java程序设计》第二周Java学习总结

A:运行时,应为java <主类名>,且主类名不要加后缀。随后便出现了结果

20165203《Java程序设计》第二周Java学习总结

Q2:出现了

20165203《Java程序设计》第二周Java学习总结

A:import java.util.*中util错拼成了until.而且两次出现了这样的问题,以后应引起重视。解决后,运行出正确结果:

20165203《Java程序设计》第二周Java学习总结

代码托管

脚本运行截图

20165203《Java程序设计》第二周Java学习总结

其他(感悟、思考等,可选)

本周学习是Java的语法学习,虽然有了一定的C语言基础,但是我还是没有掉以轻心,仔细回忆Java语法与C语言语法的相同点和不同点,并找出了自己C语言的一些漏洞。

可以说本周收获颇丰,不仅巩固了C语言的基础,而且还了解了Java语法,在自己尝试编程时,自己动脑来设计算法,有时,自己也会尝试将原来C语言的练习题用Java语言进行编程,自己仿佛找到了开启另一扇大门的钥匙,希望自己继续努力吧。

参考资料

折半查找法

比较排序法