zoukankan      html  css  js  c++  java
  • 数组和集合的区别

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    数组Array和集合的区别:
     
    (1)数组是大小固定的,并且同一个数组只能存放类型一样的数据(基本类型/引用类型)
     
    (2)JAVA集合可以存储和操作数目不固定的一组数据。 (3)若程序时不知道究竟需要多少对象,需要在空间不足时自动扩增容量,则需要使用容器类库,array不适用。
     
    联系:使用相应的toArray()和Arrays.asList()方法可以回想转换。
     
    一.集合的体系结构:
     
    List、Set、Map是这个集合体系中最主要的三个接口。 List和Set继承自Collection接口。 Map也属于集合系统,但和Collection接口不同。
     
    Set不允许元素重复。HashSet和TreeSet是两个主要的实现类。Set 只能通过游标来取值,并且值是不能重复的。
     
    List有序且允许元素重复。ArrayList、LinkedList和Vector是三个主要的实现类。 ArrayList 是线程不安全的, Vector 是线程安全的,这两个类底层都是由数组实现的 LinkedList 是线程不安全的,底层是由链表实现的
     
    Map 是键值对集合。其中key列就是一个集合,key不能重复,但是value可以重复。 HashMap、TreeMap和Hashtable是Map的三个主要的实现类。 HashTable 是线程安全的,不能存储 null 值 HashMap 不是线程安全的,可以存储 null 
     
    二.List和ArrayList的区别
     
      1.List是接口,List特性就是有序,会确保以一定的顺序保存元素.
     
      ArrayList是它的实现类,是一个用数组实现的List.
     
      Map是接口,Map特性就是根据一个对象查找对象.
     
      HashMap是它的实现类,HashMap用hash表实现的Map,就是利用对象的hashcode(hashcode()是Object的方法)进行快速散列查找.(关于散列查找,可以参看<<数据结构>>)
     
      2.一般情况下,如果没有必要,推荐代码只同List,Map接口打交道.
     
      比如:List list = new ArrayList();
     
      这样做的原因是list就相当于是一个泛型的实现,如果想改变list的类型,只需要:
     
      List list = new LinkedList();//LinkedList也是List的实现类,也是ArrayList的兄弟类
     
      这样,就不需要修改其它代码,这就是接口编程的优雅之处.
     
      另外的例子就是,在类的方法中,如下声明:
     
      private void doMyAction(List list){}
     
      这样这个方法能处理所有实现了List接口的类,一定程度上实现了泛型函数.
     
      3.如果开发的时候觉得ArrayList,HashMap的性能不能满足你的需要,可以通过实现List,Map(或者Collection)来定制你的自定义类.

    三。图示说明:

     

     注:图参来之http://www.cnblogs.com/xiaoqv/archive/2011/11/24/2262142.html

    int[] m = { 1, 2, 3 };
    String[] strings = { "aaa", "bbb" };
    List<String> list = new ArrayList<String>();
    List<Integer> lists = new ArrayList<Integer>();
    List<Map<String, Object>> list2 = new ArrayList<Map<String,Object>>();
    List<City> listcity = new ArrayList<City>();

    数组是一种最简单的复合数据类型。数组是有序数据的集合,数组中的每个元素具有相同的数据类型,可以用一个统一的数组名和下标来唯一地确定数组中的元素。数组有一维数组和多维数组。 
    ★ 一维数组 
          1. 一维数组的定义 

      type arrayName[ ]; 
      类型(type)可以为Java中任意的数据类型,包括简单类型和复合类型。 
      例如: 
       int intArray[ ]; 
       Date dateArray[]; 


      2.一维数组的初始化 

      ◇ 静态初始化 
        int intArray[]={1,2,3,4}; 
        String stringArray[]={"abc", "How", "you"}; 

      ◇ 动态初始化 
        1)简单类型的数组 
        int intArray[]; 
        intArray = new int[5]; 

       2)复合类型的数组 
        String stringArray[ ]; 
        String stringArray = new String[3];/*为数组中每个元素开辟引用 
                          空间(32位) */ 
        stringArray[0]= new String("How");//为第一个数组元素开辟空间 
        stringArray[1]= new String("are");//为第二个数组元素开辟空间 
        stringArray[2]= new String("you");// 为第三个数组元素开辟空间 

      3.一维数组元素的引用 

      数组元素的引用方式为: 
         arrayName[index] 

      index为数组下标,它可以为整型常数或表达式,下标从0开始。每个数组都有一个属性length指明它的长度,例如:intArray.length指明数组intArray的长度。 

    ★多维数组 

      Java语言中,多维数组被看作数组的数组。 

      1.二维数组的定义 

      type arrayName[ ][ ]; 
      type [ ][ ]arrayName; 

      2.二维数组的初始化 

      ◇ 静态初始化 
      int intArray[ ][ ]={{1,2},{2,3},{3,4,5}}; 

      Java语言中,由于把二维数组看作是数组的数组,数组空间不是连续分配的,所以不要求二维数组每一维的大小相同。 

      ◇ 动态初始化 
      1) 直接为每一维分配空间,格式如下: 
      arrayName = new type[arrayLength1][arrayLength2]; 
      int a[ ][ ] = new int[2][3]; 

      2) 从最高维开始,分别为每一维分配空间: 
      arrayName = new type[arrayLength1][ ]; 
      arrayName[0] = new type[arrayLength20]; 
      arrayName[1] = new type[arrayLength21]; 
      … 
      arrayName[arrayLength1-1] = new type[arrayLength2n]; 

      3) 例: 
      二维简单数据类型数组的动态初始化如下, 
      int a[ ][ ] = new int[2][ ]; 
      a[0] = new int[3]; 
      a[1] = new int[5]; 

      对二维复合数据类型的数组,必须首先为最高维分配引用空间,然后再顺次为低维分配空间。 
      而且,必须为每个数组元素单独分配空间。 

      例如: 
      String s[ ][ ] = new String[2][ ]; 
      s[0]= new String[2];//为最高维分配引用空间 
      s[1]= new String[2]; //为最高维分配引用空间 
      s[0][0]= new String("Good");// 为每个数组元素单独分配空间 

    s[0][1]= new String("Luck");// 为每个数组元素单独分配空间 
      s[1][0]= new String("to");// 为每个数组元素单独分配空间 
      s[1][1]= new String("You");// 为每个数组元素单独分配空间 

      3.二维数组元素的引用 
       
      对二维数组中的每个元素,引用方式为:arrayName[index1][index2] 
      例如: num[1][0]; 

      4.二维数组举例: 

      【例2.2】两个矩阵相乘 
      public class MatrixMultiply{ 
       public static void main(String args[]){ 
       int i,j,k; 
       int a[][]=new int [2][3]; //动态初始化一个二维数组 
       int b[][]={{1,5,2,8},{5,9,10,-3},{2,7,-5,-18}};//静态初始化 
                               一个二维数组 
       int c[][]=new int[2][4]; //动态初始化一个二维数组 
       for (i=0;i<2;i++) 
         for (j=0; j<3 ;j++) 
          a[i][j]=(i+1)*(j+2); 
       for (i=0;i<2;i++){ 
         for (j=0;j<4;j++){ 
          c[i][j]=0; 
       for(k=0;k<3;k++) 
         c[i][j]+=a[i][k]*b[k][j]; 
          } 
         } 
       System.out.println("*******Matrix C********");//打印Matrix C标记 
       for(i=0;i<2;i++){ 
         for (j=0;j<4;j++) 
          System.out.println(c[i][j]+" "); 
         System.out.println(); 
          } 
         } 
       } 

      2.5 字符串的处理 

    ★ 字符串的表示 

      Java语言中,把字符串作为对象来处理,类String和StringBuffer都可以用来表示一个字符串。(类名都是大写字母打头) 

      1.字符串常量 

      字符串常量是用双引号括住的一串字符。 
        "Hello World!" 

      2.String表示字符串常量 

      用String表示字符串: 
      String( char chars[ ] ); 
      String( char chars[ ], int startIndex, int numChars ); 
      String( byte ascii[ ], int hiByte ); 
      String( byte ascii[ ], int hiByte, int startIndex, int numChars ); 
      String使用示例: 
      String s=new String() ; 生成一个空串 

      下面用不同方法生成字符串"abc": 
      char chars1[]={’a’,’b’,’c’}; 
      char chars2[]={’a’,’b’,’c’,’d’,’e’}; 
      String s1=new String(chars1); 
      String s2=new String(chars2,0,3); 
      byte ascii1[]={97,98,99}; 
      byte ascii2[]={97,98,99,100,101}; 
      String s3=new String(ascii1,0); 
      String s4=new String(ascii2,0,0,3); 
    3.用StringBuffer表示字符串 

      StringBuffer( ); /*分配16个字符的缓冲区*/ 
      StringBuffer( int len ); /*分配len个字符的缓冲区*/ 
     StringBuffer( String s ); /*除了按照s的大小分配空间外,再分配16个 
                   字符的缓冲区*/ 

    ★访问字符串 

       1.类String中提供了length( )、charAt( )、indexOf( )、lastIndexOf( )、getChars( )、getBytes( )、toCharArray( )等方法。 

      ◇ public int length() 此方法返回字符串的字符个数 
      ◇ public char charAt(int index) 此方法返回字符串中index位置上的字符,其中index 值的 范围是0~length-1 
      ◇ public int indexOf(int ch) 
        public lastIndexOf(in ch) 
       
      返回字符ch在字符串中出现的第一个和最后一个的位置 
      ◇ public int indexOf(String str) 
        public int lastIndexOf(String str) 
      返回子串str中第一个字符在字符串中出现的第一个和最后一个的位置 
      ◇ public int indexOf(int ch,int fromIndex) 
        public lastIndexOf(in ch ,int fromIndex) 
      返回字符ch在字符串中位置fromIndex以后出现的第一个和最后一个的位置 
      ◇ public int indexOf(String str,int fromIndex) 
        public int lastIndexOf(String str,int fromIndex) 
      返回子串str中的第一个字符在字符串中位置fromIndex后出现的第一个和最后一个的位置。 
      ◇ public void getchars(int srcbegin,int end ,char buf[],int dstbegin) 
       srcbegin 为要提取的第一个字符在源串中的位置, end为要提取的最后一个字符在源串中的位置,字符数组buf[]存放目的字符串,    dstbegin 为提取的字符串在目的串中的起始位置。 
      ◇public void getBytes(int srcBegin, int srcEnd,byte[] dst, int dstBegin) 
      参数及用法同上,只是串中的字符均用8位表示。 

      2.类StringBuffer提供了 length( )、charAt( )、getChars( )、capacity()等方法。 

      方法capacity()用来得到字符串缓冲区的容量,它与方法length()所返回的值通常是不同的。 
    ★修改字符串 
    修改字符串的目的是为了得到新的字符串,类String和类StringBuffer都提供了相应的方法。有关各个方法的使用,参考java 2 API。 

      1.String类提供的方法: 

       concat( ) 
       replace( ) 
       substring( ) 
       toLowerCase( ) 
       toUpperCase( ) 

      ◇ public String contat(String str); 
      用来将当前字符串对象与给定字符串str连接起来。 
      ◇ public String replace(char oldChar,char newChar); 
      用来把串中出现的所有特定字符替换成指定字符以生成新串。 
      ◇ public String substring(int beginIndex); 
      public String substring(int beginIndex,int endIndex); 
      用来得到字符串中指定范围内的子串。 
      ◇ public String toLowerCase(); 
    把串中所有的字符变成小写。 
      ◇ public String toUpperCase(); 
      把串中所有的字符变成大写。 

      2.StringBuffer类提供的方法: 

      append( ) 
      insert( ) 
      setCharAt( ) 

      如果操作后的字符超出已分配的缓冲区,则系统会自动为它分配额外的空间。 
      ◇ public synchronized StringBuffer append(String str); 
      用来在已有字符串末尾添加一个字符串str。 
      ◇ public synchronized StringBuffer insert(int offset, String str); 
      用来在字符串的索引offset位置处插入字符串str。 
      ◇ public synchronized void setCharAt(int index,char ch); 
      用来设置指定索引index位置的字符值。 

      注意:String中对字符串的操作不是对源操作串对象本身进行的,而是对新生成的一个源操作串对象的拷贝进行的,其操作的结果不影响源串。 

      相反,StringBuffer中对字符串的连接操作是对源串本身进行的,操作之后源串的值发生了变化,变成连接后的串。 

    ★ 其它操作 

       1.字符串的比较 

      String中提供的方法: 
      equals( )和equalsIgnoreCase( ) 
      它们与运算符’= =’实现的比较是不同的。运算符’= =’比较两个对象是否引用同一个实例,而equals( )和equalsIgnoreCase( )则比较  两个字符串中对应的每个字符值是否相同。 

      2.字符串的转化 

      java.lang.Object中提供了方法toString( )把对象转化为字符串。 

      3.字符串"+"操作 

      运算符’+’可用来实现字符串的连接: 
      String s = "He is "+age+" years old."; 
      其他类型的数据与字符串进行"+"运算时,将自动转换成字符串。具体过程如下: 
      String s=new StringBuffer("he is").append(age).append("years old").toString(); 

      注意:除了对运算符"+"进行了重载外,java不支持其它运算符的重载。
  • 相关阅读:
    16级第三周寒假作业F题
    16级第三周寒假作业E题
    16级第二周寒假作业J题
    16级第二周寒假作业B题
    16级第一周寒假作业D题
    16级第一周寒假作业F题
    Drupal8 社区文档之Drupal的概述
    Drupal 社区文档之一般概念
    Drupal 8 目录结构
    PhpExcel中文帮助手册|PhpExcel使用方法
  • 原文地址:https://www.cnblogs.com/zimo-bwl1029-s/p/6842370.html
Copyright © 2011-2022 走看看