import java.util.ArrayList;
import java.util.List;

public class Test {

    public static void main(String[] args) {
        
        List<String> list = new ArrayList<String>(); 
        list.add("1"); 
        list.add("2"); 
        String[] tt =(String[]) list.toArray(new String[0]); 

    }

}

 这段代码是没问题的,但我们看到String[] tt =(String[]) list.toArray(new String[0]) 中的参数很奇怪,然而去掉这个参数new String[0]却在运行时报错。。。

 list.toArray()返回的是一个Object[]类型的,按理说,该容器中的元素已经用泛型限制了,那里面的元素就应该被当作泛型类型的来看了,然而在目前的java中却不是的,当直接String[] tt =(String[]) list.toArray()时,运行报错。原因是容器的类型已经强制转过来了,然而容器中的元素类型却没有转过来,所以运行时报错。

这是在看代码(ListFeatures.java)拥有的一个疑问:

Pet[] pa = pets.toArray(new Pet[0]);

new Pet[0]仅仅就是一个类型提示的作用吧

 

另外, subList()所产生的列表的幕后就是初始列表,因此,对所返回的列表的修改都会反映到初始列表中,反之亦然。

例如,改变subList()返回列表的顺序,原始列表相应部分的顺序也改变了

 

SortedSet接口

从TreeSet类的定义中可以发现,TreeSet中实现了SortedSet接口,此接口主要用于排序操作,即实现此接口的子类都属于排序的子类。SortedSet接口定义如下:

  1. public interface SortedSet<E> extends Set<E> 

发现此接口也继承了Set接口。此接口中定义了如表13-7所示的方法。

表13-7  SortedSet接口中定义的方法

序号

    法

类型

    述

1

public Comparator<?

 super E> comparator()

普通

返回与排序有关联的比较器

2

public E first()

普通

返回集合中的第一个元素

3

public SortedSet<E> headset

(E toElement)

普通

返回从开始到指定元素的集合

4

public E last()

普通

返回最后一个元素

5

public SortedSet<E> subSet

(E fromElement,E toElement)

普通

返回指定对象间的元素

6

public SortedSet<E> tailSet

(E fromElement)

普通

从指定元素到最后

范例:验证SortedSet接口

  1. package org.lxh.demo13.setdemo;  
  2. import java.util.SortedSet;  
  3. import java.util.TreeSet;  
  4. public class TreeSetDemo05 {  
  5.     public static void main(String[] args) {  
  6.         SortedSet<String> allSet = new  TreeSet<String>();   // 为SortedSet  
  7. 实例化  
  8.         allSet.add("A");                   // 增加元素  
  9.         allSet.add("B");                  // 增加元素  
  10.         allSet.add("C");                // 增加元素  
  11.         allSet.add("C");                 // 重复元素,不能  
  12. 加入  
  13.         allSet.add("C");                    // 重复元素,不能加入  
  14.         allSet.add("D");                     // 增加元素  
  15.         allSet.add("E");                   // 增加元素  
  16.         System.out.println("第一个元素:" +  allSet.first());  
  17.         System.out.println("最后一个元素:"  + allSet.last());  
  18.         System.out.println("headSet元素:" + allSet.headSet("C"));  
  19.         System.out.println("tailSet元素:"  + allSet.tailSet("C"));  
  20.         System.out.println("subSet元素:"  + allSet.subSet("B","D"));  
  21.     }  

程序运行结果:

  1. 第一个元素:A  
  2. 最后一个元素:E  
  3. headSet元素:[A, B]  
  4. tailSet元素:[C, D, E]  
  5. subSet元素:[B, C] 

 

net.mindview.util包下的 文件读写工具类TextFile.java

//使用此工具类可以快速的实现读取文件内容到string,并封装到ArrayList中;进行一系列的操作之后,可以再讲内容写入到文件中。
//使用此工具可以避免JavaIO中一些繁琐的装饰操作,简化了编程

 


 
   
 
 
   

 

String s1 = "how are you";
String s2 = "how are you";
String s3 = new String("how are you");
String s4 = new String("how are you");
System.out.println(s1 == s2);  //true
System.out.println(s3 == s4);  //false

 

String s1 = "java";
String s2 = "java";

System.out.println(s1==s2);            //true
System.out.println(s1.equals(s2));    //true

 

如果String缓冲池内不存在与其指定值相同的String对象,那么此时虚拟机将为此创建新的String对象,并存放在String缓冲池内。

 

如果String缓冲池内存在与其指定值相同的String对象,那么此时虚拟机将不为此创建新的String对象,而直接返回已存在的String对象的引用。

 

posted on 2017-02-15 14:02  文森博客  阅读(324)  评论(0编辑  收藏  举报