Java学习-详述main方法、可变参数、数组的工具类、二维数组

详述main方法

【1】main方法:程序的入口,在同一个类中,如果有多个方法,那么虚拟机就会识别main方法,从这个方法作为程序的入口

【2】main方法格式严格要求:

public static void main(String[] args){}

public static --->修饰符 ,暂时用这个 -->面向对象一章

void --->代表方法没有返回值 对应的类型void

main --->见名知意名字

String[] args  --->形参  ---》不确定因素

【3】问题:程序中是否可以有其他的方法也叫main方法?

可以,构成了方法的重载。

  1. public class TestArray10{
  2.     public static void main(String[] args){
  3.                 
  4.         }
  5.         public static void main(String str){
  6.                 
  7.         }
  8. }

【4】形参为String[] 那么实参到底是什么?

  1. public class TestArray10{
  2.     public static void main(String[] args){
  3.                 //从侧面验证:
  4.                 //int[] arr1; //如果对数组只声明,没有后续操作,那么相当于 白定义了。
  5.                 //int[] arr2 = null;
  6.                 //System.out.println(arr2.length);//Exception in thread "main" java.lang.NullPointerException
  7.                 //int[] arr3 = new int[0];
  8.                 //System.out.println(arr3.length);
  9.                 //int[] arr4 = new int[4];
  10.                 //System.out.println(arr4.length);
  11.                
  12.                 //System.out.println(args.length);//0
  13.                 //从这个结果证明,参数是String[],实参是  new String[0]
  14.                 //默认情况下,虚拟机在调用main方法的时候就是传入了一个长度为0的数组
  15.                
  16.                 System.out.println(args.length);
  17.                 for(String str:args){
  18.                         System.out.println(str);
  19.                 }
  20.         }
  21. }

手动传入实参:

有特殊符号的时候可以加上“”

没有特殊符号用空格隔开即可:

可变参数
  1. public class TestArray12{
  2.         /*
  3.         1.可变参数:作用提供了一个方法,参数的个数是可变的 ,解决了部分方法的重载问题
  4.         int...num
  5.         double...num
  6.         boolean...num
  7.         
  8.         
  9.         2.可变参数在JDK1.5之后加入的新特性
  10.         3.方法的内部对可变参数的处理跟数组是一样
  11.         4.可变参数和其他数据一起作为形参的时候,可变参数一定要放在最后
  12.         5.我们自己在写代码的时候,建议不要使用可变参数。
  13.         */
  14.     public static void main(String[] args){
  15.                 //method01(10);
  16.                 //method01();
  17.                 //method01(20,30,40);
  18.                 method01(30,40,50,60,70);
  19.                 //method01(new int[]{11,22,33,44});
  20.         }
  21.         public static void method01(int num2,int...num){
  22.                 System.out.println("-----1");
  23.                 for(int i:num){
  24.                         System.out.print(i+"\t");
  25.                 }
  26.                 System.out.println();
  27.                
  28.                 System.out.println(num2);
  29.         }
  30. }

Arrays工具类

为了方便我们对数组进行操作,系统提供一个类Arrays,我们将它当做工具类来使用。

  1. import java.util.Arrays;
  2. public class TestArray13{
  3.         public static void main(String[] args){
  4.                 //给定一个数组:
  5.                 int[] arr = {1,3,7,2,4,8};
  6.                 //toString:对数组进行遍历查看的,返回的是一个字符串,这个字符串比较好看
  7.                 System.out.println(Arrays.toString(arr));
  8.                 
  9.                 //binarySearch:二分法查找:找出指定数组中的指定元素对应的索引:
  10.                 //这个方法的使用前提:一定要查看的是一个有序的数组:
  11.                 //sort:排序 -->升序
  12.                 Arrays.sort(arr);
  13.                 System.out.println(Arrays.toString(arr));
  14.                 System.out.println(Arrays.binarySearch(arr,4));
  15.                
  16.                 int[] arr2 = {1,3,7,2,4,8};
  17.                 //copyOf:完成数组的复制:
  18.                 int[] newArr = Arrays.copyOf(arr2,4);
  19.                 System.out.println(Arrays.toString(newArr));
  20.                
  21.                 //copyOfRange:区间复制:
  22.                 int[] newArr2 = Arrays.copyOfRange(arr2,1,4);//[1,4)-->1,2,3位置
  23.                 System.out.println(Arrays.toString(newArr2));
  24.                
  25.                 //equals:比较两个数组的值是否一样:
  26.                 int[] arr3 = {1,3,7,2,4,8};
  27.                 int[] arr4 = {1,3,7,2,4,8};
  28.                 System.out.println(Arrays.equals(arr3,arr4));//true
  29.                 System.out.println(arr3==arr4);//false ==比较左右两侧的值是否相等,比较的是左右的地址值,返回结果一定是false
  30.                
  31.                 //fill:数组的填充:
  32.                 int[] arr5 = {1,3,7,2,4,8};
  33.                 Arrays.fill(arr5,10);
  34.                 System.out.println(Arrays.toString(arr5));
  35.         }
  36. }

