Java基础语法(总结篇)

关键字&标识符

关键字的概念与特征

概念:Java关键字是事先定义好的对Java的编译器有特殊的意义,他们用来表示一种数据类型,或者表示程序的结构等,关键字不能用做变量名、方法名、类名、包名和参数。java

特征:ajax

  • 彻底小写
  • 在加强版记事本中(例如Notepad++)有特殊颜色

标识符的概念与规则

  1.   什么是标识符?

    凡是能够由本身命名的地方都称为标识符.数组

    例: 项目名 ,包名 ,类名 .方法名性能

        2.   命名规范编码

    ①    不可使用java关键字和保留字,可是能够包含关键字和保留字.spa

    ②    可使用26个字母大小写,数字0-9,$和_.3d

    ③    可使用数字,但不可放在首位.code

    ④    长度理论上没有限制,但命名最好能反映出其做用,遵循”驼峰形式”,见命知意对象

    ⑤    包名所有小写,类名所有大驼峰式blog

    ⑥    变量名、方法名首字母小写,若是名称由多个单词组成,每一个单词的首字母都要大写

              ⑦ 常量(特指被 final 修饰的常量)名所有大写,若是是单个字母,须要大写,若是是多个单词,须要用下划线分开。而且都大写

    例:写一个ajax的项目实例,

    项目名:ajaxtest        包名:com.liu.ajax       类名:AjaxDemo

常量&变量

常量的概念:在程序运行期间。固定不变的量。

常量的分类:

  1. 字符常量:凡是用单引号引发来的单个字符,就作字符常量。例如:、‘b'、9’、‘中
  2. 字符串常量:凡是用双引号引发来的部分,叫作字符串常量。例如:"abc"、"Hello”、“123"
  3. 整数常量:直接写上的数字,没有小数点。例如:100、200、0、-250

  4. 浮点数常量:直接写上的数字,有小数点。例如:2.五、-3.1四、0.0 

  5. 布尔常量:只有两种取值 true  |  false

基本数据类型:

 

           类型                                                                                                 字节数                       二进制位数

 

          byte (字节型)                                                                                   1                                   8

 

          short(短整型)                         char    (字符型)                             2                                  16

 

          int    (整型)                            float    (单精度浮点数)                   4                                  32

 

         long  (长整型)                        double(双精度浮点数)                   8                                   64

注意事项:

  • Java中的默认类型:整数类型是 int 、浮点类型是double
  • 数据范围与字节数不必定相关,例如float数据范围比 long 更加普遍,可是float是4字节,1ong是8字节。
  • 浮点型可能只是一个近似值,并不是精确的值。
  • 浮点数当中默认类型是double。若是必定要使用float类型,须要加上一个后缀F。
  • 字符串不是基本类型,而是引用类型
  • 若是是整数,默认为int类型,若是必定要使用long类型,须要加上一个后缀L。推荐使用大写字母后缀。

 

 变量: 程序运行期间,内容能够改变的量。

建立一个变量而且使用的格式:

 

  数据类型  变量名称; //建立了一个变量

  变量名称 = 数据值;  //赋值,将右边的数据值,赋值交给左边的变量

一步到位的格式:
  数据类型  变量名称 = 数据值; //在建立一个变量的同时,马上放入指定的数据值

 注意事项:

  1.若是建立多个变量,那么变量之间的名称不能够重复。

   2.对于float和long类型来讲,字母后缀F 和 L不要丢掉。

   3.没有进行赋值的变量,不能直接使用;必定要赋值以后,才能使用。

 

做用域 : 从定义变量的一行开始,一直到直接所属的大括号结束。 

 

数据类型转换

当效据类型不同时,就会发生数据类型转换

自动类型转换(隐式)

  1.特色:代码不须要进行特殊处理,自动完成

  2.规则:数据范围从小到大

long num1 = 100; System.out.println(num1)

 

 // 左边是long类型,右边是默认的int类型,左右不同

 // int-->long,符合了数据范围从小到大的要求

 

强制类型转换(显式)

   1.特色:代码须要进行特殊的格式处理,不能自动完成

   2.格式:范围小的类型范围小的变量名=(范围小的类型)本来范围大的数据

 

int num=(int)100L; System.out.print1n(num);

 

 //左边是int类型,右边是long类型,不同

 //格式范围小的类型  范围小的变量名 =(范围小的类型) 本来范围大的数据 ;

