Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> 關於Android編程 >> 第五天:JAVA中的方法和格式以及例題

第五天:JAVA中的方法和格式以及例題

編輯:關於Android編程

1:方法(掌握)
(1)方法:就是完成特定功能的代碼塊。
注意:在很多語言裡面有函數的定義,而在Java中,函數被稱為方法。
(2)格式:
修飾符 返回值類型 方法名(參數類型 參數名1,參數類型 參數名2...) {
方法體語句;
return 返回值;
}


修飾符:目前就用 public static。後面再詳細講解其他修飾符
返回值類型:就是功能結果的數據類型
方法名:就是起了一個名字,方便我們調用該方法。
參數類型:就是參數的數據類型
參數名:就是變量
參數分類:
實參:實際參與運算的數據
形參:方法上定義的,用於接收實際參數的變量
方法體語句:就是完成功能的代碼塊
return:結束方法
返回值:就是功能的結果,由return帶給調用者。
(3)兩個明確:
返回值類型:結果的數據類型
參數列表:參數的個數及對應的數據類型
(4)方法調用
A:有明確返回值的方法
a:單獨調用,沒有意義
b:輸出調用,不是很好,因為我可能需要不結果進行進一步的操作。但是講課一般我


就用了。
c:賦值調用,推薦方案
B:void類型修飾的方法
a:單獨調用
(5)案例:
A:求和方案
B:獲取兩個數中的較大值
C:比較兩個數據是否相同
D:獲取三個數中的最大值
E:輸出m行n列的星形
F:輸出nn乘法表
(6)方法的注意事項
A:方法不調用不執行
B:方法之間是平級關系,不能嵌套定義
C:方法定義的時候,參數是用,隔開的
D:方法在調用的時候,不用在傳遞數據類型
E:如果方法有明確的返回值類型,就必須有return語句返回。
(7)方法重載
在同一個類中,方法名相同,參數列表不同。與返回值無關。

參數列表不同:
參數的個數不同。
參數的對應的數據類型不同。
(8)方法重載案例
不同的類型的多個同名方法的比較。

2:數組(掌握)
/*
數組:存儲同一種數據類型的多個元素的容器。

定義格式:
A:數據類型[] 數組名;
B:數據類型 數組名[];

舉例:
A:int[] a; 定義一個int類型的數組a變量
B:int a[]; 定義一個int類型的a數組變量

注意:效果可以認為是一樣的,都是定義一個int數組,但是念法上有些小區別。推薦使用第一種。

如何對數組進行初始化呢?
A:何謂初始化呢? 就是為數組開辟內存空間,並為每個數組元素賦予值
B:有幾種方式呢?
a:動態初始化 只指定長度,由系統給出初始化值
b:靜態初始化 給出初始化值,由系統決定長度

動態初始化的格式:
數據類型[] 數組名 = new 數據類型[數組長度];

舉例:
int[] arr = new int[3];

如何獲取數組中的元素呢?
通過:
數組名[索引]
索引其實就是每個元素的編號,從0開始,最大索引是數組的長度-1。
*/
class ArrayDemo {
public static void main(String[] args) {
//定義一個數組
//int[] a;
//可能尚未初始化變量a
//System.out.println(a);

int[] arr = new int[3];
/*
左邊:
int:說明數組中的元素的數據類型是int類型
[]:說明這是一個數組
arr:是數組的名稱

右邊:
new:為數組分配內存空間。
int:說明數組中的元素的數據類型是int類型
[]:說明這是一個數組
3:數組長度,其實也就是數組中元素的個數
*/

System.out.println(arr); //[I@175078b 地址值。
//我要地址值沒有意義啊,我就要數據值,怎麼辦呢?
//不用擔心,java為你考慮到了。
//其實數組中的每個元素都是有編號的,並且是從0開始。最大編號是數組的長度-1。
//用數組名和編號的配合就可以獲取數組中的指定編號的元素。這個編號的專業叫法:索引
//通過數組名訪問數據的格式是:數組名[索引];
System.out.println(arr[0]);
System.out.println(arr[1]);
System.out.println(arr[2]);
}
}
(1)數組:存儲同一種數據類型的多個元素的容器。
(2)特點:每一個元素都有編號,從0開始,最大編號是長度-1。
編號的專業叫法:索引
(3)定義格式
A:數據類型[] 數組名;
B:數據類型 數組名[];

推薦是用A方式,B方法就忘了吧。
但是要能看懂
(4)數組的初始化
A:動態初始化
只給長度,系統給出默認值

舉例:int[] arr = new int[3];
B:靜態初始化
給出值,系統決定長度

舉例:int[] arr = new int[]{1,2,3};
簡化版:int[] arr = {1,2,3};
(5)Java的內存分配
A:棧 存儲局部變量
B:堆 存儲所有new出來的
C:方法區(面向對象部分詳細講解)
D:本地方法區(系統相關)
E:寄存器(CPU使用)

