硬核Java SE 基础语法知识点 C语言极快转Java
目录
13.3 InputStreamReader和BufferedReader方法
1、Java程序基础
1.1 JDK和JRD
JDK=JRE Java开发工具;
JRD=JVM Java核心类库;
1.2 命令行操作
cd md创建文件目录;
cd rd删除;
cd del删文件;
cd ..返回上一级;
cd /跳转目录;
1.3 pubilic class
类名-->与文件名一致;
1.4 字节码文件
编译后生成字节码文件(.class)有几个类生成几个;
2、标识符
2.1 标识符的组成
数字、字母、下划线、美元符号(可以是中文),
与C语言相同首字符不能以数字开头;
与C语言相比,标识符的组成多了一个美元符号;
2.2 遵守驼峰命名方式
e.g. SytemService、UserService;
2.3 类名、接口名:
首字母大写,后面每个单词首字母大写;
2.4 变量名、方法名:
首字母小写,后面每个单词首字母大写;
2.5 常量名:
全部大写;
//与C语言的常量不同 字面值(数据)看见字知其数据;
e.g.10.100,3.14,"abc",'a',ture、false(布尔型);
3、关键字
关键字要小写
public、class、static、void......
4、变量与常量
4.1 变量
Java中变量必须声明再赋值才能访问(否则内存未开辟出来);
变量必须初始化;
4.2 常量
常量有final关键字修饰;
5、boolean类型
5.1 布尔类型的值
boolean类型只有ture false 没有其他值;
5.2 布尔类型占用的字节数
boolen类型只占用1个字节;
5.3 布尔类型的底层表示和定义
不像C语言有0、1表示假和真;
底层false为0,ture为1;
定义:boolean i = true;
6、byte类型
byte类型表示8位带符号的二进制数;
7、char类型
7.1 char类型占有字节数
char类型在java中占2个字节;
7.2 char类型与short类型
char和short可表示的种类数量相同,但char可取更大的正整数;
8、float类型与double类型
java中无float类型,定义float类型时,在浮点数后 f;
否则认为是double类型,编译失败;
9、类型转换
1、布尔类型无法强制转换;
2、Java:高精度赋值给低精度时需要强制转换,否则编译错误,显示不兼容的类型,高精度到低精度会造成损失精度;e.g.long-->int
3、C语言:高精度赋值给低精度时,会有精度缺失,但不会造成编译失败;
4、Java和C语言:低精度赋值给高精度(小容量-->大容量) 自动转换,不存在精度损失;e.g. int-->long
5、当整数字面值未超过byte、short、char的取值范围可以直接赋值给byte、short、char;
6、byte、short、char混合运算时,先各自转换成int;
-
byte b=10;
-
b=b 5;
-
System.out.println(b);
编译报错,因为(b 5自动转换成了int类型,所以要想通过编译,需要加强制转换)
-
byte b=10;
-
b=(byte)(b 5);
-
System.out.println(b);
7、多种数据类型混合运算时,先转换成容量最大的类型;
8、long类型在后面 'L',long 10L,L用来判断是否为long类型;
9、float表示离散、有限、舍入误差、大约、接近不等于、0.1!=0.1,c=c 1;
需要完全避免用浮点数比较大小;
10、
-
int i = 128;
-
byte b=(byte) i;
输出为-127(因为有溢出);
11、JDK新特性
数字之间可以用下划线分隔,更清楚分辨位数;
e.g.10_0000_0000
10、类的定义
10.1 语法结构
[修饰符列表] class 类名{
}
String不属于基本数据类型,是一个字符串类型,也是一个引用类型;
引用数据类型还包括:类,接口,数组;
String是SUN在JavaSE中提供的字符串类型;
String.class字节码文件;
重点:
1、属性通常是采用一个变量的形式来完成定义的;
2、在类体当中,方法体之外定义的变量被称为"成员变量",成员变量没有赋值,系统赋默认值:一切向0看齐;
10.2 基本数据类型
byte、short、int、long、float、double、boolean、char;
10.3 引用数据类型
String.class SUN提供的;
System.class SUN提供的;
Student.class 程序员自定义的(是一个类,类型,引用数据类型);
11、逻辑运算符(布尔运算符)
& 逻辑与
| 逻辑或
!逻辑非(取反)
^ 逻辑异或(两边的算子只要不一样,结果就是ture)
&& 短路与
|| 短路或
1、逻辑运算符要求两边的算子都是布尔类型,并且逻辑运算符最终的运算结果也是一个布尔类型;
2、“短路与(或)”和“逻辑与(或)”最终的结果相同,只不过“短路与(或)”存在短路现象
11.1 逻辑与&
&左边无论是true还是flase都会计算右边;
-
int x=10;
-
int y=8;
-
System.out.println(x < y & x < y);
-
System.out.println(x);
运行结果为11
11.2 短路与&&
&&左边若为false则直接短路,右边不再计算(短路现象);
-
int x=10;
-
int y=8;
-
System.out.println(x < y && x < y);
-
System.out.println(x);
运行结果为10
从某个角度来看,短路与更智能,效率更高;
12、运算符
12.1 赋值运算符
=、-=、*=、/=、%=;
byte、short、char混合运算时,先各自转换成int;
-
byte b=10;
-
b=b 5;
-
System.out.println(b);
编译报错,(b 5自动转换成了int类型,所以要想通过编译,需要加强制转换或者使用b =5)
-
byte b=10;
-
b=(byte)(b 5);
-
b =5;
-
System.out.println(b);
以上述例子为例
b =5和b=b 5并不等同;
b =5与b=(byte)(b 5)是等同的;
结论:
扩展类的赋值运算符不改变运算结果类型,假设最初这个变量的类型是byte类型,无论怎么进行追加或追减,最终该变量的数据类型还是byte类型,但有可能会损失;
12.2 字符串连接运算符
关于java中" "运算符:
1、 运算符在java语言当中有两个作用:
*加法运算,求和;
*字符串的连接运算;
2、" "两边的数据都是数字的话一定是加法运算;
3、" "两边的数据只要有一个数据是字符串,一定会进行字符串的连接运算,连接运算之后的结果还是一个字符串类型;
静态输出
e.g.System.out.println(10 20);//30
System.out.println(10 20 "30");//"3030"
System.out.println(10 (20 "30");//"102030"
System.out.println("10 20=" a b);
"10 20="是字符串;
"10 20=" a先运算字符串 a等于个字符串"10 20=10";
"10 20=" a b再运算 b等于个字符串"10 20=1020";
System.out.println("10 20=" (a b));
此时先运算(a b)=30,在进行字符串"10 20=" 30="10 20=30";
动态输出
System.out.println(a " " b "=" (a b));
12.3 三元运算符/三目运算符/条件运算符
e.g.1
10,'男'不是一个完整的java语句;
-
boolean sex=false;
-
sex ? '男' : '女';
编译会报错;
修改如下:
-
boolean sex=false;
-
char c = sex ? '男' : '女';
-
System.out.println(c);
e.g.2
-
boolean sex=false;
-
char c = sex ? "男" : '女';
-
System.out.println(c);
编译报错,类型不兼容,但可以直接用
System.out.println(sex ? "男" : '女');
13、用户控制端输入
第一步:创建键盘扫描器对象
java.util.scanner s = new java.util.Scanner(System.in);
第二步:调用Scanner对象的next()方法开始接收用户键盘输入
敲完回车键 键入的信息会自动赋值给标识符
String userInputContent = s.next();
【以字符串的形式接收】
int num = s.nextInt();
【以整型的形式接收】
//标识符的命名规范:见名知意
13.1 Scanner类中的方法
-
优点一: 可以获取键盘输入的字符串 ;
-
优点二: 有现成的获取int,float等类型数据,非常强大,也非常方便;
-
Scanner s = new Scanner(System.in);
-
System.out.println("ScannerTest, Please Enter Name:");
-
String name = sc.nextLine(); //读取字符串型输入
-
Scanner s = new Scanner(System.in);
-
System.out.println("ScannerTest, Please Enter Age:");
-
int age = sc.nextInt(); //读取整型输入
-
Scanner s = new Scanner(System.in);
-
System.out.println("ScannerTest, Please Enter Salary:");
-
float salary = sc.nextFloat(); //读取float型输入
-
Scanner s = new Scanner(System.in); System.out.println("Your Information is as below:");
-
System.out.println("Name:" name "\n" "Age:" age "\n" "Salary:" salary);
13.2 System.in和System.out方法
-
缺点一: 该方法能获取从键盘输入的字符,但只能针对一个字符的获取
-
缺点二: 获取的只是char类型的。如果想获得int,float等类型的输入,比较麻烦。
-
try{
-
System.out.print("Enter a Char:");
-
char i = (char)System.in.read();
-
System.out.println("Yout Enter Char is:" i);
-
}
-
catch(IOException e){
-
e.printStackTrace();
-
}
13.3 InputStreamReader和BufferedReader方法
-
优点: 可以获取键盘输入的字符串
-
缺点: 如何要获取的是int,float等类型的仍然需要转换
-
System.out.println("ReadTest, Please Enter Data:");
-
InputStreamReader is = new InputStreamReader(System.in); //new构造InputStreamReader对象
-
BufferedReader br = new BufferedReader(is); //拿构造的方法传到BufferedReader中
-
try{ //该方法中有个IOExcepiton需要捕获
-
String name = br.readLine();
-
System.out.println("ReadTest Output:" name);
-
}
-
catch(IOException e){
-
e.printStackTrace();
-
}
13.4 nextLine( )和next( )的区别
nextLine( )方法返回的是Enter键之前的所有字符,它是可以得到带空格的字符串的。 next( )会自动消去有效字符前的空格,只返回输入的字符,不能得到带空格的字符串。
14、方法
14.1 方法的定义,语法结构
[修饰符列表] 返回值类型 方法名(形式参数列表){
方法体;
}
注意:
1)修饰符列表可选项,不是必须的,目前统一写成public static;
2)方法内的修饰符列表当中有static关键字时,调用方法:类名.方法名(实际参数列表);当方法在该类中时,"类名."可以省略;
3)方法名:首字母小写,后面每个字母大写,遵循驼峰规则;
4)建议一个源文件当中只定义一个class,比较清晰;
14.2 方法在执行过程中,JVM内存的分配和变化
14.2.1 方法的定义和执行:
方法只定义,不调用是不会执行的,并且在JVM中也不会给该方法分配"运行所属"的内存空间;只有调用的时候才会分配所属的内空间;
14.2.2 JVM内存划分上主要的内存空间:
方法区内存、堆内存、栈内存(还有其他的内存空间);
14.2.3 栈数据结构 :
*栈:stack,是一种数据结构;
*数据结构是数据的存储形态;
*常见的数据结构:数组、队列、栈、链表、二叉树、哈希表/散列表;
14.2.4 方法代码文件的存储位置,内存的分配位置:
1)方法代码片段属于.class字节码文件的一部分,字节码文件在类的加载的时候,将其放到了方法区当中。所以JVM中的三块主要的内存空间中方法区内存最先有数据。存在了代码片段;
2)代码片段虽然在方法区当中只要一份,但是可以重复调用。每一次调用这个方法的时候,需要给该方法分配独立的活动场所,在栈内存中分配【栈内存中分配方法运行的所属空间】;
3)方法在调用的瞬间会给该方法分配独立的内存空间,在栈中发生压栈动作,方法执行结束之后,给该方法分配独立的内存空间全部释放,此时发生弹栈动作。
压栈:给方法分配内存;
弹栈:释放该方法的内存空间;
4)局部变量在在“方法体”中声明,在栈中存储,运行时在栈中分配;
e.g.下列程序模型就是一个压栈、弹栈的过程;
-
main begin
-
m1 begin
-
m2 begin
-
m3 begin
-
m3 over
-
m2 over
-
m3 over
-
main over
14.3 栈内存的特点
1)栈帧永远指向栈顶元素
2)栈顶元素处于活跃状态,其他元素静止
3)术语: 压栈/入栈/push
弹栈/出栈/pop
4)栈数据结构存储数据的特点:
先进后出;
后进先出;
15、方法执行内存分析
-
public class MethodTest01
-
{
-
public static void main(String[] args)
-
{
-
int a = 10;
-
int b = 20;
-
int restValue = sumInt(a,b);
-
System.out.println("retValue = " retvalue);
-
}
-
public ststic int sumInt(int i,int j)
-
{
-
int result = i j;
-
int num = 3;
-
int reValue = divide (result,num);
-
return retValue;
-
}
-
public static int divide (int x,int y)
-
{
-
int z = x / y;
-
return z;
-
}
-
}
16、方法重载(overload)
优点:
功能不相同但相似,像是在使用同一个方法一样,程序员编写代码更加方便,也不需要记忆更多的方法名,代码更美观;
(javascript不支持方法重载机制)
-
public class MethodTest01
-
{
-
public static void main(String[] args)
-
{
-
System.out.println(sum(1,2));
-
System.out.println(sum(1.0,2.0));
-
System.out.println(sum(1L,2L));
-
}
-
public static int sum(int a,int b)
-
{
-
return a b;
-
}
-
public static long sum(long a,long b)
-
{
-
return a b;
-
}
-
public static double sum(double a,double b)
-
{
-
return a b;
-
}
-
}
参数的类型不同,对应调用的方法也不同。此时区分方法不再依靠方法名了,依靠的是实参的数据类型。
16.1 什么时候考虑使用方法重载?
*功能相似的时候,尽可能让方法名相同;
【功能不同/不相似的时候,尽可能让方法名不同】;
16.2 构成方法重载的条件
1)在同一个类中
2)方法名相同
3)参数列表不同
(数量不同、顺序不同、类型不同)
16.3 方法重载的影响因素
1)方法重载和方法名 参数列表有关;
2)方法重载和返回值类型无关;
3)方法重载和修饰符列表无关;
16.4 方法重载的应用
用户自定义封装一段代码,使得在使用时更加便捷快速调用;
-
public class helloworld
-
{
-
public static void main(String[] args)
-
{
-
U.v(2.0);
-
}
-
}
-
class U
-
{
-
public static void v(long b){
-
System.out.println(b);
-
}
-
public static void v(double b){
-
System.out.println(b);
-
}
-
public static void v(short b){
-
System.out.println(b);
-
}
-
public static void v(char b){
-
System.out.println(b);
-
}
-
public static void v(String b){
-
System.out.println(b);
-
}
-
public static void v(byte b){
-
System.out.println(b);
-
}
-
}
17、方法递归
缺点:
耗费栈内存,调用一次方法栈内存就会新分配一块所属的内存空间;
当没有结束条件时,栈内存溢出错误,错误无法挽回,只要一个结果,就是JVM停止工作;
这篇好文章是转载于:学新通技术网
- 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
- 本站站名: 学新通技术网
- 本文地址: /boutique/detail/tanhhaeghi
-
photoshop保存的图片太大微信发不了怎么办
PHP中文网 06-15 -
《学习通》视频自动暂停处理方法
HelloWorld317 07-05 -
word里面弄一个表格后上面的标题会跑到下面怎么办
PHP中文网 06-20 -
Android 11 保存文件到外部存储,并分享文件
Luke 10-12 -
photoshop扩展功能面板显示灰色怎么办
PHP中文网 06-14 -
微信公众号没有声音提示怎么办
PHP中文网 03-31 -
excel下划线不显示怎么办
PHP中文网 06-23 -
excel打印预览压线压字怎么办
PHP中文网 06-22 -
TikTok加速器哪个好免费的TK加速器推荐
TK小达人 10-01 -
怎样阻止微信小程序自动打开
PHP中文网 06-13