数组的复制操作

原理:

代码:

  1. import java.util.Arrays;
  2. public class TestArray14{
  3.         public static void main(String[] args){
  4.                 //给一个源数组:
  5.                 int[] srcArr = {11,22,33,44,55,66,77,88};
  6.                 //给一个目标数组:
  7.                 int[] destArr = new int[10];
  8.                 
  9.                 //复制:
  10.                 System.arraycopy(srcArr,1,destArr,3,3);
  11.                 //遍历查看目标数组:
  12.                 System.out.println(Arrays.toString(destArr));
  13.         }
  14.        
  15. }

结果:

二维数组

【1】引入:本质上全部都是一维数组:

【2】基本代码:

  1. public class TestArray15{
  2.         public static void main(String[] args){
  3.                 //定义一个二维数组:
  4.                 int[][] arr = new int[3][];//本质上定义了一个一维数组,长度为3
  5.                 
  6.                 int[] a1 = {1,2,3};
  7.                 arr[0] = a1;
  8.                 
  9.                 arr[1] = new int[]{4,5,6,7};
  10.                
  11.                 arr[2] = new int[]{9,10};
  12.         }
  13. }

对应内存:

【3】四种遍历方式:

  1. public class TestArray15{
  2.         public static void main(String[] args){
  3.                 //定义一个二维数组:
  4.                 int[][] arr = new int[3][];//本质上定义了一个一维数组,长度为3
  5.                 
  6.                 int[] a1 = {1,2,3};
  7.                 arr[0] = a1;
  8.                 
  9.                 arr[1] = new int[]{4,5,6,7};
  10.                
  11.                 arr[2] = new int[]{9,10};
  12.                
  13.                 //读取6这个元素:
  14.                 //System.out.println(arr[1][2]);
  15.                
  16.                 //对二维数组遍历:
  17.                 //方式1:外层普通for循环+内层普通for循环:
  18.                 for(int i=0;i<arr.length;i++){
  19.                         for(int j=0;j<arr[i].length;j++){
  20.                                 System.out.print(arr[i][j]+"\t");
  21.                         }
  22.                         System.out.println();
  23.                 }
  24.                
  25.                 //方式2:外层普通for循环+内层增强for循环:
  26.                 for(int i=0;i<arr.length;i++){
  27.                         for(int num:arr[i]){
  28.                                 System.out.print(num+"\t");
  29.                         }
  30.                         System.out.println();
  31.                 }
  32.                 
  33.                 //方式3:外层增强for循环+内层增强for循环:
  34.                 for(int[] a:arr){
  35.                         for(int num:a){
  36.                                 System.out.print(num+"\t");
  37.                         }
  38.                         System.out.println();
  39.                 }
  40.                
  41.                 //方式4:外层增强for循环+内层普通for循环:
  42.                 for(int[] a:arr){
  43.                         for(int i=0;i<a.length;i++){
  44.                                 System.out.print(a[i]+"\t");
  45.                         }
  46.                         System.out.println();
  47.                 }
  48.         }
  49. }

二维数组的初始化方式

数组的初始化方式总共有三种:静态初始化、动态初始化、默认初始化。

  • 静态初始化

除了用new关键字来产生数组以外,还可以直接在定义数组的同时就为数组元素分配空间并赋值。

eg:

int[][] arr = {{1,2},{4,5,6},{4,5,6,7,8,9,9}};

int[][] arr =new int[][] {{1,2},{4,5,6},{4,5,6,7,8,9,9}};

  • 动态初始化

数组定义与为数组元素分配空间并赋值的操作分开进行。

eg:

int[][] arr = new int[3][]; //本质上定义了一维数组长度为3,每个“格子”中放入的是一个数组

arr[0] = new int[]{1,2};

arr[1] = new int[]{3,4,5,6};

arr[2] = new int[]{34,45,56};

eg:

int[][] arr = new int[3][2]; 

public class TestArray16{

