메소드는 C 언어의 "함수"와 유사합니다. 방법은 반복적으로 사용될 수 있는 함수로 이해될 수 있습니다.
현재 메소드 작성 시 다음과 같이 작성됩니다.
pubiic 정적 반환 값 반환 이름(공식 매개변수 목록) {
함수 본문/메서드 본문
}
코드 예시 : 1-n의 합을 구합니다.
/** * 求我们1-n的和 * 函数名字必须采用小驼峰 * @param n 输入一个数字 */ public static int sumAdd(int n){ int sum = 0; for(int i = 1;i <= 10;i++){ sum += i; } return sum; } public static void main(String[] args) { int ret = sumAdd(10);//方法的调用 }
그림 설명:
함수 반환 값의 연쇄 호출:
위 예에 따라 예를 들어 보겠습니다.
/** * 求我们1-n的和 * 函数名字必须采用小驼峰 * @param n 输入一个数字 */ public static int sumAdd(int n){ int sum = 0; for(int i = 1;i <= 10;i++){ sum += i; } return sum; } public static void main(String[] args) { int ret = sumAdd(10);//方法的调用 System.out.println(sumAdd(10)*2);//函数的返回值,支持链式调用 }
그림 설명:
Java에는 함수 선언이 없습니다. 함수가 주 함수 위나 아래에 있든 호출할 수 있습니다.
함수에 의해 열린 메모리 공간을 함수 스택 프레임이라고 합니다. 각 함수가 호출되면 스택 프레임이 열립니다. 이 함수의 메모리
메모리 공간에서 함수가 호출되는 방법:
예: 함수 메서드를 사용하여 n의 계승 합을 구합니다.
用函数的方法求n的阶乘之和 public static int Fac(int n) { int sum = 1; for (int i = 1; i <= n; i++) { sum = sum * i; } return sum; } /** * 求n的阶乘之和 * @param */ public static int facSum(int n){ int ret = 0; for (int i = 1;i <= n; i++){ ret = ret + Fac(i); } return ret; } public static void main(String[] args) { System.out.println(facSum(5)); } }
1.Java无法通过传地址的方式交换两个值的变量,后续会讲怎么做 public class TestDemo { public static void swap(int a,int b){//交换两个变量的值 int tmp = a; a = b; b = tmp; } public static void main(String[] args) { int a = 10; int b = 10; System.out.println("交换实参前:"+a+" " +b); swap(&a,b);//Java是做不到取地址的,如果想要写一个函数交换两个数的的值,只能把a和b的值放到堆上 System.out.println("交换实参后:"+a+" " +b); } }
함수를 사용해야 하는 경우가 있습니다. 여러 매개변수가 동시에 호환되는 경우 메소드 오버로딩을 사용할 수 있습니다.
그림 설명:
메소드 이름은 모두 add라고 합니다. 일부 add는 정수의 추가를 계산하고 일부는 double을 추가합니다. 두 숫자의 추가를 계산하고 때로는 세 개의 숫자의 추가를 계산합니다. 이를 메소드 오버로딩이라고 합니다.
예: 세 번의 로그인을 시뮬레이션하는 기능적 방식으로 코드 작성 시나리오
public static void login(){ int count = 3; Scanner scanner = new Scanner(System.in); while(count != 0){ System.out.println("请输入你的密码"); String password = scanner.nextLine(); if(password.equals("123456")){//equals的返回值是true或者false System.out.println("登录成功了"); break; }else{ count--; System.out.println("你输错密码了,你还有"+count+"次机会"); } } } public static void main(String[] args) { login(); }
질문 예: 수선화 수를 찾는 함수
求水仙花数 public static void findNum(int n){ for (int i = 1; i <=n; i++) { int count = 0;//数字的位数 int tmp = i; while(tmp != 0){ count++; tmp = tmp/10; } tmp = i; int sum = 0; while(tmp != 0){ sum += Math.pow(tmp%10,count); tmp/=10; } if(sum == i){ System.out.println(i); } } } public static void main(String[] args) { Scanner scanner = new Scanner(System.in); int n = scanner.nextInt(); findNum(n); }
질문 예: 짝수보다 먼저 홀수를 찾으세요
调整数组顺序使得奇数位于偶数之前,调整之后,不关心大小顺序 public class TestDemo { public static void main(String[] args) { int[]arr = {1,2,3,4,5,6,7,8,9}; int left = 0; int right = arr.length-1; while(left < right){ while(left < right && arr[left] % 2 != 0){ left++; } while(left < right && arr[right] % 2== 0){ right--; } int tmp = arr[left]; arr[left] = arr[right]; arr[right] = tmp; } for (int i = 0; i <arr.length ; i++) { System.out.print(arr[i]+" "); } } }
질문 예: 찾는 함수 세 숫자의 최대값
1.用函数求三个数的最大值 public class TestDemo { public static int Max(int a,int b){ return a > b? a : b; } public static int Max1(int a,int b,int c){ return Max(Max(a,b),c); } public static void main(String[] args) { System.out.println(Max1(4, 6, 8)); } }
위 내용은 Java 메소드 정의 및 사용 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!