注意事项:

  1.强制类型转换通常不推荐使用,由于有可能发生精度损失、数据溢出。

  2.byte / short / char这三种类型均可以发生数学运算,例如加法“+”.

  3.byte/short/char这三种类型在运算的时候,都会被首先向上提高成为int类型,而后再计算。符合ASCII编码表。 

例3: byte num4 = 40;//注意!右侧的数值大小不能超过左侧的类型范围
byte num5 = 50//当byte + byte,会先向上提高称为int类型,因此结果就是--> int + int ,返回类型也应该是int
int result1 = num4 + num5;
System.out.println(result1);
//90

 

 运算符 :进行特定操做的符号。例如:+

 表达式:用运算符连起来的式子叫作表达式。例如:20+5 。   又例如:a+b

 四则运算:加+      减 -      乘 *      除  /

 

  取模(取余数):%

 只有对于整数的除法来讲,取模运算符才有余数的意义。

 

int x = 10;
int y = 3;
int resultl = x / y ;
System.out.println(result1);//3
int result2 = x % y ;
System.out.println(result2);//余数,模,1

 

 算术运算符

 

 

 

 

 四则运算当中的加号“+”有常见的三种用法:

  1.对于数值来讲,+ 就是加法。

  2.对于字符char类型来讲,在计算以前,char会被提高成为int,而后再计算。
  char类型字符,和int类型数字,之间的对照关系表:ASCII、Unicode

  3.对于字符串String来讲,+ 表明字符串链接操做。   () 小括号的优先级最高

例3:
String str = "Java";

//
String + int --> String
System.out.println(str2+20);
//Java20

 

 

自增运算符:++

   例如:   a++;   先使用a值,再执行a = a + 1 ; 
int a = 1; int b = 2; b = a++; //在这一步,a的值尚未改变,因此是将a=1的值赋给了b,而后再进行改变。 System.out.println("a:"+a); //a:2 System.out.println("b:"+b); //b:1

 

自减运算符:- -

  例如:   ++a; 先执行a = a + 1 ; 再使用a值。
int a = 1; int b = 2; b = --a; System.out.println("a:"+a); System.out.println("b:"+b);

 

a++ : 在变量值被使用以后才增长的值

++a : 在变量值在被使用以前增长它的值

- - 操做符的工做原理与此相同,只是它所执行的是减值操做而非增值操做。

 赋值运算符

赋值运算符是指为变量或常量指定数值的符号。如可使用 “=” 将右边的表达式结果赋给左边的操做数。

Java 支持的经常使用赋值运算符,以下表所示:

 

 

 比较运算符

比较运算符用于判断两个数据的大小,例如:大于、等于、不等于。比较的结果是一个布尔值( true 或 false )。

Java 中经常使用的比较运算符以下表所示:

注意事项:

  一、  > 、 < 、 >= 、 <= 只支持左右两边操做数是数值类型

  二、  == 、 != 两边的操做数既能够是数值类型,也能够是引用类型

 

逻辑运算符

主要用于进行逻辑运算,链接两个Boolean值,表明两个条件。

Java 中经常使用的逻辑运算符以下表所示:

咱们能够从“投票选举”的角度理解逻辑运算符:

  一、 与:要求全部人都投票赞成,才能经过某议题

  二、 或:只要求一我的投票赞成就能够经过某议题

  三、 非:某人本来投票赞成,经过非运算符,可使其投票无效

  四、 异或:有且只能有一我的投票赞成,才能够经过某议题

 

当使用逻辑运算符时,咱们会遇到一种颇有趣的 “短路” 现象    >> 若是根据左边已经能够判断获得最终结果,那么右边的代码将再也不执行,从而节省必定的性能。

譬如:( 1 > 2 ) && ( 1 < 3 ) 中,若是能肯定左边 1 > 2 运行结果为 false , 则系统就认为已经没有必要执行右侧的 1 < 3 啦。

 

条件运算符

条件运算符( ? : )也称为 “三元运算符”。

  • 一元运算符:只须要一个数据就能够进行操做的运算符。例如:取反!、自增++、自减--
  • 二元运算符:须要两个数据才能够进行操做的运算符。例如:加法+、赋值=
  • 三元运算符:须要三个数据才能够进行操做的运算符。

 

语法形式:布尔表达式 ? 表达式1 :表达式2

运算过程:若是布尔表达式的值为 true ,则返回 表达式1 的值,不然返回 表达式2 的值

例如 :

 

 

 由于,表达式 8>5 的值为 true ,因此,返回: 8大于5

 

方法 ♦ ♦

所谓方法,就是用来解决一类问题的代码的有序组合,是一个功能模块。

