Python Web開發初試,基於Flask
Java方法
什麼是方法
-
Java方法是語句的集合,他們在一起執行一個功能。
-
方法是解決一類問題的步驟的有序組合
-
方法包含於類或物件中
-
方法在程式中被建立,在其他地方被引用
-
-
設計方法的原則:方法的本意是功能塊,就是實現某個功能的語句塊的集合。我們設計方法的時候,最好保持方法的原子性,就是一個方法只完成1個功能,這樣利於我們後期的擴充套件。
-
Java的方法類似於其它語言的函式,是一段用來完成特定功能的程式碼片段,一般情況下,定義一個方法包含以下語法:
-
方法包含一個方法頭和一個方法體。下面是一個方法的所有部分:
-
修飾符:修飾符,這是可選的,告訴編譯器如何呼叫該方法。定義了該方法的訪問型別。
-
返回值型別:方法可能會返回值。returnValueType 是方法返回值的資料型別。有些方法執行所需的操作,但沒有返回值。在這種情況下,returnValueType 是關鍵字void。
-
方法名:是方法的實際名稱。方法名和引數表共同構成方法簽名。
-
引數型別:引數像是一個佔位符。當方法被呼叫時,傳遞值給引數。這個值被稱為實參或變數。引數列表是指方法的引數型別、順序和引數的個數。引數是可選的,方法可以不包含任何引數。
-
形式引數:在方法被呼叫時用於接收外界輸入的資料。用來定義作用的
-
實參:呼叫方法時實際傳給方法的資料。
-
-
方法體:方法體包含具體的語句,定義該方法的功能。
-
修飾符 返回值型別 方法名(引數型別 引數名){
方法體
return 返回值;//return又稱為終止方法 方法裡面碰到return 這個方法就終止了。
}
-
方法呼叫
-
呼叫方法:物件名.方法名(實參列表)
-
Java支援兩種呼叫方法的方式,根據方法是否返回值來選擇
-
當方法返回一個值的時候,方法呼叫通常被當做一個值,例如:
-
int larger = max(30,40)
-
如果方法返回值是void,方法呼叫一定是一條語句。
-
值傳遞(Java) 和 引用傳遞
方法的過載
-
過載就是在一個類中,有相同的函式名稱,但形參不同的函式。
-
方法的過載規則:
-
方法名必須相同。
-
引數列表必須不同(個數不同 或 型別不同 或 引數排列順序{不能只有一種引數型別}
-
不同等)
-
方法的返回型別可以相同也可以不相同。
-
僅僅返回型別不同不足以成為方法的過載。
-
-
實現理論:
-
方法名稱相同時,編譯器會根據呼叫方法的引數個數、引數型別等去逐個匹配,以選擇對應的方法,如果匹配失敗,則編譯器報錯。
-
-
public class MethodDemo02 {
public static void main(String[] args) {
int num = max(10, 20);
System.out.println(num);
}
//比大小
public static double max(double num1 , int num2){
double result = 0;
if (num1==num2){
System.out.println("num1==num2");
return 0;
}
if (num1>num2){
result = num1;
}else {
result = num2;
}
return result;
}
public static double max( int num2, double num1 ){
double result = 0;
if (num1==num2){
System.out.println("num1==num2");
return 0;
}
if (num1>num2){
result = num1;
}else {
result = num2;
}
return result;
}
public static double max(double num1 , double num2){
double result = 0;
if (num1==num2){
System.out.println("num1==num2");
return 0;
}
if (num1>num2){
result = num1;
}else {
result = num2;
}
return result;
}
public static int max(int num1 , int num2){
int result = 0;
if (num1==num2){
System.out.println("num1==num2");
return 0;
}
if (num1>num2){
result = num1;
}else {
result = num2;
}
return result;
}
} -
命令列傳參
可變引數(不定項引數)
-
JDK 1.5開始,Java支援傳遞同類型的可變引數給一個方法。
-
在方法宣告中,在指定引數型別後加一個省略號(...)。
-
一個方法中只能指定一個可變引數,他必須是方法的最後一個引數。任何普通的引數必須在它之前宣告。
-
public class MethodDemo04 {
public static void main(String[] args) {
printMax(34,3,3,2,56.5);
printMax(new double[]{1,2,3});
}
public static void printMax(double...numbers){
if (numbers.length==0){
System.out.println("沒有最大數!");
return;
}
double result = numbers[0];
for (int i = 1; i < numbers.length ; i++) {
if (numbers[i]> result){
result = numbers[i];
}
}
System.out.println("最大值是:"+result);
}
}
遞迴
-
什麼是遞迴 :A方法呼叫A方法!就是自己呼叫自己
-
利用遞迴可以用簡單的程式來解決一些複雜的問題。它通常把一個大型複雜的問題層層轉化為一個與原問題相似的規模較小的問題來求解,遞迴策略只需要少量的程式就可描述出解題過程所需要的多次重複計算,大大地減少了程式的程式碼量。遞迴的能力在於用有限的語句來定義物件的無限集合。
-
遞迴結構包括兩個部分
-
遞迴頭:什麼時候不呼叫自身方法。如果沒有頭,將陷入死迴圈。
-
遞迴體:什麼時候需要呼叫自身方法。
-
public class MethodDemo06 {
public static void main(String[] args) {
System.out.println(f(5));
}
public static int f(int n){
if (n==1){
return 1;
}
return n*f(n-1);
}
}
//計算器
import java.util.Scanner;
public class Demo {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
System.out.println("請輸入你要選擇的運算子");
String s = scanner.nextLine();
switch (s){
case "+":
System.out.println("請輸入第一個數:");
int a = scanner.nextInt();
System.out.println("請輸入第二個數:");
int b = scanner.nextInt();
System.out.println("計算結果為:"+add(a,b));
break;
case "-":
System.out.println("請輸入第一個數:");
int c = scanner.nextInt();
System.out.println("請輸入第二個數:");
int d = scanner.nextInt();
System.out.println("計算結果為:"+app(c,d));
break;
case "*":
System.out.println("請輸入第一個數:");
int e = scanner.nextInt();
System.out.println("請輸入第二個數:");
int f = scanner.nextInt();
System.out.println("計算結果為:"+mul(e,f));
break;
case "/":
System.out.println("請輸入第一個數:");
int g = scanner.nextInt();
System.out.println("請輸入第二個數:");
int h = scanner.nextInt();
System.out.println("計算結果為:"+chu(g,h));
break;
}
}
//加法
public static int add(int a, int b){
return a+b;
}
//減法
public static int app(int a ,int b){
return a-b;
}
//乘法
public static double mul(int a , int b){
return a*b;
}
//除法
public static double