数组的初始化及其基本属性

数组的初始化及其基本属性数组的初始化及其基本属性1.数组:属于引用类型,就是一个存放同类型变量数据的容器。(容器概念以后再补)2.数组初始化第一种:数据类型[]数组名=new数据类型[数据长度];(动态初始

大家好,又见面了,我是你们的朋友全栈君。

数组的初始化及其基本属性

1. 数组:属于引用类型,就是一个存放同类型变量数据的容器。(容器概念以后再补)

2. 数组初始化

第一种:数据类型[] 数组名 = new 数据类型[数据长度];(动态初始化过程)
int[] arr = new int [5];
第二种:数据类型 数组名[] = {数据1,数据2,数据3……};(静态初始化过程)
int arr[] = {1,2,3,4,5};
动态初始化:我们自己指定了数组长度,系统会自动开辟相应的内存空间,并且给所有位置分配一个默认值。
静态初始化:我们在初始化开始就给定了数组值,系统会根据值的数量,开辟内存空,所以不需要我们指定数组长度。
静态对象还可以用在匿名对象上(参考面向对象的匿名对象)

例:String str = Arrays.toString(new int[] {1,2,3,4,5})(这里的数组没有名字,是临时定义的)

3.访问数组的元素

数组名[下标/索引]引用存储数据的地址(实际上就是使用了指针,而Java中没有指针,故使用引用对象)。

例:int arr[] ={1,2,3,4,5};
 	System.out.println(Arrays.toString(arr));
输出:
	[1,2,3,4,5]
	int arr1[]=arr; //这里是把数组arr引用对象的地址给了arr1,所以这俩数组实际上都是一个东西,
					//对其中一个修改,两边引用的数组都会发生改变。
	arr1[0]=5;
	System.out.println(Arrays.toString(arr));
	System.out.println(Arrays.toString(arr1));
输出:
	[5,2,3,4,5]
	[5,2,3,4,5]

当引用对象赋值给其他对象时,修改的是地址上的数据,所以只要引用这个对象的值都会发生变化。
这里得说说引用传递,值传递。
引用传递:引用传递最终操作的是引用指向JVM虚拟机堆里面存储的数据,所有引用这组数据的引用对象都会受到影响。
值传递:直接对数据进行操作,改变的只是装着这个值的单个变量。

4.数组的基本操作

首先建立一个数组

package com.study.monday;

import java.util.Arrays;
import java.util.Scanner;

public class ArrayPractice2 {

	public static void main(String[] args) {
		/*
		 * 有一个数列:8,4,2,1,23,344,12
		 * 求出最大值 
		 * 数组查找
		 * 数组排序
		 */
		int[] arr= {8,4,2,1,23,344,12};
		System.out.println("最大值为:" + getArrMax(arr));		//获取最大值
		ascOrder(arr);		//升序排列数组
		descOrder(arr);		//降序排列数组
		lookupArr(arr);		//查找数组中是否存在相同的数值
	}

遍历数组的用法,主要是利用for循环来对数组每一个数进行访问使用。

	/*
	 * 方法名:getArrMax
	 * 功能:求出数组的最大值max
	 * 返回值类型:int
	 */
	public static int getArrMax(int arr3[]) {
		int max = arr3[0];
		for (int i = 1; i < arr3.length; i++) {
			max = max > arr3[i] ? max : arr3[i];
		}
		return max;
	}

对数组的排序(冒泡法),检索。(排序、查找单独写一篇详细记录)

	/*
	 * 方法名:lookupArr
	 * 功能:键盘输入一个值,查看数组内是否有相同的值
	 * 返回值类型:void
	 */
	public static void lookupArr(int arr5[]) {
		Scanner input = new Scanner(System.in);
		int a = input.nextInt();
		for (int i = 0; i < arr5.length; i++) {
			if (a == arr5[i]) {
				System.out.println("有!!在a[" + i + "]");
			}
		}
	}
	/*
	 * 方法名:ascOrder
	 * 功能:对数组进行升序排列,并且输出
	 * 返回值类型:void
	 */
	public static void ascOrder(int arr6[]) {
		int a;
		for (int i = 0; i < arr6.length; i++) {
			for (int j = 0; j < arr6.length -1-i; j++) {
				if (arr6[j] > arr6[j + 1]) {
					a = arr6[j];
					arr6[j] = arr6[j + 1];
				    arr6[j + 1] = a;
				}
			}
		}
		System.out.print("升序排列为:");
		printArray(arr6);
	}


这些就是上课老师讲的,我自己理解的,最后汇总出来的。有些东西是老师的,有些是我自己的,我只是把自己认为比较重要的写出来了。关于最后的数组排序,查询,还有上面提到过的程序效率问题,决定单独再写一篇来自己总结一下,八大排序,二分法查询,目前自己已知的程序效率算法。

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

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/154798.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 软件过程改进纪实—从CVS到UnitTest再到Bugzilla

    软件过程改进纪实—从CVS到UnitTest再到Bugzilla

    2021年8月25日
    55
  • 迭代法塔的问题,如果中国

    迭代法塔的问题,如果中国

    2022年1月2日
    43
  • floyed「建议收藏」

    floyed「建议收藏」#include<iostream>#include<cstdio>#include<cstdlib>#include<cstring>#include<algorithm>usingnamespacestd;constintmaxn=405;constintinf=4000005;intd1[maxn][m…

    2022年6月15日
    26
  • Senparc.Weixin.MP SDK 微信公众平台开发教程(三):微信公众平台开发验证

    Senparc.Weixin.MP SDK 微信公众平台开发教程(三):微信公众平台开发验证要对接微信公众平台的”开发模式”,即对接到自己的网站程序,必须在注册成功之后(见Senparc.Weixin.MPSDK微信公众平台开发教程(一):微信公众平台注册),等待官方审核,审核通过之后,会在后台顶部出现“高级功能”菜单。使用“高级功能”>“开发模式”之前,必须有一个已经部署在Internet上,可以用80端口访问的网站(域名或IP访问都可以),一些…

    2022年8月21日
    8
  • oracle普通索引改唯一索引,Oracle唯一索引功能替代[通俗易懂]

    oracle普通索引改唯一索引,Oracle唯一索引功能替代[通俗易懂]Oracle唯一索引在字段全部为NULL时,不做唯一性判断,允许重复插入,而在8t中即使均为NULL值也会做重复值判断,在某些场景下客户会存在此类需求,在数据量不大不存在性能问题的情况下可以考虑通过如下方式进行替代示例表createtable”informix”.secconstitute(iddecimal(20,0)notnull,codevarchar(32),namevar…

    2022年9月16日
    5
  • L2-021 点赞狂魔(排序)「建议收藏」

    L2-021 点赞狂魔(排序)「建议收藏」原题链接微博上有个“点赞”功能,你可以为你喜欢的博文点个赞表示支持。每篇博文都有一些刻画其特性的标签,而你点赞的博文的类型,也间接刻画了你的特性。然而有这么一种人,他们会通过给自己看到的一切内容点赞来狂刷存在感,这种人就被称为“点赞狂魔”。他们点赞的标签非常分散,无法体现出明显的特性。本题就要求你写个程序,通过统计每个人点赞的不同标签的数量,找出前3名点赞狂魔。输入格式:输入在第一行给出一个正整数N(≤100),是待统计的用户数。随后N行,每行列出一位用户的点赞标签。格式为“Name K F​1​

    2022年8月8日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号