        public static void main(String[] args){

                int[][] arr = new int[3][2];

                //本质上:定义一维数组,长度为3,每个数组“格子”中,有一个默认的长度为2的数组:

                arr[1] = new int[]{1,2,3,4};

                //数组遍历:

                for(int[] a:arr){

                        for(int num:a){

                                        System.out.print(num+"\t");

                        }

                        System.out.println();

                }

        }

}

  • 默认初始化

数组是引用类型,它的元素相当于类的实例变量,因此数组一经分配空间,其中的每个元素也被按照实例变量同样的方式被隐式初始化。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/555771.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【NOI-题解】1320. 时钟旋转1323. 扩建花圃问题1462. 小明的游泳时间1565. 成绩(score)1345. 玫瑰花圃

文章目录 一、前言二、问题问题&#xff1a;1320. 时钟旋转问题&#xff1a;1323. 扩建花圃问题问题&#xff1a;1462. 小明的游泳时间问题&#xff1a;1565. 成绩&#xff08;score&#xff09;问题&#xff1a;1345. 玫瑰花圃 三、感谢 一、前言 本章节主要对基本运算中整数…

Windows系统搭建Plex网站结合内网穿透实现公网访问本地影音文件

文章目录 1.前言2. Plex网站搭建2.1 Plex下载和安装2.2 Plex网页测试2.3 cpolar的安装和注册 3. 本地网页发布3.1 Cpolar云端设置3.2 Cpolar本地设置 4. 公网访问测试5. 结语 1.前言 用手机或者平板电脑看视频&#xff0c;已经算是生活中稀松平常的场景了&#xff0c;特别是各…

奶酪——并查集,BFS,DFS(NOIP2017提高组)

目录 题目 思路 并查集 代码&#xff08;java&#xff09; BFS&#xff08;DFS同理&#xff09; 代码&#xff08;C&#xff09; 题目 思路 这个题目意思是有很多个球分布在一个三维空间内&#xff0c;如果这些球相切或者相交都可以互相到达&#xff0c;我们需要判断能否…

二、e2studio VS STM32CubeIDE之功能对比

目录 一、概述/目的 二、官网资料 2.1 stm32cubeide 2.2 e2studio 三、功能对比 二、e2studio VS STM32CubeIDE之功能对比 一、概述/目的 通过对比学习&#xff0c;更快速的掌握两款IDE 二、官网资料 2.1 stm32cubeide https://www.stmcu.com.cn/ecosystem/Cube/STM32C…

41、二叉树-二叉树的层序遍历

思路&#xff1a; 层序遍历就是从左到右依次遍历。这个时候就可以使用队列的方式。例如先把头节点入队&#xff0c;然后遍历开始&#xff0c;首先计算队列长度&#xff0c;第一层&#xff0c;长度为了&#xff0c;遍历一次&#xff0c;依次出队&#xff0c;头结点出队&#xff…

Codeforces Round 924 (Div. 2) ---- F. Digital Patterns ---- 题解

F. Digital Patterns&#xff1a; 题目描述&#xff1a; 思路解析&#xff1a; 要求在一个方块中&#xff0c;任意相邻的方块中他的透明度系数不能相同&#xff0c;这样的方块称为趣味性方块&#xff0c;问这样的方块有多少种。 那么我们可以相当&#xff0c;假设 a1 a2, 那…

iOS ------ Block的总结

前面看了Block的基本知识&#xff0c;和一些源码。但对于block怎么用的还不了解&#xff0c;代码中出现block会看不懂&#xff0c;现在来具体看一下Block的用法并做个总结。 1.Block是什么 block对象是一个C语言结构体&#xff0c;可以并入C和OC的代码中&#xff0c;Block本质…

每日OJ题_多源BFS①_力扣542. 01 矩阵(多源BFS解决最短路原理)

目录 多源BFS解决最短路算法原理 力扣542. 01 矩阵 解析代码 多源BFS解决最短路算法原理 什么是单源最短路 / 多源最短路&#xff1f; 之前的BFS解决最短路都是解决的单源最短路。 画图来说&#xff0c;单源最短路问题即为&#xff1a; 而对于多源最短路问题: 如何解决此…

微信小程序之点击事件

微信小程序中常用的点击事件主要是 tap&#xff0c;但除此之外还有其他的触摸类事件&#xff0c;用于不同的交互场景。以下是一些常见的点击和触摸相关的事件及其区别&#xff1a; 1、tap——最基本的点击事件&#xff0c;适用于一般的轻触交互&#xff0c;类似于 HTML 中的 c…