注意:
a:局部變量 在方法定義中或者方法聲明上定義的變量。
b:棧內存和堆內存的區別
棧:數據使用完畢,就消失。
堆:每一個new出來的東西都有地址
每一個變量都有默認值
byte,short,int,long 0
float,double 0.0
char '\u0000'
boolean false
引用類型 null
數據使用完畢後,在垃圾回收器空閒的時候回收。
(6)數組內存圖
A:一個數組
B:二個數組
C:三個數組(兩個棧變量指向同一個堆內存)
(7)數組的常見操作
A:遍歷
方式1:
public static void printArray(int[] arr) {
for(int x=0; x System.out.println(arr[x]);
}
}

方式2:
public static void printArray(int[] arr) {
System.out.print("[");
for(int x=0; x if(x == arr.length-1) {
System.out.println(arr[x]+"]");
}else {
System.out.println(arr[x]+", ");
}
}
}
B:最值
最大值:
public static int getMax(int[] arr) {
int max = arr[0];

for(int x=1; x if(arr[x] > max) {
max = arr[x];
}
}

return max;
}

最小值:
public static int getMin(int[] arr) {
int min = arr[0];

for(int x=1; x if(arr[x] < min) {
min = arr[x];
}
}

return min;
}
C:逆序
方式1:
public static void reverse(int[] arr) {
for(int x=0; x int temp = arr[x];
arr[x] = arr[arr.length-1-x];
arr[arr.length-1-x] = temp;
}
}

方式2:
public static void reverse(int[] arr) {
for(int start=0,end=arr.length-1; start<=end; start+


+,end--) {
int temp = arr[start];
arr[start] = arr[end];
arr[end] = temp;
}
}
D:查表
public static String getString(String[] strArray,int index) {
return strArray[index];
}
E:基本查找
方式1:
public static int getIndex(int[] arr,int value) {
for(int x=0; x if(arr[x] == value) {
return x;
}
}

return -1;
}

方式2:
public static int getIndex(int[] arr,int value) {
int index = -1;

for(int x=0; x if(arr[x] == value) {
index = x;
break;
}
}

return index;

}

例題

/*
定義一個數組,輸出該數組的名稱和數組元素值。
給數組元素賦值,再次輸出該數組的名稱和數組元素值。
*/
class ArrayDemo2 {
public static void main(String[] args) {
//定義一個數組
int[] arr = new int[3];

//輸出數組名稱
System.out.println(arr);
//輸出數組元素值
System.out.println(arr[0]);
System.out.println(arr[1]);
System.out.println(arr[2]);
System.out.println("----");

//給數組元素賦值
arr[0] = 100;
arr[2] = 200;

//輸出數組名稱
System.out.println(arr);
//輸出數組元素值
System.out.println(arr[0]);
System.out.println(arr[1]);
System.out.println(arr[2]);
}
}

 

/*
數組操作的兩個常見小問題:
ArrayIndexOutOfBoundsException:數組索引越界異常
原因:你訪問了不存在的索引。

NullPointerException:空指針異常
原因:數組已經不在指向堆內存了。而你還用數組名去訪問元素。

作用:請自己把所有的場景Exception結尾的問題總結一下。以後遇到就記錄下來。
現象,原因,解決方案。
*/
class ArrayDemo6 {
public static void main(String[] args) {
//定義數組
int[] arr = {1,2,3};

//System.out.println(arr[3]);

//引用類型的常量:空常量 null
arr = null;
System.out.println(arr[0]);
}
}

/*


數組的靜態初始化:
格式:數據類型[] 數組名 = new 數據類型[]{元素1,元素2,…};
簡化格式:
數據類型[] 數組名 = {元素1,元素2,…};

舉例:
int[] arr = new int[]{1,2,3};

簡化後:

int[] arr = {1,2,3};

注意事項:
不要同時動態和靜態進行。
如下格式:
int[] arr = new int[3]{1,2,3}; //錯誤
*/
class ArrayDemo5 {
public static void main(String[] args) {
//定義數組
int[] arr = {1,2,3};

System.out.println(arr);
System.out.println(arr[0]);
System.out.println(arr[1]);
System.out.println(arr[2]);
}
}

/*
數組獲取最值(獲取數組中的最大值最小值)

分析:
A:定義一個數組,並對數組的元素進行靜態初始化。
B:從數組中任意的找一個元素作為參照物(一般取第一個),默認它就是最大值。
C:然後遍歷其他的元素,依次獲取和參照物進行比較,如果大就留下來,如果小,就離開。
D:最後參照物裡面保存的就是最大值。
*/
class ArrayTest2 {
public static void main(String[] args) {
//定義一個數組
int[] arr = {34,98,10,25,67};

//請獲取數組中的最大值
/*
//從數組中任意的找一個元素作為參照物
int max = arr[0];
//然後遍歷其他的元素
for(int x=1; x //依次獲取和參照物進行比較,如果大就留下來,如果小,就離開。
if(arr[x] > max) {
max = arr[x];
}
}
//最後參照物裡面保存的就是最大值。
System.out.println("max:"+max);
*/

//把這個代碼用方法改進
//調用方法
int max = getMax(arr);
System.out.println("max:"+max);

//請獲取數組中的最小值
int min = getMin(arr);
System.out.println("min:"+min);
}

/*
需求:獲取數組中的最大值
兩個明確:
返回值類型:int
參數列表:int[] arr
*/
public static int getMax(int[] arr) {
//從數組中任意的找一個元素作為參照物
int max = arr[0];
//然後遍歷其他的元素
for(int x=1; x //依次獲取和參照物進行比較,如果大就留下來,如果小,就離開。
if(arr[x] > max) {
max = arr[x];
}
}
//最後參照物裡面保存的就是最大值。
return max;
}

public static int getMin(int[] arr) {
//從數組中任意的找一個元素作為參照物
int min = arr[0];
//然後遍歷其他的元素
for(int x=1; x //依次獲取和參照物進行比較,如果小就留下來,如果大,就離開。
if(arr[x] < min) {
min = arr[x];
}
}
//最後參照物裡面保存的就是最小值。
return min;
}
}

