java基础梳理--朝花夕拾(二)

1、Java语言语法规则和文件格式;

第一个Java程序:
/**
第一个Java程序:
控制台输出Hello world!
*/
public class Test{
    //访问修饰符 class关键词用于声明类使用 后面跟类名
   public static void main(String args[]){//程序的入口,主函数main方法;
        System.out.println(“Hello world!”);// 输出语句
   }
}

Java语言区分大小写;
public 为访问修饰符;
class关键词,用于声明类;
/**/ 多行注释;注释掉内容不被程序视为可执行内容;
//单行注释;
一条语句结束,需要通过“;” 分号结束,表示这条语句已经结束;
Java语言可以通过空格或者换行符、制表符等将其分隔开.

文件格式:一个Java程序,需要有类的声明,一般一个.java 文件中只有一个类;但是,也可以有多个class存在,此时主意:一个.java文件中,只能存在一个public 修饰的类,即:一个java文件名,应该与这个文件中public 修饰的类名相同;一个java文件中只能存在一个public 修饰的类;


2、程序的入口主函数(主方法);

在java中主函数main方法,语句格式如下:public static void main(String args[]){}

主函数只能存在于public修饰的类中;否则无法执行该主方法;如果放到其他没有被public修饰的类中,没语法错误,但是无法执行。


3、变量的声明和赋值;

变量主要用于数据的存储,需先声明再使用;
1、全局变量:声明在类中,方法外,多个方法可同时使用,也被称作“属性”、类变量、成员变量等;可以不赋初始值;全局变量可以在类型前面加访问修饰符,来控制该变量被访问的范围:
例如:
private int i=100;
pulic String str=“”;
protected short t;

2、局部变量:声明在方法中,供当前方法使用; 声明是必须赋值或者使用时必须有赋值操作;
例如:
字节型:byte b=99;
短整型:int i=11;
整型: short t=5;
长整型:long l=1898989;
字符串变量:String str=“HELLO”;
浮点型:单精度:float f=1.78;
浮点型:双精度:double d=1.7878787878;
布尔类型: boolean b=true;
字符型:char c=‘A’;


4、Java中数据类型的分类;

Java中可以分为两大类数据类型:
1、基本数据类型:
整型:
字节型(8位): byte -128到127之间的任意整数
短整型(16位): short -32768~32767之间的任意整数
整型(32位):int -2^31到2^31-1之间的任意整数
长整型(64位):long -2^63到2^63-1之间的任意整数
浮点型:
单精度(32位):float 32位单精度浮点数 根据IEEE754-1985标准
双精度(64位):double
布尔类型: boolean (true/false)
字符型(16位):char

       2、引用数据类型:引用类型的内存单元中只存放对象的地址,而对象本身存贮在内存堆中,只是简单的引用对象的地址。非基本数据类型变量,都是引用数据类型;
      (1)类class 例如:Object类 Date类
      (2)接口interface
      (3)数组array


5、基本数据类型之间的转换;

在Java中有如下几种转换方式:
1、隐式转换(亦称自动类型转换):系统默认将其转换为我们需要的数据类型;
     转换规则:从存储范围小的类型到存储范围大的类型。
     具体规则为:byte→short(char)→int→long→float→double

     也就是说 short类型的变量可以自动转换为 int 类型
     例如:short t=10,10默认为int类型;
     注意:在java中,整数默认为int类型,小数默认为double类型;

2、强制转换:在变量前加小括号,写转换类型,将其强制转换为指定类型;强制类型转换,也称显式类型转换,是指必须书写代码才能完成的类型转换。
                      该类类型转换很可能存在精度的损失,所以必须书写相应的代码,并且能够忍受该种损失时才进行该类型的转换。
     转换规则:从存储范围大的类型到存储范围小的类型。
    具体规则为:double→float→long→int→short(char)→byte
    语法格式为:(转换到的类型)需要转换的值
   例如:
         (1)byte<- short<-int<-long(这里表示赋值方向)例如:
             int i=10;short t=(short)i;
             float f=(float)10.123;
             long l=10; int i2=(int) l; short t2=(short) l;
        (2) double->float;(double赋值给float类型)
             float/double->(byte/short/int/long)例如:
             float f=(float)10.123; float f=10.123f;
             double d=10.123;int i3=(int) d;short t3=(short) d;long l2=(long) d; byte b=(byte) d;
     (3)(byte/short/int/long/float/double)->char
              char c='A';
              c=(char) i;
   特殊情况下:通过某些JavaAPI相关方法实现类型转换(不是基本数据类型之间的转换了)
   例如:
             double dRes=Double.valueOf("10.89");