Pixverse:开启文生视频与图生视频新纪元

✨✨ 欢迎大家来访Srlua的博文&#xff08;づ&#xffe3;3&#xffe3;&#xff09;づ╭❤&#xff5e;✨✨ &#x1f31f;&#x1f31f; 欢迎各位亲爱的读者&#xff0c;感谢你们抽出宝贵的时间来阅读我的文章。 我是Srlua小谢&#xff0c;在这里我会分享我的知识和经验。&am…

NPU流式输出-torch_npu和transformers框架-多线程Streamer-昇腾910B-EE1001

前情提要 torch_npu框架不支持多线程自动set_device 报错详情 直接使用transformers的TextIteratorStreamer进行流式推理&#xff0c;会报错 Exception in thread Thread-6: Traceback (most recent call last):File "/root/anaconda3/envs/AI/lib/python3.9/threadin…

Linux shell 脚本基础与部署SpringCloud实战

博主介绍&#xff1a;✌全网粉丝5W&#xff0c;全栈开发工程师&#xff0c;从事多年软件开发&#xff0c;在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战&#xff0c;博主也曾写过优秀论文&#xff0c;查重率极低&#xff0c;在这方面有丰富的经验…

L2正则化——解释为什么可以减少模型的复杂度

L2正则化是一种用于机器学习模型的技术&#xff0c;旨在减少模型的复杂度&#xff0c;从而提高其泛化能力。在L2正则化中&#xff0c;通过添加一个惩罚项&#xff0c;模型的权重被迫保持较小的值&#xff0c;这有助于防止过拟合&#xff0c;即模型在训练数据上表现良好但在未见…

python学习笔记B-07:序列结构之列表--列表的常用函数和方法

以xx_函数名(列表名)的形式出现的是函数&#xff1b;以xx_列表名.xx_方法名的形式出现的是方法。 列表常用函数如下&#xff1a; len()&#xff1a;计算列表元素数量 max()&#xff1a;获取列表元素最大值 min():获取列表元素最小值 sum():计算列表中各元素之和 列表常用方法如…

【Java EE】文件操作

目录 1.认识文件 2.树型结构组织和目录 3.文件路径&#xff08;Path&#xff09; 4.其他知识 5.Java中操作文件 5.1File概述 5.1.1属性 5.1.2构造方法 5.1.3方法 5.2代码示例 1.认识文件 我们先来认识狭义的文件&#xff08;file&#xff09;。针对1硬盘这种持久化存…

HTML重要标签梳理学习

1、HTML文件的框架 使用VS Code编码时&#xff0c;输入!选中第一个&#xff01;就可以快速生成一个HTML文件框架。 2、标签 <hr> <!--下划线--> <br> <!--换行--> <strong>加粗</strong> &…

MySQL行级锁——技术深度+1

引言 本文是对MySQL行级锁的学习&#xff0c;MySQL一直停留在会用的阶段&#xff0c;需要弄清楚锁和事务的原理并DEBUG查看。 PS:本文涉及到的表结构均可从https://github.com/WeiXiao-Hyy/blog中获取&#xff0c;欢迎Star&#xff01; MySQL行级锁 行级锁&#xff08;Row-…

案例研究 | JumpServer助力天虹股份构建可靠的运维安全审计平台

天虹数科商业股份有限公司&#xff08;以下简称为“天虹股份”&#xff09;成立于1984年&#xff0c;是国有控股的上市公司。通过人本、科学的管理&#xff0c;以及专业、高效的运营&#xff0c;天虹股份连续多年入围中国连锁百强企业&#xff0c;拥有全国领先的零售技术研发和…

vue3 项目启动时vite版本问题报错

背景&#xff1a; 我是在项目迁移过程中遇到的这个问题&#xff0c;前提可以看下面这篇 http://t.csdnimg.cn/g70Eq 问题描述 迁移项目时&#xff0c;将项目整体升级到了vue3版本&#xff0c;启动项目时出现下列报错&#xff1a; npm ERR! Found: vite5.1.4 npm ERR! node_…

2024-2.基础操作-Python

Jupiter基本使用 cell有两种模式&#xff1a; codemarkdown 快捷键 新建cell&#xff1a;a,b删除cell&#xff1a;dd&#xff0c;x运行cell&#xff1a;shiftenter切换cell模式&#xff1a; m&#xff1a;将code模式的cell切换到mdy:将md模式的cell切换到code 智能补全&#x…