热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

javase的基础知识

本文主要介绍关于java,intellij-idea,程序人生的知识点,对【【JavaSE】“方法”论—《方法的概念及使用》】和【javase的基础知识】有兴趣的朋友可以看下由【eat_slee

本文主要介绍关于java,intellij-idea,程序人生的知识点,对【【Java SE】“方法”论 — 《方法的概念及使用》】和【javase的基础知识】有兴趣的朋友可以看下由【eat_sleep_play( )】投稿的技术文章,希望该技术和经验能帮到你解决你所遇的Java零基础入门到进阶相关技术问题。

javase的基础知识

目录

方法的概念及使用

1.什么是方法

2.方法的定义

方法语法格式及代码示例

【注意事项】

3.方法调用的执行过程

执行过程和注意事项

4.实际参数和形式参数(重要)

5.没有返回值的方法


 

方法的概念及使用 1.什么是方法

相当于C语言中的函数,可以用来将代码封装起来,一个模块一个模块的代码片断。

是能够模块化的组织代码(当代码规模比较复杂的时候).做到代码被重复使用, 一份代码可以在多个位置使用.让代码更好理解更简单.直接调用现有方法开发, 不必重复造轮子.
 

2.方法的定义 方法语法格式及代码示例


//方法定义
修饰符 返回值类型 方法名称([参数类型 形参 ...]){
方法体代码;
[return 返回值];
}
 

代码示例1:写一个方法,检查一个年份是否为闰年

 public static int isleapyear(int year) {
        if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0) {
            return 1;
        }else {
            return -1;
        }
 }
    public static void main(String[] args) {
        int ret = isleapyear(2022);
        if (1 == ret) {
            System.out.println("2022是闰年");
        }else {
            System.out.println("2022不是闰年");
        }
 }

代码结果:

 

代码示例2:写一个方法,实现两个整数相减的方法

public static int sub(int x, int y) {
       return x - y;
}

    public static void main(String[] args) {
        int ret = sub(10, 5);
        System.out.println(ret);
}

代码结果:

 

【注意事项】 修饰符:现阶段直接使用public static 固定搭配返回值类型:如果方法有返回值,返回值类型必须要与返回的实体类型一致,如果没有返回值,必须写成void方法名字:采用小驼峰命名参数列表:如果方法没有参数,()中什么都不写,如果有参数,需指定参数类型,多个参数之间使用逗号隔开方法体:方法内部要执行的语句在java当中,方法必须写在类当中在java当中,方法不能嵌套定义在java当中,没有方法声明一说
 

3.方法调用的执行过程

执行过程和注意事项

做菜的过程就相当于是方法;食材就相当于是参数。 

【注意事项】

 定义方法的时候, 不会执行方法的代码. 只有调用的时候才会执行.一个方法可以被多次调用.

代码示例1:写一个方法,计算两个整数相乘

public  static int mul(int x, int y) {
        return x * y;
}

    public static void main(String[] args) {
        int ret1 = mul(3, 7);
        int ret2 = mul(10, 10);
        System.out.println("ret1:" + ret1);
        System.out.println("ret2:" + ret2);
}

代码结果:

 

代码示例2:计算1! + 2! + 3! + 4! + 5!

public static int fac(int num) {
        int ret = 1;
        for (int i = 1; i <= num ; i++) {
            ret *= i;
        }
        return ret;
}

    public static void main(String[] args) {
        int sum = 0;
        for (int i = 1; i <= 5; i++) {
            sum += fac(i);
        }
        System.out.println(sum);
}

代码结果:

 

4.实际参数和形式参数(重要)

形参的名字可以随意取,对方法都没有任何影响,形参只是方法在定义时需要借助的一个变量,用来保存方法在调用时传递过来的值
 

public static int getSum(int N){ // N是形参
return (1+N)*N / 2;
}

getSum(100); // 100是实参,在方法调用时,形参N用来保存10
getSum(1000); // 1000是实参,在方法调用时,形参N用来保存100
 

一个加法方法的例子

public static int add(int a, int b){
return a + b;
}

add(2, 3); // 2和3是实参,在调用时传给形参a和b

图解

 注意:在Java中,实参的值永远都是拷贝到形参中,形参和实参本质是两个实体

 