通常状况下,定义一个方法的语法是:  

访问修饰符  返回值类型  方法名(参数列表){

  方法体

}

 其中:

  一、 访问修饰符:方法容许被访问的权限范围, 能够是 public、protected、private 甚至能够省略 ,其中 public 表示该方法能够被其余任何代码调用

  二、 返回值类型:方法返回值的类型,若是方法不返回任何值,则返回值类型指定为 void ; 若是方法具备返回值,则须要指定返回值的类型,而且在方法体中使用 return 语句返回值

  三、 方法名:定义的方法的名字,必须使用合法的标识符

  四、 参数列表:传递给方法的参数列表,参数能够有多个,多个参数间以逗号隔开,每一个参数由参数类型和参数名组成,以空格隔开 

 

 根据方法是否带参、是否带返回值,可将方法分为四类:

 

   无参无返回值方法

  若是方法不包含参数,且没有返回值,咱们称为无参无返回值的方法。

  方法的使用分两步:

  第一步,定义方法

  例如:下面代码定义了一个方法名为 show ,没有参数,且没有返回值的方法,执行的操做为输出 “ welcome to imooc. ”

  

 注意 :

  一、 方法体放在一对大括号中,实现特定的操做

  二、 方法名主要在调用这个方法时使用,须要注意命名的规范,通常采用第一个单词首字母小写,其它单词首字母大写的形式

 

  第二步,调用方法

  当须要调用方法执行某个操做时,能够先建立类的对象,而后经过  对象名.方法名();  来实现

  例如:在下面的代码中,咱们建立了一个名为 hello 的对象,而后经过调用该对象的 show( ) 方法输出信息

  

  运行结果为:  welcome to imooc.

 

 

  无参带返回值方法

  若是方法不包含参数,但有返回值,咱们称为无参带返回值的方法。

  例如:下面的代码,定义了一个方法名为 calSum ,无参数,但返回值为 int 类型的方法,执行的操做为计算两数之和,并返回结果

  

    在 calSum( ) 方法中,返回值类型为 int 类型,所以在方法体中必须使用 return 返回一个整数值

  调用带返回值的方法时须要注意,因为方法执行后会返回一个结果,所以在调用带返回值方法时通常都会接收其返回值并进行处理。以下:第6行

  

  运行结果为: 两数之和为:17

 

 不容忽视的“小陷阱”:

  一、 若是方法的返回类型为 void ,则方法中不能使用 return 返回值!

  

  二、 方法的返回值最多只能有一个,不能返回多个值

  

  三、 方法返回值的类型必须兼容,例如,若是返回值类型为 int ,则不能返回 String 型值

  

 

   带参无返回值方法

 有时方法的执行须要依赖于某些条件,换句话说,要想经过方法完成特定的功能,须要为其提供额外的信息才行。

 例如,现实生活中电饭锅能够实现“煮饭”的功能,但前提是咱们必须提供食材,若是咱们什么都不提供,那就真是的“巧妇难为无米之炊”了。

 咱们能够经过在方法中加入参数列表接收外部传入的数据信息,参数能够是任意的基本类型数据或引用类型数据。

 

 咱们先来看一个带参数,但没有返回值的方法:

 

  上面的代码定义了一个 show 方法,带有一个参数 name ,实现输出欢迎消息。

 

  调用带参方法与调用无参方法的语法相似,但在调用时必须传入实际的参数值

 

 例如:

  

  运行结果为: 欢迎您,爱慕课!

  不少时候,咱们把定义方法时的参数称为形参,目的是用来定义方法 须要传入参数的个数和类型;把调用方法时的参数称为实参,是传递给方法真正被处理的值。

 

  必定不可忽视的问题:

  一、 调用带参方法时,必须保证明参的数量、类型、顺序与形参一一对应

 

  

 

二、 调用方法时,实参不须要指定数据类型,如 

 

  三、 方法的参数能够是基本数据类型,如 int、double 等,也能够是引用数据类型,如 String、数组等           

 

 

 

                         第10行,Array.toString()方法将数组转换为字符串输出

 

 四、 当方法参数有多个时,多个参数间以逗号分隔

 

 带参带返回值方法

  若是方法既包含参数,又带有返回值,咱们称为带参带返回值的方法。

  例如:

下面的代码,定义了一个 show 方法,带有一个参数 name ,方法执行后返回一个 String 类型的结果

  

调用带参带返回值的方法:

  

  运行结果为: 欢迎您,爱慕课!

相关文章
相关标签/搜索