/*
數組元素逆序 (就是把元素對調)

分析:
A:定義一個數組,並進行靜態初始化。
B:思路
把0索引和arr.length-1的數據交換
把1索引和arr.length-2的數據交換
...
只要做到arr.length/2的時候即可。
*/
class ArrayTest3 {
public static void main(String[] args) {
//定義一個數組,並進行靜態初始化。
int[] arr = {12,98,50,34,76};

//逆序前
System.out.println("逆序前:");
printArray(arr);

//逆序後
System.out.println("逆序後:");
//reverse(arr);
reverse2(arr);
printArray(arr);
}

/*
需求:數組逆序
兩個明確:
返回值類型:void (有人會想到應該返回的是逆序後的數組,但是沒必要,因為這兩個數組其實是同一個數組)
參數列表:int[] arr
*/
public static void reverse(int[] arr) {
/*
//第一次交換
int temp = arr[0];
arr[0] = arr[arr.length-1-0];
arr[arr.length-1-0] = temp;

//第二次交換
int temp = arr[1];
arr[1] = arr[arr.length-1-1];
arr[arr.length-1-1] = temp;

//第三次交換
int temp = arr[2];
arr[2] = arr[arr.length-1-2];
arr[arr.length-1-2] = temp;
*/
//用循環改進
for(int x=0; x int temp = arr[x];
arr[x] = arr[arr.length-1-x];
arr[arr.length-1-x] = temp;
}
}

public static void reverse2(int[] arr) {
for(int start=0,end=arr.length-1; start<=end; start++,end--) {
int temp = arr[start];
arr[start] = arr[end];
arr[end] = temp;
}
}

//遍歷數組
public static void printArray(int[] arr) {
System.out.print("[");
for(int x=0; x if(x == arr.length-1) { //這是最後一個元素
System.out.println(arr[x]+"]");
}else {
System.out.print(arr[x]+", ");
}
}
}
}

/*
數組查表法(根據鍵盤錄入索引,查找對應星期)
意思是:String[] strArray = {"星期一","星期二",...};
*/
import java.util.Scanner;


class ArrayTest4 {
public static void main(String[] args) {
//定義一個字符串數組
String[] strArray = {"星期一","星期二","星期三","星期四","星期五","星期六","星期日"};

//創建鍵盤錄入對象
Scanner sc = new Scanner(System.in);

System.out.println("請輸入一個數據(0-6):");
int index = sc.nextInt();

System.out.println("你要查找的日期是:"+strArray[index]);
}
}

/*
需求:數組元素查找(查找指定元素第一次在數組中出現的索引)

分析:
A:定義一個數組,並靜態初始化。
B:寫一個功能實現
遍歷數組,依次獲取數組中的每一個元素,和已知的數據進行比較
如果相等,就返回當前的索引值。
*/
class ArrayTest5 {
public static void main(String[] args) {
//定義一個數組,並靜態初始化
int[] arr = {200,250,38,888,444};

//需求:我要查找250在這個數組中第一次出現的索引
int index = getIndex(arr,250);
System.out.println("250在數組中第一次出現的索引是:"+index);

int index2 = getIndex2(arr,250);
System.out.println("250在數組中第一次出現的索引是:"+index2);

int index3 = getIndex2(arr,2500);
System.out.println("2500在數組中第一次出現的索引是:"+index3);
}

/*
需求:查找指定數據在數組中第一次出現的索引
兩個明確:
返回值類型:int
參數列表:int[] arr,int value
*/
public static int getIndex(int[] arr,int value) {
//遍歷數組,依次獲取數組中的每一個元素,和已知的數據進行比較
for(int x=0; x if(arr[x] == value) {
//如果相等,就返回當前的索引值。
return x;
}
}

//目前的代碼有一個小問題
//就是假如我要查找的數據在數組中不存在,那就找不到,找不到,你就對應的返回嗎?
//所以報錯。

//只要是判斷,就可能是false,所以大家要細心。


//如果找不到數據,我們一般返回一個負數即可,而且是返回-1
return -1;
}

public static int getIndex2(int[] arr,int value) {
//定義一個索引
int index = -1;

//有就修改索引值
for(int x=0; x if(arr[x] == value) {
index = x;
break;
}
}

//返回index
return index;
}
}

  1. 上一頁:
  2. 下一頁:
熱門文章
閱讀排行版
Copyright © Android教程網 All Rights Reserved