6、关键字、标识符和常量用法;

1.关键字(词):是java中特有的词语,是电脑语言(这里我们指Java)里事先定义的,有特别意义的标识符,有时又叫保留字,还有特别意义的变量。
   例如:
        abstract 抽象类或方法
       assert 用来查找内部程序错误
       break 跳出一个switch或循环
       byte 8位整数类型
       case switch的一个分支
       catch 捕获异常的try块子句
2.标识符
(1)由字母、数字、_下划线,或者$美元符号组成;
(2)不能以数字开头;
(3)区分大小写,长度无限制,但是要见名知意;
(4)不能是Java关键字或者保留字;
  例如:
       合法:Person 、 user_name、 _userName、$abc_123、userProject
       非法:2Username、#Test、class 、void、pulic

 p.s.类、方法、属性(变量)、常量命名规则:
      类名:开头字母必须大写,后面每个单词首字母也大写,其他小写字母;
     方法名:开头字母小写、后面每个单词首字母大写;
     常量:所有字母大写;

3.常量:例如:当我们在项目中定义一个性别标识时,如男性:SEX_MEN="1" ,在我们使用时,永远不会修改这个数据,此时我们可以认为它就是常量;定义常量后,不   会被修改;(注意:之声明在类中作为全局变量使用)例如:
   public static final String SEX_MAN="0";


7、运算符、表达式;

例如:
int i=6,j,k,m,n;
j = +i; //取原值,即j=6
k = -i; //取负值,即k=-6
m = i++; //先m=i,再i=i+1,即m=6,i=7
m = ++i; //先i=i+1,再m=i,即i=7,m=7
n = j--; //先n=j,再j=j-1,即n=6,j=5
n = --j; //先j=j-1,再n=j,即j=5,n=5;
p.s. ++/-- 在前时,则先运算再取值;在后时,则先取值再运算。

 


8、条件判断语句: if语句和switch语句;

(1)if语句结构

       

(2)switch流程控制语句结构:
主意:switch只能实现等值条件判断;而且表达式类型只能是int、char、byte类型变量;其中break表示退出当前判断的执行体;如果再循环中表示退出整个循环;

 

例如:

(3)三元运算符
语法为:条件表达式?表达式1:表达式2。
说明:问号前面的位置是判断的条件,判断结果为bool型,为true时调用表达式1,为false时调用表达式2。
例如:A>B ? 100 :200;

9、循环语句结构;

(1)for循环流程控制

p.s. for循环中另有此种循环方式: for (循环变量类型 循环变量名称 : 要被遍历的对象) 循环体,例如:

(2)while循环流程控制

 

(3)do…while循环流程

 

p.s. do...while循环与while循环的区别是do…while的循环主体至少运行一次。

10、字符串的定义和使用;

Java中String声明字符串两种方法及它们的区别 :
方法1:String msg = “Hello”;
直接赋值。该方法执行后会自动将字符串“Hello”保存在字符串池中。则第二次使用直接赋值时,先检测字符串池中是否已存在“Hello”,如果存在,则将堆地址赋给引用。
Public class StringDemo{
    String msg1 = “Hello”;
    String msg2 = “Hello”;
}
执行后使得msg1与msg2的指向的地址是相同的。即内存中只有一个Hello的值。被两个引用所指向。String类采用了共享的设计模式。

方法2:String msg =new String(“Hello”);
构造方法赋值。该方法执行后,会开辟两个内存空间(耗费资源),msg会指向其中的一个,而另一个没有引用指向,就会成为垃圾内存被清理掉。使用构造方法声明的“Hello”不会自动保存到字符串池中,不能共享。
Public class StringDemo{
  String msg1 = new String(“Hello”);
  String msg2 = new String(“Hello”);
}
执行后,虽然内容一样,但是存放的地址是不一样的。他不会自动保存在字符串内存池中。
总结:综上所述,直接赋值及构造方法赋值,因保存到字符串池有差异,导致是否可以共享亦有差异,效果如下:
  String str1=“weight”;
  String str2=“weight”;
  String str3=new String (“weight”);
  System.out.println(str1==str2);//true
  System.out.println(str2==str3);//false

字符串常用方法

1、charCodeAt方法返回一个整数,代表指定位置字符的Unicode编码。
strObj.charCodeAt(index)
说明:
index将被处理字符的从零开始计数的编号。有效值为0到字符串长度减1的数字。
如果指定位置没有字符,将返回NaN。
例如:
var str = "ABC";
str.charCodeAt(0);
结果:65
2、fromCharCode方法从一些Unicode字符串中返回一个字符串。
String.fromCharCode([code1[,code2...]])
说明:
code1,code2...是要转换为字符串的Unicode字符串序列。如果没有参数,结果为空字符串。
例如:
String.fromCharCode(65,66,112);
结果:ABp
3、charAt方法返回指定索引位置处的字符。如果超出有效范围的索引值返回空字符串。
strObj.charAt(index)
说明:
index想得到的字符的基于零的索引。有效值是0与字符串长度减一之间的值。
例如:
var str = "ABC";
str.charAt(1);
结果:B
4、slice方法返回字符串的片段。
strObj.slice(start[,end])
说明:
start下标从0开始的strObj指定部分其实索引。如果start为负,将它作为length+start处理,此处length为字符串的长度。
end小标从0开始的strObj指定部分结束索引。如果end为负,将它作为length+end处理,此处length为字符串的长度。
例如:
012345
var str = "ABCDEF";
str.slice(2,4);
结果:CD
5、substring方法返回位于String对象中指定位置的子字符串。
strObj.substring(start,end)
说明:
start指明子字符串的起始位置,该索引从0开始起算。
end指明子字符串的结束位置,该索引从0开始起算。
substring方法使用start和end两者中的较小值作为子字符串的起始点。如果start或end为NaN或者为负数,那么将其替换为0。
例如:
012345
var str = "ABCDEF";
str.substring(2,4); // 或 str.substring(4,2);
结果:CD
6、substr方法返回一个从指定位置开始的指定长度的子字符串。
strObj.substr(start[,length])
说明:
start所需的子字符串的起始位置。字符串中的第一个字符的索引为0。
length在返回的子字符串中应包括的字符个数。
例如:
012345
var str = "ABCDEF";
str.substr(2,4);
结果:CDEF
7、indexOf方法放回String对象内第一次出现子字符串位置。如果没有找到子字符串,则返回-1。
strObj.indexOf(substr[,startIndex])
说明:
substr要在String对象中查找的子字符串。
startIndex该整数值指出在String对象内开始查找的索引。如果省略,则从字符串的开始处查找。
例如:
01234567
var str = "ABCDECDF";
str.indexOf("CD",1); // 由1位置从左向右查找 123...
结果:2
8、lastIndexOf方法返回String对象中字符串最后出现的位置。如果没有匹配到子字符串,则返回-1。
strObj.lastIndexOf(substr[,startindex])
说明:
substr要在String对象内查找的子字符串。
startindex该整数值指出在String对象内进行查找的开始索引位置。如果省略,则查找从字符串的末尾开始。
例如:
01234567
var str = "ABCDECDF";
str.lastIndexOf("CD",6); // 由6位置从右向左查找 ...456
结果:5
9、search方法返回与正则表达式查找内容匹配的第一个字符串的位置。
strObj.search(reExp)
说明:
reExp包含正则表达式模式和可用标志的正则表达式对象。
例如:
var str = "ABCDECDF";
str.search("CD"); // 或 str.search(/CD/i);
结果:2
10、concat方法返回字符串值,该值包含了两个或多个提供的字符串的连接。
str.concat([string1[,string2...]])
说明:
string1,string2要和所有其他指定的字符串进行连接的String对象或文字。
例如:
var str = "ABCDEF";
str.concat("ABCDEF","ABC");
结果:ABCDEFABCDEFABC
11、将一个字符串分割为子字符串,然后将结果作为字符串数组返回。
strObj.split([separator[,limit]])
说明:
separator字符串或 正则表达式 对象,它标识了分隔字符串时使用的是一个还是多个字符。如果忽略该选项,返回包含整个字符串的单一元素数组。
limit该值用来限制返回数组中的元素个数。
例如:
var str = "AA BB CC DD EE FF";
alert(str.split(" ",3));
结果:
AA,BB,CC
12、toLowerCase方法返回一个字符串,该字符串中的字母被转换成小写。
例如:
var str = "ABCabc";
str.toLowerCase();
结果:abcabc
13、toUpperCase方法返回一个字符串,该字符串中的所有字母都被转换为大写字母。
例如:
var str = "ABCabc";
str.toUpperCase();
结果:ABCABC


11、数组的定义和使用;

数组的定义和使用

1.数组:它是一个变量,用于存储相同数据类型的一组数据;
2.建立java数组需要以下三个步骤:
  声明数组
  创建数组空间
  初始化数组元素
3.数组的声明方式:
  (1)数据类型 变量名[];
  (2)数据类型[] 变量名;

例如:char s[]; char[] s;
     Object p[]; Object[] p;
注意:
  为数组开辟内存空间,在创建数组空间时必须为它指明数组的长度。
  一个数组是一个对象,所以用new来创建数组

