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不支持其它运算符的重载。
  • 相关阅读:
    VisualSVN-Server windows 版安装时报错 "Service 'VisualSVN Server' failed to start. Please check VisualSVN Server log in Event Viewer for more details."
    Pytest 单元测试框架之初始化和清除环境
    Pytest 单元测试框架入门
    Python(email 邮件收发)
    Python(minidom 模块)
    Python(csv 模块)
    禅道简介
    2020年最好的WooCommerce主题
    Shopify网上开店教程(2020版)
    WooCommerce VS Magento 2020:哪个跨境电商自建站软件更好?
  • 原文地址:https://www.cnblogs.com/zimo-bwl1029-s/p/6842370.html
Copyright © 2011-2022 走看看