工作小驿

Ninja!

BlogJava 首页 新随笔 联系 聚合 管理
  103 Posts :: 0 Stories :: 36 Comments :: 0 Trackbacks
      今天我们讲个不一样的概念――数组,数组也没什么不好理解的,就是一组数。不过这组数有点特性。今天我们的任务就是,了解这个有特性的这组数。下面我们具体讲一下它有哪些特性:

1、数组中的元素是同一类型。数组的长度在创建时确定,并且在创建后不变。解释一下 声明一个数组 int i[5]; 这就是int类型,名字叫i的数组。里面的数都必须是int类型。并且长度在创建时确定了是5。

     2、在java语言中,数组就是一个对象,所以创建数组与创建对象一样也是用new关键字来创建。举个例子,s = new char[20]; p = new Point[50];

     3、数组在被创建后,其元素被系统自动初始化了。字符元素被初始化为‘\u0000’,而对于对象数组都被初始化为null。 如果你不初始化的话,在内存是找不到它的位置的。

     4、数组中的第一元素记做第0个,i[0]是数组i 的第一个元素。

     说了这么些,我们还是得练练啊

实践:

public class TestArrays {

  public static void main(String[] args) {

    // 第1,2步: 声明并初始化数组变量

    int[]  array1 = { 2, 3, 5, 7, 11, 13, 17, 19 };

    int[]  array2;



    // 第3步: 显示数组初始化值

    System.out.print("array1 is ");

    printArray(array1);

    System.out.println();

    // 第4步: array2引用array1

    array2 = array1;

    // 更改array2

    array2[0] = 0;

    array2[2] = 2;

    array2[4] = 4;

    array2[6] = 6;

    // 打印array1

    System.out.print("array1 is ");

    printArray(array1);

    System.out.println();

    // 第5步: 声明一个整数类型的二维数组

    int[][] matrix = new int[5][];

    // 第6步: 将这个矩阵构成三角形

    for ( int i = 0; i < matrix.length; i++ ) {

      matrix[i] = new int[i];

      for ( int j = 0; j < i; j++ ) {

       matrix[i][j] = i * j;

      }

    }

    // 第7步打印矩阵

    for ( int i = 0; i < matrix.length; i++ ) {

      System.out.print("matrix[" + i + "] is ");

      printArray(matrix[i]);

      System.out.println();

    }

  }

  public static void printArray(int[] array) {

    System.out.print('<');

    for ( int i = 0; i < array.length; i++ ) {

      // 打印一个元素

      System.out.print(array[i]);

      // 输出最后一个元素的时候不输出逗号

      if ( (i + 1) < array.length ) {

       System.out.print(", ");

      }

    }

    System.out.print('>');

  }

}  此源码和其它例子打包下载
http://www.100jq.com/upload/2007_07/07070716584024.rar

    在jdk5.0中,我们发现了一些更简单的方法,打印一维数组时,用toString(array)方法,

打印二维数组时,用deepToString(array)方法。这样的话就剩了我们又是循环又是判断的。我们看个例子吧:实践:

import java.util.Arrays;

public class ArraysTester {

  private int[] ar;



  public ArraysTester(int numValues) {

    ar = new int[numValues];

    for (int i=0; i < ar.length; i++) {

      ar[i] = (1000 - (300 + i));

    }

  }

  public int[] get() {

    return ar;

  }

  public static void main(String[] args) {

    ArraysTester tester = new ArraysTester(50);

    int[] myArray = tester.get();

    // 比较两个数组

    int[] myOtherArray = tester.get().clone();

    if (Arrays.equals(myArray, myOtherArray)) {

      System.out.println("这两个数组是相等的!");

    } else {

      System.out.println("这两个数组是不相等的!");

    }

    // 填上一些值

    Arrays.fill(myOtherArray, 2, 10, new Double(Math.PI).intValue());

    myArray[30] = 98;

    // 打印数组

    System.out.println("这是一个未排序的数组...");

    System.out.println(Arrays.toString(myArray));

    System.out.println();

    // 数组排序

    Arrays.sort(myArray);    

    // 打印被排序的数组 用toString()

    System.out.println("这是一个被排序的数组...");

    System.out.println(Arrays.toString(myArray));

    System.out.println();



    // 得到特殊值的索引

    int index = Arrays.binarySearch(myArray, 98);

    System.out.println("98 被定位在第 " + index + "个位置上");



    String[][] ticTacToe = { {"X", "O", "O"},

                             {"O", "X", "X"},

                             {"X", "O", "X"}};

    //打印二维数组用deepToString()

    System.out.println(Arrays.deepToString(ticTacToe));

    String[][] ticTacToe2 = { {"O", "O", "X"},

                              {"O", "X", "X"},

                              {"X", "O", "X"}};

    String[][] ticTacToe3 = { {"X", "O", "O"},

                              {"O", "X", "X"},

                              {"X", "O", "X"}};

    if (Arrays.deepEquals(ticTacToe, ticTacToe2)) {

      System.out.println("Boards 1 和 2 相等.");

    } else {

      System.out.println("Boards 1 和 2 不相等.");

    }

    if (Arrays.deepEquals(ticTacToe, ticTacToe3)) {

      System.out.println("Boards 1 和 3 are 相等.");

    } else {

      System.out.println("Boards 1 和 3 are 不相等.");

    }

  }

}此源码和其它例子打包下载
http://www.100jq.com/upload/2007_07/07070716584024.rar
posted on 2007-07-09 08:18 王君 阅读(311) 评论(2)  编辑  收藏 所属分类: J2SE

Feedback

# re: 全新java初学者实践教程9(java SE5.0版)----jdk5的数组 2007-07-10 11:53 Persuse3
这是百家拳软件项目研究室,的原创教程,看全部教程请访问
<a href="http://www.100jq.com/list.aspx?cid=11">
http://www.100jq.com/list.aspx?cid=11</a>  回复  更多评论
  

# re: 全新java初学者实践教程9(java SE5.0版)----jdk5的数组 2007-07-10 11:53 Persuse3
http://www.100jq.com/list.aspx?cid=11  回复  更多评论
  


只有注册用户登录后才能发表评论。


网站导航: