ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

数组

2022-07-15 09:35:26  阅读:155  来源: 互联网

标签:Arrays int System arrays 数组 out


 

 

JAVA基础学习Day8

数组的定义

  • 数组是相同类型数据的有序集合

  • 数组描述的是相同类型的若干个数据,按照一定的先后次序排列组合而成

  • 其中,每一个数据称作一个数据元素,每隔二数组元素可以通过一个下标来访问

数组声明创建

  • 首先必须声明数组变量,才能在程序中使用数组。下面是语法:

    datatype[] arrayRefVar;//首选
    datatype arrayRefVar[];
  • Java语言使用new操作符来创建数组,语法如下:

    dataType[] arrayRefVar = new dataType[arraySize];
  • 数组的元素是通过索引访问的,数组索引从0开始

  • 获取数组的长度:arrays.length

    • 例:

      package study;

      public class ArrayDemo01 {
         public static void main(String[] args) {
             int[] nums;//1.声明一个数组
             nums = new int[10];//2.创建一个数组
      //       int[] nums2 = new int[10];//1,2融合写法
             //3.给数组元素赋值
             nums[0]=1;
             nums[1]=2;
             nums[2]=3;
             nums[3]=4;
             nums[4]=5;
             nums[5]=6;
             nums[6]=7;
             nums[7]=8;
             nums[8]=9;
             nums[9]=10;

             //计算所有元素的和
             int sum = 0;
             for (int i = 0; i <nums.length; i++) {
                 sum = sum+nums[i];
            }

             System.out.println("元素的和为"+sum);
        }
      }

内存分析

  • 存放new的对象和数组

  • 可以被所有的线程共享,不会存放别的对象引用

  • 存放基本变量类型(包含这个基本类型的具体数值)

  • 引用对象的变量(会存放这个引用在堆里面的具体地址)

方法区

  • 可以被所有的线程共享

  • 包含了所有的class和static变量

数组的基本特点

  1. 其长度是确定的。数组一旦被创建,它的大小就是不可以被改变的。

  2. 其元素必须是相同类型的,不允许出现混合类型

  3. 数组中的元素可以是任何数据类型,包括基本类型和引用类型

  4. 数组变量属于引用类型,数组也可以看成对象,数组中每个元素相当该对象的成员变量。数组本身就是对象,Java中对象是在堆中的,因此数组无论保存原始类型还是其他对象类型,数组对象本身是在堆中的

数组边界

  • 下标的合法区间:[0,length-1],如果越界就会报错

  • java.lang.ArrayIndexOutOfBoundsException 数组下标越界异常

数组的使用

例:

package study;

public class ArrayDemo02 {
   public static void main(String[] args) {
       int[] arrays = {1,2,3,4,5};
       for (int array : arrays) {
           System.out.println(array);
      }
       System.out.println("=========================");

       for (int i = 0; i < arrays.length; i++) {
           System.out.println(arrays[i]);
      }
       //打印数组元素
       printArray(arrays);

       System.out.println("\n=========================");

       int[] reverse = reverse(arrays);
       printArray(reverse);

       System.out.println("\n=========================");

       int max = max(arrays);
       System.out.println(max);
  }
   public static void printArray(int[] arrays){
       for (int i = 0; i < arrays.length; i++) {
           System.out.print(arrays[i]+" ");
      }
  }
   //反转数组
   public static int[] reverse(int[] arrays){
       int[] result = new int[arrays.length];
       for (int i = 0,j = arrays.length - 1; i < arrays.length; i++,j--) {
           result[j] = arrays[i];
      }

       return result;
  }
   //最大值
   public static int max(int[] arrays){
       int max = arrays[0];
       for (int i = 1; i < arrays.length; i++) {
           if(max<arrays[i]){
               max = arrays[i];
          }
      }
       return max;
  }
}

Arrays类

  • 数组的工具类java.util.Arrays

  • 由于数组对象本身并没有什么方法可以供我们调用,但是API中提供了一个工具类Arrays供我们使用,从而可以对数据对象进行一些基本的操作。

  • Arrays类中的方法都是static修饰的静态方法,在使用的时候可以直接使用类名进行调用,而不用使用对象来调用

  • 例:

    package study;

    import java.util.Arrays;

    public class ArrayDemo03 {
       public static void main(String[] args) {
           int[] a = {1,2,6546,96,4585645,89,5};
           System.out.println(a);

           //打印数组元素Arrays.toString
           System.out.println(Arrays.toString(a));

           //对数组元素进行排序Arrays.sort
           Arrays.sort(a);
           System.out.println(Arrays.toString(a));

           //数组填充
           Arrays.fill(a,2,4,0);
           System.out.println(Arrays.toString(a));
      }
    }

冒泡排序

  1. 比较数组中,两个相邻的元素,如果第一个数比第二个大,我们就交换他们的位置

  2. 每一次比较,都会产生一个最大,或者最小的数字

  3. 下一轮则可以少一次排序

  4. 依次循环,直到结束

    package study;

    import java.util.Arrays;

    public class ArraysDemo04 {
       public static void main(String[] args) {
           int[] a = {1,54,567,3,5,657};
           int[] b = sort(a);
           System.out.println(Arrays.toString(b));
      }

       public static int[] sort(int[] array){
           int temp = 0;
           for (int i = 0; i < array.length-1; i++) {
               for (int j = 0; j < array.length-1-i; j++) {
                   if (array[j+1]<array[j]){
                       temp=array[j];
                       array[j]=array[j+1];
                       array[j+1]=temp;
                  }
              }
          }
           return array;
      }
    }

     

  5.  

 

标签:Arrays,int,System,arrays,数组,out
来源: https://www.cnblogs.com/jiangwang-jzh/p/16480148.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有