<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Vincent.Chan‘s Blog

    常用鏈接

    統(tǒng)計(jì)

    積分與排名

    網(wǎng)站

    最新評(píng)論

    《Java 5.0 Tiger》Chapter 1

    Chapter 1. What's New?

    1.1 Working with Arrays

    String[] s1 = "1""2""3" };
    System.out.println(Arrays.toString(s1));
    String[][] s2 
    = "1""2""3" }"4""5""6" } };
    System.out.println(Arrays.deepToString(s2));
    String[][] s3 
    = "1""2""3" }"4""5""6" } };
    System.out.println(Arrays.deepEquals(s2, s3));
    /* --- console output --- */
    [123]
    [[
    123], [456]]
    true

    The first method to take note of, at least for Tiger fans, is toString( ). This handles the rather annoying task of printing arrays for you. While this is trivial to write on your own, it's still nice that Sun takes care of it for you now.

    Another similar, but also new, method is deepToString( ). This method takes in an object array, and prints out its contents, including the contents of any arrays that it might contain.

    Finally, Arrays provides a deepEquals( ) method that compares multidimensional arrays.

    1.2 Using Queues

    Another cool collection addition is the java.util.Queue class, for all those occasions when you need FIFO (first-in, first-out) action.

    Queue q = new LinkedList();
    q.offer(
    "First");
    q.offer(
    "Second");
    q.offer(
    "Third");
     Object o;
     
    while ((o = q.poll()) != null)
             System.out.println(o);

    Use offer(), poll() instead of add(), remove() respectivelly. If you want the head without removing it, ues element() or peek().

    In Tiger, LinkedList has been retrofitted to implement the Queue interface. While you can use it like any other List implementation, it can also be used as a Queue implementation.

    1.3 Ordering Queues Using Comparators

    PriorityQueue, a Queue with Comparator. If you don't specify a Comparator, natural ordering occurs.

    import java.util.Comparator;
    import java.util.PriorityQueue;
    import java.util.Queue;

    public class PriorityQueueTester {
        
    public static void main(String[] args) {
            Queue
    <Integer> pq = new PriorityQueue<Integer>(20,
                    
    new Comparator<Integer>() {
                        
    public int compare(Integer i, Integer j) {
                            
    int result = i % 2 - j % 2;
                            
    if (result == 0)
                                result 
    = i - j;
                            
    return result;
                        }

                    }
    );
            
    // Fill up with data, in an odd order
            for (int i = 0; i < 20; i++{
                pq.offer(
    20 - i);
            }

            
    // Print out and check ordering
            for (int i = 0; i < 20; i++{
                System.out.print(pq.poll() 
    + " ");
            }

        }

    }

    /* --- console output --- */

    2 4 6 8 10 12 14 16 18 20 1 3 5 7 9 11 13 15 17 19 

    1.4 Overriding Return Types 

    class Point2D {
        
    protected int x, y;

        
    public Point2D() {
            
    this.x = 0;
            
    this.y = 0;
        }


        
    public Point2D(int x, int y) {
            
    this.x = x;
            
    this.y = y;
        }

    }


    class Point3D extends Point2D {
        
    protected int z;

        
    public Point3D(int x, int y) {
            
    this(x, y, 0);
        }


        
    public Point3D(int x, int y, int z) {
            
    this.x = x;
            
    this.y = y;
            
    this.z = z;
        }

    }


    class Position2D {
        Point2D location;

        
    public Position2D() {
            
    this.location = new Point2D();
        }


        
    public Position2D(int x, int y) {
            
    this.location = new Point2D(x, y);
        }


        
    public Point2D getLocation() {
            
    return location;
        }


    }


    class Position3D extends Position2D {
        Point3D location;

        
    public Position3D(int x, int y, int z) {
            
    this.location = new Point3D(x, y, z);
        }


        
    public Point3D getLocation() {
            
    return location;
        }

    }

    The key is the line public Point3D getLocation( ), which probably looks pretty odd to you, but get used to it. This is called a covariant return, and is only allowed if the return type of the subclass is an extension of the return type of the superclass. 

    1.5 Taking Advantage of Better Unicode

    In Tiger, Java has moved to support Unicode 4.0, which defines several characters that don't fit into 16 bits. This means that they won't fit into a char, and that has some far-reaching consequences. You'll have to use int to represent these characters, and as a result methods like Character.isUpperCase( ) and Character.isWhitespace( ) now have variants that accept int arguments. So if you're needing values in Unicode 3.0 that are not available in Unicode 3.0, you'll need to use these new methods..

    Most of the new characters in Unicode 4.0 are Han ideographs.

    1.6 Adding StringBuilder to the Mix 

    Replace all your StringBuffer code with StringBuilder code. Really—it's as simple as that. If you're working in a single-thread environment, or in a piece of code where you aren't worried about multiple threads accessing the code, or synchronization, it's best to use StringBuilder instead of StringBuffer.

    posted on 2006-02-18 18:28 Vincent.Chen 閱讀(156) 評(píng)論(0)  編輯  收藏 所屬分類: Java

    主站蜘蛛池模板: 亚洲激情视频网站| 国产精品免费小视频| 国产午夜精品免费一区二区三区 | 免费国产污网站在线观看不要卡| 在线精品自拍亚洲第一区| 中文日本免费高清| 久久伊人免费视频| 国内大片在线免费看| 久久影视综合亚洲| 亚洲高清免费在线观看| 亚洲AV第一成肉网| 无码精品国产一区二区三区免费| 在线免费观看a级片| 亚洲精品中文字幕| CAOPORN国产精品免费视频| 天天影视色香欲综合免费| 在线永久免费观看黄网站| 亚洲精品自拍视频| 亚洲第一网站免费视频| 亚洲午夜无码片在线观看影院猛| 亚洲国产精品白丝在线观看| www成人免费视频| 女人18一级毛片免费观看| 日韩欧美亚洲中文乱码| 亚洲国产成人久久综合野外| 亚洲国产成人无码av在线播放| 国产乱子伦精品免费视频| 亚洲日韩精品A∨片无码| 鲁死你资源站亚洲av| 免费在线观看你懂的| 在线综合亚洲欧洲综合网站| 中文字幕乱码免费看电影| 亚洲精品无码久久久久AV麻豆| 亚洲a级成人片在线观看| 999久久久免费精品播放| 精品亚洲视频在线观看| 久久免费公开视频| 亚洲人成未满十八禁网站| 亚洲精品乱码久久久久久蜜桃| 国内少妇偷人精品视频免费| 亚洲影视自拍揄拍愉拍|