方法的调用
自定函数(方法)
函数(方法):
给定一个具有独立功能的代码片段进行"命名",并通过该该类名调用"方法"
main主函数
在当前类中,可以直接调用方法(因为方法使用了static关键字)
package study;import java.time.LocalDate;
import java.time.format.DateTimeFormatter;
import java.util.UUID;public class Demo01 {// 自定函数(方法)// 函数(方法):给定一个具有独立功能的代码片段进行"命名",并通过该该类名调用"方法"public static void createorderNo() {// 生成一个订单编号// 订单编号格式规则:// 当前日期+流水号(5位随机数字+字母)// 例如:20240115AX32B// 当前日期:获取当前日期,并转换成字符串// 方式1:// toString():按照默认日期个数yyyy-MM-dd,转换成字符串// String orderNo = LocalDate.now().toString();// 方式2:// format()按照指定日期格式yyyy年MM月dd日,转换成字符串// String orderNo = LocalDate.now().format(DateTimeFormatter.ofPattern("yyyy年MM月dd日"));// format()按照指定日期格式yyyyMMdd,转换成字符串String orderNo = LocalDate.now().format(DateTimeFormatter.ofPattern("yyyyMMdd"));System.out.println(orderNo);// 流水号:String traceId = UUID.randomUUID().toString().substring(0,5).toUpperCase();System.out.println(traceId);// 订单编号=当前日期+流水号orderNo = orderNo + traceId;System.out.println("新订单编号:" + orderNo);}// main主函数public static void main(String[] args) {// 在当前类中,可以直接调用方法(因为方法使用了static关键字)createorderNo();}
}运行结果:
20240306
93F3C
新订单编号:2024030693F3C
Demo02调用Demo01类的createorderNo(),需要通过"类名.方法名"调用
package study;public class Demo02 {public static void main(String[] args) {// 创建新订单编号// 调用Demo01类的createorderNo()// 需要通过"类名.方法名"调用Demo01.createorderNo();}
}运行结果:
20240306
C8560
新订单编号:20240306C8560
定义方法语法结构
访问修饰符[private/public] static 返回值类型 方法名称(参数){ }
[访问修饰符]: 代表该方法可以使用的范围
[static关键字]: 该方法通过类名调用(如果是在当前类类,可以直接调用,类名省略)
[返回值类型]:该方法调用后,产生并返回的结果类型(如果没有返回值,需要使用void)
[方法名称]: 按照该方法的作用,为方法命名
[方法参数]: 按照该方法的作用,为方法设计参数的个数和类型
方法的定义
查找3个int类型参数中的最大值
package study;public class Demo03 {// 方法的定义// 查找3个int类型参数中的最大值public static int max(int a,int b,int c) {int ret = a>b?(a>c?a:c):(b>c?b:c);return ret;}public static void main(String[] args) {// 方法的调用int val1 = max(23,11,45);System.out.println("结果1:"+val1);int val2 = max(21,17,5);System.out.println("结果2:"+val2);}
}运行结果:
结果1:45
结果2:21
动态查找
查找N个int类型整数中的最大值
package study;public class Demo04 {// 动态查找// 查找N个int类型整数中的最大值private static int maxN(int... ns) {int ret = ns[0];for(int i = 1;i < ns.length;i++) {if(ns[i] > ret) {ret = ns[i];}}return ret;}public static void main(String[] args) {// 可以传入N个整数int max = maxN(4,33,55,66,128,41);System.out.println(max);}
}运行结果:
128
两数之和参数
target : 需要查找的目标值参数
numbers : 需要查找的一组整数(动态参数)
注意: 动态参数必须是整个参数列表的最后1部分
package study;public class Demo05 {public static void main(String[] args) {String ret = twoSum(5,1,4,2,3,5,6,7,8,9);System.out.println(ret);}public static String twoSum(int target,int... numbers) {String result = "";outter:for(int i = 0;i <numbers.length-1;i++) {for(int k =i+1;k<numbers.length;k++) {if(numbers[i]+numbers[k] == target) {//1+4=5//result = numbers[i]+"+"+numbers[k]+"="+(numbers[i]+numbers[k]);//String.format():格式化拼接result = String.format("%d+%d=%d",numbers[i],numbers[k],numbers[i]+numbers[k]);//方式1//break outter;//方式2return result;}}}return result;}
}运行结果:
1+4=5
通过方法的调用逆序字符串
package study;public class Demo06 {public static void main(String[] args) {//方法的调用String ret = reverse("忽如一夜春风来");System.out.println(ret);}//方法的定义//字符串逆序//参数s:原始字符串public static String reverse(String s) {String ret = "";
// for(int i = 0;i <s.length();i++) {
// char c = s.charAt(i);
// ret = c+ret;
// }for(int i = s.length()-1;i>=0;i--) {char c = s.charAt(i);ret = ret + c;}return ret;}
}运行结果:
来风春夜一如忽
通过循环计算整数的位数
package study;public class Demo07 {public static void main(String[] args) {int n1 = 12345;int len1 = numberLength(n1);System.out.println(n1+"的长度是"+len1+"位!");int n2 = 789456;int len2 = numberLength(n2);System.out.printf("%d的长度是%d位!",n2,len2);}public static int numberLength(int number) {//方式1:计算该整数以10为底的对数//int ret = (int)Math.log(number) + 1;//return ret;//方式2:通过循环int ret = 0;while(number != 0) {System.out.println("个位数值:" + number%10);ret++;number = number / 10;}return ret;}
}
运行结果:
运行结果:
个位数值:5
个位数值:4
个位数值:3
个位数值:2
个位数值:1
12345的长度是5位!
个位数值:6
个位数值:5
个位数值:4
个位数值:9
个位数值:8
个位数值:7
789456的长度是6位!
方法的传参
基本数据类型的参数:传递"值"
引用数据类型的参数:传递"内存地址"
package study;import java.util.Arrays;public class Demo09 {public static void main(String[] args) {//定义数组,保存一组"需要进行的扩容"的整数int[] array = {1,2,3,4,5};System.out.println("改变前:"+Arrays.toString(array));System.out.println("数组array的内存地址:" + array);//引用数据类型的传参//array传递的是"内存地址"grow2(array);System.out.println("改变后:"+Arrays.toString(array));}//引用数据类型的传参//参数numbers接收的是"内存地址"public static void grow2(int[] numbers) {System.out.println("数组numbers的内存地址:" + numbers);for(int i = 0;i < numbers.length;i++) {numbers[i] = numbers[i] << 1;}System.out.printf("改变中");for(int n : numbers) {System.out.println(n + "\t");}System.out.println();}
}
运行结果:
改变前:[1, 2, 3, 4, 5]
数组array的内存地址:[I@7de26db8
数组numbers的内存地址:[I@7de26db8
改变中2
4
6
8
10 改变后:[2, 4, 6, 8, 10]
通果冒泡排序和二分查找查找数组中的目标元素
package study;import java.util.Arrays;public class Demo10 {public static void main(String[] args) {int[] arr = {4,3,1,23,12,8,17,7,5};
// System.out.println("排序前:"+Arrays.toString(arr));
// sort(arr);
// System.out.println("排序后:"+Arrays.toString(arr));//查找int ret = binarySearch(arr,3);System.out.println("查找的目标值在数组的下标="+ret);}//冒泡排序public static void sort(int[] ns) {for(int i = 0,n = ns.length;i<n-1;i++) {boolean isSort = true;for(int k = 0;k < n-1-i;k++) {if(ns[k] > ns[k+1]) {ns[k] = ns[k] ^ ns[k+1];ns[k+1] = ns[k] ^ ns[k+1];ns[k] = ns[k] ^ ns[k+1];isSort = false;}}if(isSort) {break;}}}//查找(二分查找算法)//参数ns : 要查找的目标数组//参数target : 在目标数组中查找的目标值//返回值:返回目标值在目标数组中的下标,如果不存在,则返回-1public static int binarySearch(int[] ns,int target) {//先排序sort(ns);//在一个方法中调用另一个方法//再二分查找int low = 0,high = ns.length-1;while(low <= high) {int mid = (low + high) >> 1;if(ns[mid] == target) {return mid;}else if(ns[mid] < target) {low = mid+1;}else if(ns[mid] >target) {high = mid-1;} }return -1;}
}
运行结果:
查找的目标值在数组的下标=1
数组旋转调用方法
package study;import java.util.Arrays;public class Demo11 {public static void main(String[] args) {int[] numbers = {1,2,3,4,5,6,7};System.out.println("原始数组"+Arrays.toString(numbers));right(numbers,3);System.out.println("向左旋转"+Arrays.toString(numbers));right(numbers,2);System.out.println("向右旋转"+Arrays.toString(numbers));}// 向右旋转:把尾元素,通过不断交换,移动到数组的"头部"public static void right(int[] ns,int n) {// 向右旋转几次for(int i = 1;i <= n;i++) {for(int k = ns.length-1;k >0;k--) {//每次向右旋转1位ns[k] = ns[k] ^ ns[k-1];ns[k-1] = ns[k] ^ ns[k-1];ns[k] = ns[k] ^ ns[k-1];}}}//向左旋转:把头元素,通过不断交换,移动到数组的"尾部"public static void left(int[] ns,int n) {for(int i = 1;i <= n;i++) {for(int k = 0;k < ns.length-1;k++) {ns[k] = ns[k] ^ ns[k+1];ns[k+1] = ns[k] ^ ns[k+1];ns[k] = ns[k] ^ ns[k+1];}}}
}
运行结果:
原始数组[1, 2, 3, 4, 5, 6, 7]
向左旋转[5, 6, 7, 1, 2, 3, 4]
向右旋转[3, 4, 5, 6, 7, 1, 2]
使用数组,返回查找到的两个下标
package study;import java.util.Arrays;public class Demo12 {public static void main(String[] args) {int[] retArr = twoSum(5,1,4,2,3,5,6,7,8,9);System.out.println(Arrays.toString(retArr));}//使用数组,返回查找到的两个下标public static int[] twoSum(int target,int... numbers) {int[] rets = {-1,-1};outter:for(int i = 0;i <numbers.length-1;i++) {for(int k =i+1;k<numbers.length;k++) {if(numbers[i]+numbers[k] == target) {rets[0] = i;rets[1] = k;break outter;}}}return rets;}
}
运行结果:
[0, 1]
相关文章:

方法的调用
自定函数(方法) 函数(方法): 给定一个具有独立功能的代码片段进行"命名",并通过该该类名调用"方法" main主函数 在当前类中,可以直接调用方法(因为方法使用了static关键字) package study;import java.time.LocalDate; import java.time.format.Date…...

VGW在 Windows 平台上局域网就绪的旁路由器程序
在查阅本篇文章之前可以查看下,本人前两年写的关于VGW软件路由器的文章 Linux 平台上面单网卡 TUN/TAP实现局域网其它设备上网_linux 物理网卡与tun同网段-CSDN博客 VGW软件路由器是一个工作IEEE以太网(L2)链路层的路由器程序,它…...

能源大数据采集,为您提供专业数据采集服务
随着经济的不断发展,能源产业也逐渐成为国民经济的支柱产业之一。而对于能源行业来说,数据采集是一项至关重要的工作。以往,能源企业采集数据主要依靠人工收集、整理,但是这种方式不仅效率低下,而且容易出现数据不准确…...

01_Maven
文章目录 Maven安装MavenMaven的工作流程配置MavenMaven的使用module和project的关系如何用Maven导包 如何用Maven进行项目构建指令介绍clean指令compile指令package指令install指令 Maven的依赖管理如何导包scope作用域依赖传递依赖冲突 使用Maven开发项目Junit如何使用Junit …...

C语言题目练习
目录 前言 1、转置矩阵 1.1 题目 描述 输入描述: 输出描述: 1.2解题 分析: 程序: 2、KiKi判断上三角矩阵 2.1 题目 描述 输入描述: 输出描述: 2.2 解题 分析: 程序: 3、…...

物联网安全|TrustAsia助力PSWG应对全球物联网产品安全合规挑战
万物互联时代,随着物联网连接数快速增长,物联网设备的潜在网络安全隐患也日益增长,可能导致设备故障、数据被盗、篡改、隐私泄露等问题的发生,甚至成为网络攻击的跳板,对互联网基础设施构成严重威胁。 我们看到&#…...

基于单片机的医院输液系统设计
目 录 摘 要 Ⅰ Abstract Ⅱ 引 言 1 1系统方案设计与论证 3 1.1系统硬件结构总体设计方案 3 1.2点滴速度测量电路方案的选择与论证 3 1.3液面检测电路方案的选择与论证 4 1.4通过电机控制滴速电路的方案与论证 4 1.5显示器接口电路方案选择与论证 5 1.6键盘接口电路方案选择与…...

安卓简单登录
注意 有的朋友不知道登录咋写,这里我就简单给出相应代码,用的本地存储,没用网络请求,有需要可以替换成想要的,废话不多上代码 登录 import androidx.appcompat.app.AppCompatActivity;import android.content.Context…...

【计算机网络】DNS/ICMP协议/NAT技术
文章目录 一、DNS(Domain Name System)1.DNS背景2.域名3.浏览器中输入url后,发生的事情 二、ICMP协议1.什么是ICMP协议2.ICM功能3.ICMP的报文格式4.ping命令5.traceroute命令 三、NAT技术1.NAT技术背景2.NAT IP转换过程3.NAPT4.NAT技术的缺陷5.NAT和代理服务器 四、TCP/IP五层模…...

2403C++,C++20协程通道
原文 通道是一个可用来连接协程,实现不同协程间通信的并发安全队列. Test fun test know channel() runBlocking<Unit> {val channel Channel<Int>()//生产者val producer GlobalScope.launch {var i 0while (true) {delay(1000)channel.send(i)println("…...

C语言从入门到实战——预处理详解
预处理详解 前言一、预定义符号1.1 __FILE__1.2__LINE__1.3 __DATE__1.4__TIME__1.5__STDC__ 二、 #define定义常量三、 #define定义宏四、 带有副作用的宏参数五、 宏替换的规则六、宏函数的对比七、 #和##7.1 #运算符7.2 ##运算符 八、 命名约定九、 #undef十、命令行定义十一…...

【LabVIEW FPGA】CIC滤波器
一、CIC滤波器应用概述 在通信数字信号上下变频时,经常会用到对数字信号的升采样和降采样,即通过CIC数字速率器实现变采样率。 二、滤波器IP 首先设置滤波器基本参数(filter specification) 滤波器类型(Filter Type…...

砝码称重 蓝桥杯
在C中,fabs()和abs()都用于计算数字的绝对值,但它们之间有一些区别。 fabs(double x):计算浮点数x的绝对值,返回一个double类型的结果。 abs(int x):计算整数x的绝对值,返回一个int类型的结果。 数组的默…...

AmzTrends x TiDB Serverless:通过云原生改造实现全局成本降低 80%
本文介绍了厦门笛卡尔数据(AmzTrends)在面临数据存储挑战时,选择将其数据分析服务迁移到 TiDB Serverless 的思路和实践。通过全托管的数据库服务,AmzTrends 实现了全局成本降低 80% 的效果,同时也充分展示了 TiDB Ser…...

[最佳实践] Windows上构建一个和Linux类似的Terminal
感谢大佬批评指正,现已更新 preview Target:致力打造最赏心悦目Window下的终端,同时能够很接近Linux的使用习惯 key word:windows终端美化 windows terminal windows powershell 类似Linux下的Window终端 Window也能用ll windows…...

租赁系统|手机租赁软件|租赁系统功能开发
当如今的生活用品越来越多、交流更加便捷时,人们的消费需求也变得越来越丰富。不可避免地,我们会遇到这样一种情况:需要新的手机,但资金有限。此时,手机租赁小程序呼之欲出。这种创意不仅使我们能够充分利用各类闲置物…...

【设计模式 04】建造者模式
如果要构建的对象很复杂,那么可以将整个构建过程拆分成多个步骤,并为每一个步骤定义一个抽象的接口。并添加一个指导者用来控制构建产品的顺序和步骤。 Java实现: // 产品类 class Product {private String part1;private String part2;pub…...

Python使用错误总结
【1】cannot import name ‘ParameterSource’ from ‘click.core’ 其根本原因在于是black模块,其模块版本可能过时,升级black模块版本即可: pip install black --upgrade【2】partially initialized module ‘charset_normalizer’ has n…...

【Java EE初阶三十】JVM的简单学习
1. JVM 内存区域划分 一个运行起来的 Java 进程,就是一个 JVM 虚拟机,需要从操作系统申请一大块内存,就会把这个内存,划分成不同的区域,每个区域都有不同的作用. JVM 申请了一大块内存之后,也会划分成不同的内…...

thinkphp5水平分割表partition,以及查询操作
前言 先交代下背景,在一个项目中,有一个数据表有水平分表的需求。当时想找到一种方法,把对数据库的操作,写到一个模型里,通过去换模型属性中的table来达到代码不变操作的数据表变化的效果。 我们都知道,模型要想关联数据表的话&a…...

docker部署aria2-pro
前言 我平时有一些下载视频和一些资源文件的需求,有时候需要离线下载,也要速度比较快的方式 之前我是用家里的玩客云绝育之后不再写盘当下载机用的,但是限制很多 我发现了aria2 这个下载器非常适合我,而有个大佬又在原来的基础…...

vue中Mixins
使用 Mixins 的主要优点包括: 代码复用: 可以将常用的逻辑封装在 Mixin 中,然后在多个组件中重复使用。逻辑分离: 将不同功能的代码分开管理,使代码更加清晰和易于维护。灵活性: Mixins 允许你在组件中引入多个 Mixin,并且可以根…...

linux常用指令(定期更新)
linux常用指令 1.页相关页大小 2.系统参数3.启动参数4.网络参数查询网卡所属numa节点信息网络测速相关iperf测试sar监控网卡流量查看网卡txqueuelen和mtu抓包tcpdump 网络数据收发状态snmp协议栈netstat -i所有网口TX-OK、RX-OKnetstat-s查看各个协议的收发数据ethtool -S单个网…...

【项目】图书管理系统
目录 前言: 项目要求: 知识储备: 代码实现: Main: Books包: Book: BookList: Operate包: Operate: addOperate: deleteOperate: exitOperate: findOperate:…...

华为OD机试 - 疫情扩散时间计算 - 矩阵(Java 2024 C卷 200分)
目录 专栏导读一、题目描述二、输入描述三、输出描述四、解题思路五、Java算法源码六、效果展示1、输入2、输出3、说明 华为OD机试 2024C卷题库疯狂收录中,刷题点这里 专栏导读 本专栏收录于《华为OD机试(JAVA)真题(A卷B卷C卷&am…...

[数据集][图像分类]棉花叶子病害分类数据集2293张4类别
数据集类型:图像分类用,不可用于目标检测无标注文件 数据集格式:仅仅包含jpg图片,每个类别文件夹下面存放着对应图片 图片数量(jpg文件个数):2293 分类类别数:4 类别名称:["diseased_cotton_leaf"…...

《辐射4》是一款什么样的游戏 怎样在mac电脑上玩到《辐射4》辐射4攻略 辐射4开局加点 怎么在Mac电脑玩Steam游戏
辐射4(Fallout 4)是由Bethesda开发的一款动作角色扮演类游戏,为《辐射》系列游戏作品的第四代,于2015年11月10日发行。游戏叙述了主角一家在核爆当天(2077年10月23日),被Vault-Tec(避…...

视频推拉流EasyDSS平台直播通道重连无法转推的原因排查与解决
视频推拉流EasyDSS视频直播点播平台,集视频直播、点播、转码、管理、录像、检索、时移回看等功能于一体,可提供音视频采集、视频推拉流、播放H.265编码视频、存储、分发等视频能力服务。 用户使用EasyDSS平台对直播通道进行转推,发现只要关闭…...

Javaweb之SpringBootWeb案例之自动配置案例的自定义starter测试的详细解析
3.2.4.3 自定义starter测试 阿里云OSS的starter我们刚才已经定义好了,接下来我们就来做一个测试。 今天的课程资料当中,提供了一个自定义starter的测试工程。我们直接打开文件夹,里面有一个测试工程。测试工程就是springboot-autoconfigurat…...

java包的相关概念
包:有效地管理类的一个机制。 包名的目的:通过隶属不同的包有效的区分不同源文件中名字相同的类 包语句 声明:通过关键字 package声明包语句。 位置:源文件中的第一条语句。 作用:为该源文件中声明的类指定包名。 …...