对应网课为:【黑马程序员Java+AI智能辅助编程全套视频教程,java零基础入门到大牛一套通关】
项目代码地址如下(如果对你有帮助请给我一个免费的star):
gitcode链接(无需梯子)https://gitcode.com/CherryTaylor/AboutJava_first
github链接https://github.com/CarrieChai/AboutJava_first
Day02-基础语法
一 方法
方法:是用于执行特定任务或操作的代码块,可以接收数据进行处理并返回一个处理的结果
方法的定义如下
//修饰符 返回值类型 方法名(参数列表){
// 方法体代码(执行功能)
// return 返回值;
//}
定义一个方法一般考虑两方面:是否需要接收数据和是否需要返回数据
方法必须调用才可以执行,调用格式如下
//方法名称(参数1,参数2……)
注意事项
方法重载:一个类中,出现多个方法的方法名相同,但是参数列表不同,成为方法重载
无返回值的方法中可以通过单独使用return来提前结束当前方法的执行
二 类型转换
顾名思义,就是将一种数据类型的变量转化为另一种数据类型
为什么需要这个技术?为了兼容,有时需要将不同类型的数据进行操作,其次考虑到多态,类型转换允许父类引用指向子类对象
- 自动类型转换
类型范围小的变量,可以直接赋值给类型范围大的变量
比如 byte 转成 int 或者 int 转成 double - 强制类型转换
类型范围大的变量转换为类型范围小的变量可能会导致数据溢出,所以不能自动转换
需要强制类型转换
数据类型2 变量2 = (数据类型1)变量1/数据
数据类型2是类型范围大的目标数据类型
数据类型1是类型范围小的原本的数据类型
int i = 100;
// byte b1 = i; // 范围大的变量不可以直接赋值给范围小的变量
byte b1 = (byte)i;// 强制转换
System.out.println(b1);// 100
int i1 = 130;
byte b2 = (byte)i1;
System.out.println(b2); //-126 数据溢出了
double d1 = 100.99;
int i2 = (int)d1;
System.out.println(i2);// 100 double直接赋值给int只保留整数部分
注意:
- 强制类型转换可能会导致数据溢出
- 小数强制转换为整数时会截断小数保留整数
表达式的类型转换
小范围的类型会自动转换成大范围的类型参与运算
byte、short、char --> int -->long -->float -->Double
表达式的最终类型由表达式中范围最大的类型决定
byte short char是直接转换成int类型参与运算的
三 输入输出
输出:把程序中的数据展示出来
System.out.println("Hello World!")
输入:程序读取用户键盘输入的数据 通过Java提供的Scanner实现
- 从哪儿找Scnner呢?
- Java提供的API里
-
API是什么?API(Application Programming Interface)是应用程序编程接口,也就是Java写好的、可以直接调用的程序
四 运算符
1 基本运算符
+ - * / %
+ 符号有些时候可以做连接符,+符号与字符串运算的时候是用作连接符,结果仍然是一个字符串【基本上就是能算的时候就算加法,不能算的时候就连接在一起】
public static void print2(){
int a = 5;
System.out.println("abc"+a);
System.out.println(a+5);
System.out.println("yigezifuchuan"+a+'a'); // "yigezifuchuan"+5(目前为止已经不能运算了 所以连在一起形成一个新的字符串
System.out.println(a+'a'+"yigezifuchuan"); // 5+97(a的ASCII码)+"yigezifuchuan"
}
2 自增自减运算符
比如
int a=10
这个时候 a++或者++a a都为11
a–或者–a a都为9
自增和自减符号放到前面和后面有很大区别
b = ++a 表示先自增,即a从10变成11,然后再赋值,即b=11
b = a++ 表示先赋值,即b = a = 10,然后再a自增,即a 变成11
自减也是类似的
不只是赋值操作,其他操作也是这样,比如输出(打印)
public static void print() {
int a = 10;
System.out.println(a++); // 10
System.out.println(a); //11
System.out.println(++a); //12
System.out.println(a); //12
int b = 10;
System.out.println(b--); //10
System.out.println(b); //9
System.out.println(--b);//8
System.out.println(b);//8
}
3 赋值运算符
就是‘=’ 程序中的赋值要从右往左看
例如 b = a+1 这个代码的意思就是把a+1的值赋值给b
扩展赋值运算符 Day02OperatorDemo3
扩展运算符(以a+=b为例),一方面是 a+b的值赋值给a 另一方面是a+b的结果强制转换成a的类型,换句话说 a+=b运行之后a的数据类型是不会改变的
byte a = 10;
byte b = 15;
a += b;
//正常情况下两个byte数据类型的数据求和是会自动转换为int类型的
//但是这里使用扩展赋值运算符,所以a的数值变成(a+b)的值,a的数据类型也还是byte
4 关系运算符、三元运算符
关系运算符 Day02OperatorDemo4
三元运算符 Day02 OperatorDemo5
// 条件表达式 ? 表达式1 : 表达式2
// 如果条件表达式为真,则返回表达式1的值,否则返回表达式2的值
5 逻辑运算符
Day02 OperatorDemo6
一个项目实战 健康计算器