语法格式为:数组名 = new 数组元素类型[数组元素的个数];
例如:
  int[] MyIntArray;
  MyIntArray =new int[4];

       MyIntArray[0]=0;

          MyIntArray[1]=1;

          MyIntArray[2]=2;

          MyIntArray[3]=3;

 

也可以在创建数组空间的时候,同时将初值给出来,例如:
  int[] myIntArray={1,2,3,4};

存储空间的分配等价于使用new
有上面描述得知:java中数组长度不可变;

基本数据类型的数组元素会自动初始化成“空”值(对于数值,空值就是零;对于char,它是null;而对于boolean,它却是false)。

 

多维数组的定义和使用
1. 定义方式:type 维数 arrayName;
  例如:int [][] intArray;int[][][] a2;
2. 分配内存空间: 有两种方法:
  a.直接为每一维分配空间:
  如:int[][] a = new int[2][3];
  b.分别为每一维分配空间:
  如:int[][] a = new int[2][ ];
    a[0] = new int[4];
    a[1] = new int[3];
  p.s.Java中多维数组被看作数组的数组。例如二维数组为一个特殊的一维数组,其每个元素又是一个一维数组。
      如:int[][] a = new int[2][3];
             a[0][0] a[0][1] a[0][2]
             a[1][0] a[1][1] a[1][2]
3.多维数组(这里我们针对二维数组举例)初始化有两种方式:
   例如:
  (1)int[][] a = new int[2][3]; 先定义后再赋值;
  (2)int a[][] = {{2,3,6}, {1,5}, {3,4}}; 定义时直接赋值;

关于java数组的常用操作方法

1. 声明一个数组

1 String[] arr1 = new String[5];  
2 String[] arr2 = {"a","b","c", "d", "e"};  
3 String[] arr3= new String[]{"a","b","c","d","e"};  

2. 输出一个数组

复制代码
1 int[] arr = { 1, 2, 3, 4, 5 };  
2 String arrString = Arrays.toString(arr);  
3    
4 // 直接输出,为内存地址
5 System.out.println(arr);  
6 // [I@139a55
7    
8 System.out.println(arrString );  
9 // [1, 2, 3, 4, 5]  
复制代码

3. 检查一个数组是否包含某值

1 String[] arr= { "a", "b", "c", "d", "e" };  
2 boolean b = Arrays.asList(arr).contains("a");  
3 System.out.println(b);  
4 // true  

4. 连接两个数组

1 //使用Apache Commons Lang library
2 
3 1 int[] arr1 = { 1, 2, 3, 4, 5 };  
4 2 int[] arr2= { 6, 7, 8, 9, 10 };  
5 3 int[] combArr = ArrayUtils.addAll(arr1 , arr2); 

 

复制代码
// System.arraycopy()
1 static String[] concat(String[] a, String[] b) { 2 String[] c = new String[a.length + b.length]; 3 System.arraycopy(a, 0, c, 0, a.length); 4 System.arraycopy(b, 0, c, a.length, b.length); 5 return c; 6 }
复制代码
复制代码
1 //Arrays.copyOf()
2 
3 public static int[] concat(int[] first, int[] second) {
4     int[] result = Arrays.copyOf(first, first.length + second.length);
5     System.arraycopy(second, 0, result, first.length, second.length);
6     return result;
7 }
复制代码

5. 逆向输出一个数组

复制代码
1 // Apache Commons Lang library
2 
3 int[] arr= { 1, 2, 3, 4, 5 };  
4 ArrayUtils.reverse(intArray);  
5 System.out.println(Arrays.toString(intArray));  
6 //[5, 4, 3, 2, 1]  
复制代码
复制代码
1 int[] arr = { 1, 2, 3, 4, 5 };
2 int[] revArr = new int[arr.length];
3 for(int i = 0; i < arr.length; i++){
4     revArr[i] = arr[arr.length - i -1];
5 }
6 System.out.println(Arrays.toString(revArr));
7 
8 //[5, 4, 3, 2, 1]
复制代码

6. 移除数组中的元素

1 // Apache common lang  
2 
3 int[] arr= { 1, 2, 3, 4, 5 };  
4 int[] removed = ArrayUtils.removeElement(intArray, 3);//create a new array  
5 System.out.println(Arrays.toString(removed))

 

p.s. 《java基础梳理-朝花夕拾》系列由何东飞根据自己工作几年以来对java的理解梳理而成,笔者闲暇时将持续更新,有不对的地方请各位指教。QQ:983489147

posted @ 2017-08-22 23:54  何年何月生  阅读(2781)  评论(0编辑  收藏  举报