2024年java基础语法项目

java基础语法项目public class Test public static void main String args int arr 10 20 swap arr System out println a arr 0 b arr 1 public static

大家好,我是讯享网,很高兴认识大家。



public class Test{

public static void main(String[] args){

int[] arr = {10, 20};

swap(arr);

System.out.println("a = " + arr[0] " b = " + arr[1]);

}

public static void swap(int[] arr){

int tmp = arr[0];

arr[0] = arr[1];

arr[1] = tmp;

}

}

// 运行结果为 a = 20 b = 10

二、方法的重载


1. 重载要解决的问题

什么是重载呢?大家可能都会有这个疑问,接下来我们直接用一个代码,揭开重载的面纱

public class Test{

public static void main(String[] args){

//当我们求两个整数和时

int a1 = 10;

int b1 = 20;

int ret1 = add(a1, b1);

System.out.println("ret1 = " + ret1);

//当我们求两个浮点数和时

double a2 = 1.5;

double b2 = 2.4;

double ret2 = a2 + b2;

System.ouy.println(“ret2 =” + ret2);

}

public static int addInt(int a, int b){

return a + b;

}

public static double addDouble(double a, double b){

return a + b;

}

}

上面我们分别对整数和浮点数求和都写了一个方法,这个做法也是对的。但是 Java 认为 addInt 这样的名字不友好,不如直接就叫 add。啥意思呢,在 java基础语法项目 Java 中上述代码可以写出这样

public class Test{

public static void main(String[] args){

//当我们求两个整数和时

int a1 = 10;

int b1 = 20;

int ret1 = add(a1, b1);

System.out.println("ret1 = " + ret1);

//当我们求两个浮点数和时

double a2 = 1.5;

double b2 = 2.4;

double ret2 = a2 + b2;

System.ouy.println(“ret2 =” + ret2);

}

public static int add(int a, int b){

return a + b;

}

public static double add(double a, double b){

return a + b;

}

}

细心的可以发现我们把方法名都叫作了 add,这个就叫做重载

2. 什么是重载

  1. 含义

同一个方法名字相同,提供不同版本的实现,称为重载

  1. 满足要求
  • 方法名相同
  • 参数列表不同(参数的个数或者参数的类型不同)
  • 返回值不作要求

以上条件都满足时,才是重载。后面我们还会讲到重写,这是面试时时常会被问到的问题

  1. 注意事项

重载不是必须在一个类当中(继承)

三、方法递归


1. 什么是递归

  1. 概念

一个方法在执行过程中调用自身,就称为“递归”

  1. 实行条件
  • 存在限制条件,当满足这个限制条件的时候,递归便不再继续
  • 每次递归调用之后越来越接近这个限制条件

递归其实就是调用自己嘛,如果不存在限制条件只是调用自己的话,就可能有错误,如

public class Test{

public static void main(String[] args){

func();

}

public static void func(){

func();

}

}

上述代码就会栈溢出(StackOverflowError),因为方法调用时都会在栈上开辟内存,无休止的调用就会导致无休止的开辟,使栈溢出

2. 递归执行过程分析

既然知道什么是递归后,我们先来看一个求 n 的阶乘的例子

public class Test{

public static void main(String[] args){

int num = 4;

int ret = factor(num);

System.out.println(ret);

}

public static int factor(int n){

if(n == 1 || n == 0)

return 1;

else

return n * factor(n-1);

}

}

// 结果为24

而接下来我用两种方法为大家分析一下递归的执行过程

  1. 分析方法一
 
 讯享网 
讯享网
  1. 分析方法二在这里插入图片描述
 

3. 递归练习

接下来我们做几个练习,让方法递归的理解更加深刻一些吧!

  1. 按顺序打印一个数字的每一位

public static void print(int num){

if(num < 10)

System.out.print(num);

else{

print(num / 10);

System.out.print(num % 10);

}

}

  1. 求 1 + 2 + … + n 的和

public static int sum(int num){

if(num == 1)

return 1;

else

return num + sum(num - 1);

}

  1. 写一个递归方法,输入一个非负整数,返回组成它的数字之和

public static int sum(int num){

if(num < 10)

return num;

else

return num % 10 + sum(num / 10);

}

  1. 求斐波那契数列数列的第 N 项

public static int fic(int num){

if(num == 1 || num == 2)

return 1;

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

如何快速更新自己的技术积累?

  • 在现有的项目里,深挖技术,比如用到netty可以把相关底层代码和要点都看起来。
  • 如果不知道目前的努力方向,就看自己的领导或公司里技术强的人在学什么。
  • 知道努力方向后不知道该怎么学,就到处去找相关资料然后练习。
  • 学习以后不知道有没有学成,则可以通过面试去检验。

我个人觉得面试也像是一场全新的征程,失败和胜利都是平常之事。所以,劝各位不要因为面试失败而灰心、丧失斗志。也不要因为面试通过而沾沾自喜,等待你的将是更美好的未来,继续加油!

以上面试专题的答小编案整理成面试文档了,文档里有答案详解,以及其他一些大厂面试题目

八年CRUD,疫情备战三个月,三面头条、四面阿里拿offer面经分享

八年CRUD,疫情备战三个月,三面头条、四面阿里拿offer面经分享

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
目前的努力方向,就看自己的领导或公司里技术强的人在学什么。

  • 知道努力方向后不知道该怎么学,就到处去找相关资料然后练习。
  • 学习以后不知道有没有学成,则可以通过面试去检验。

我个人觉得面试也像是一场全新的征程,失败和胜利都是平常之事。所以,劝各位不要因为面试失败而灰心、丧失斗志。也不要因为面试通过而沾沾自喜,等待你的将是更美好的未来,继续加油!

以上面试专题的答小编案整理成面试文档了,文档里有答案详解,以及其他一些大厂面试题目

[外链图片转存中…(img-uc719iNg-41)]

[外链图片转存中…(img-cpqVYMsQ-41)]

小讯
上一篇 2024-12-24 22:51
下一篇 2024-12-24 22:57

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/4573.html