代码示例:写一个方法,交换两个整形的值。

public static void swap(int x, int y) {
     int tmp = x;
     x = y;
     y = tmp;
     System.out.println("交换后:" + "x = " + x + "y = " + y);
}

public static void main(String[] args) {
     int a = 4;
     int b = 6;
     swap(4, 6);
     System.out.println("交换前:" + "a = " + a + "b = " + b);
}

代码结果:

 

可以看到,在swap函数交换之后,形参x和y的值发生了改变,但是main方法中x和y还是交换之前的值,即没有交换成功

 【原因分析】

实参a和b是main方法中的两个变量,其空间在main方法的栈(一块特殊的内存空间)中,而形参x和y是swap方法中的两个变量,x和y的空间在swap方法运行时的栈中,因此:实参a和b 与 形参x和y是两个没有任何关联性的变量,在swap方法调用时,只是将实参a和b中的值拷贝了一份传递给了形参x和y,因此对形参x和y操作不会对实参a和b产生任何影响
 

注意:对于基础类型来说, 形参相当于实参的拷贝. 即 传值调用
 

【解决办法】

传引用类型参数 (例如数组来解决这个问题)

这个代码的运行过程, 后面学习数组的时候再详细解释

public static void main(String[] args) {
        int[] arr = {10, 20};
        swap(arr);
        System.out.println("arr[0] = " + arr[0] + " arr[1] = " + arr[1]);
}
    public static void swap(int[] arr) {
        int tmp = arr[0];
        arr[0] = arr[1];
        arr[1] = tmp;
}

代码结果:

 

5.没有返回值的方法

当一个方法没有返回值的时候,返回类型必须写为 void 

代码示例1:写一个方法,求两个整数的和,要求不设计返回值

public static void add(int x, int y) {
        int sum = x + y;
        System.out.println(sum);
}

    public static void main(String[] args) {
        int a = 10;
        int b = 20;
        add(a, b);
}

代码结果:

 

代码示例2:写一个方法并设计一个返回值,求两个整数的和

public static int add(int x, int y) {
        return x + y;
}

    public static void main(String[] args) {
        int a = 10;
        int b = 20;
        System.out.println(add(a, b));
}

代码结果:

这两个示例都是求两个整数的和,区别是示例没有返回值;而示例2有返回值。 

本文《【Java SE】“方法”论 — 《方法的概念及使用》》版权归eat_sleep_play( )所有,引用【Java SE】“方法”论 — 《方法的概念及使用》需遵循CC 4.0 BY-SA版权协议。


推荐阅读
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
  • This article discusses the efficiency of using char str[] and char *str and whether there is any reason to prefer one over the other. It explains the difference between the two and provides an example to illustrate their usage. ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • C# 7.0 新特性:基于Tuple的“多”返回值方法
    本文介绍了C# 7.0中基于Tuple的“多”返回值方法的使用。通过对C# 6.0及更早版本的做法进行回顾,提出了问题:如何使一个方法可返回多个返回值。然后详细介绍了C# 7.0中使用Tuple的写法,并给出了示例代码。最后,总结了该新特性的优点。 ... [详细]
  • 从零学Java(10)之方法详解,喷打野你真的没我6!
    本文介绍了从零学Java系列中的第10篇文章,详解了Java中的方法。同时讨论了打野过程中喷打野的影响,以及金色打野刀对经济的增加和线上队友经济的影响。指出喷打野会导致线上经济的消减和影响队伍的团结。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • 本文讨论了一个数列求和问题,该数列按照一定规律生成。通过观察数列的规律,我们可以得出求解该问题的算法。具体算法为计算前n项i*f[i]的和,其中f[i]表示数列中有i个数字。根据参考的思路,我们可以将算法的时间复杂度控制在O(n),即计算到5e5即可满足1e9的要求。 ... [详细]
  • C语言判断正整数能否被整除的程序
    本文介绍了使用C语言编写的判断正整数能否被整除的程序,包括输入一个三位正整数,判断是否能被3整除且至少包含数字3的方法。同时还介绍了使用qsort函数进行快速排序的算法。 ... [详细]
author-avatar
速度向前迈进
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有