天阔阔雪漫漫共谁同航 这沙滚滚水皱皱笑着浪荡

Start from Java 2 -- Class, Interface, Final

|

Inner Class

  1. Definition: A class defined in another class is called as an Inner Class. The class which contains an Inner class is known as an enclosed class or Outer class.
  2. Scope: The scope of an Inner class is limited to the boundary of Outer Class.
  3. Inner class and Outer class:
    1. An Inner class can access all the members from Outer class including private members directly.(different from subclass).
    2. However, an Outer class can access the Inner class members only through an object of Inner class.
    3. Any static method of outer class can access the member of non-static inner class as : .<Runtime/Anonymous Object of Inner class>.member example(way-2):
       class OuterA {
           int x = 2;
           private String name = "James";
      
           class InnerA {
      
               double d = 23.45;
      
               void in() {
                   System.out.println(d);
                   System.out.println(name);
                   System.out.println(x);
               }	
      
           }
      
           // this method is part of the first way to invoke in() inside main
           void out() {
               InnerA obj = new InnerA();
               obj.in();
           }
      
           public static void main(String a[]) {
               OuterA o1 = new OuterA();
               //two ways to invoke in()
               //1. 
               o1.out();	
               //2. InnerA is a member of o1, like variables and methods
               o1.new InnerA().in();
               /*
                   what we can not do:
                   OuterA.InnerA inA = new InnerA(); 
                   inA.in();
                   because the prefix of OuterA.InnerA is supposed to be a package name rather than class name
               */
           }
       }
      
    4. An Inner class defined within a method can access everything from outside the method but only final type of variables or objects from within the method in which it is defined.(wt??)
  4. With static:
    1. Whenever an Inner class contains at least one static member, the whole Inner class must be declared as static Inner class.
    2. A static Inner class can access only static members of Outer class directly & to access Non-static members it has to create an Object of Outer class.

Abstract Class Vs Interface

  1. abstract:
    1. method: if only a method name must be declared, but not a body–abstract method
    2. class: In a class if any one of the method is abstract, then the whole class must be declared as abstract. The class which extends an abstract class, it must override all the abstract methods of the super class, otherwise, the subclass must also be declared as abstract.
    3. Only a class & method can be declared as abstract. But not a variable.
    4. abstract and static cannot be used together for a method.
    5. An abstract class can not be instantiated as it is termed as incomplete (non-concrete) in terms of its definition.(The class which is having all the methods defined with a body is called as concrete class.)
  2. interface
    1. definition: contains only abstract methods, which will be used for multiple inheritance.
    2. rules:
      1. A class can implement any number of Interfaces
      2. A class which implements an interface must override all the methods of Interface, otherwise the class must be declared as abstract.
      3. All the methods of an interface must be overridden by “public” access specifier.
      4. An interface cannot be instantiated.(the same as abstract class)

final:

  • final class can not be inherited (compile error)
  • final method can not be overriden in subclass (compile error)
  • the value of a final variable can not be changed
  • the reason to declare a method or class “final” is to improve the speed of a program

Start from Java -- OOP Concept

|

Start from Java

concepts list:

  1. class
  2. object
  3. constructors
  4. methods
  5. inheritance
  6. overloading/overriding
  7. access specifiers
    1. private : The private members can be accessed only within the same class, but not outside the class.
    2. default – same package (Default is not a keyword but reserved word in Java)
    3. protected – same package, subclass
    4. public – same package, subclass, others
  8. access modifiers
    1. static
    2. final
    3. abstract
    4. transient
    5. volatile
    6. synchronized
    7. native
  9. abstract class
  10. interface
  11. inner class
  12. package

Details:

  1. terminal run java project:
    1. javac className.java
    2. java className
    3. start point of any program: main()
    4. As per the OOPS of Java, main() must be inside a class, it is also a member of a class
    5. before creating any object, main() must be identified from within the class
    6. main() is declared as static, which can be accessed without creating any object
  2. class: An object is an instance of a class used to access the members(properties and methods) of a class.
  3. method: A block which has a name, a return type (void if does not return anything) sometimes parameters and a set of statements, which would be executed is called as a method.
    • method signature: return type, method name, parameters(doesn’t include access specifiers like public…)
  4. scope of
    1. local variable: only within a particular block. Variables which are declared inside a block can be accessed only within the same block is called as Local Variables.
    2. global variable: (There is no direct concept of global variable in java)
      1. class variable(static): A class variable is a variable defined in a class of which a single copy exists, regardless of how many instances of the class exist.
         class classVariable{
             //one fixed memory location shared by every instance
             private static int i = 0;
             ...
         }
        
      2. instance variable(without static): declared in class, out of method, are only initialized when the class is instantiated.(Variables, which are declared outside of any block but inside a class can be accessed throughout the class)
  5. static:
    1. Any method which is static can access only other static members(static context) directly,
    2. Any method which is static wants to access non-static members, an object of a class must be created.
    3. Where as a non-static method can access both static & non-static members directly.
    4. The static modifier, in combination with the final modifier, is also used to define constants. The final modifier indicates that the value of this field cannot change.
    5. static variable: memory share variable x the whole class
    6. static method, static block: (and static variables) are all executed before main static { statement1; ...}
    7. static class
    8. only 5,6,7, static variable, static method, static block, static class these four things can be static
    9. Can class be static? Inner class (more details of inner class, see start with java 2) can be static, top-level class can not.
    10. Is there will be a static variable inside of a function? Local variables can not be static an explaination from stackoverflow
      /*
      where I use the private static variables is when you need to use a variable in a static function. For the static functions you can only use static variables, so you make them private to not access them from other classes. That is the only case I use private static for.
      Here is an example:
      */
      Class test {
              public static String name = "AA";
              private static String age;
      
              public static void setAge(String yourAge) {
                  //here if the age variable is not static you will get an error that you cannot access non static variables from static procedures so you have to make it static and private to not be accessed from other classes
                  age = yourAge;
              }
      }
      
  6. constructor:
    1. definition:
      1. A block which contains same name as a class name, which does not have any return type,
      2. used for initializing the variables & objects
      3. will be executed automatically when an object of a class is initialized
    2. rules:
      1. By default, every class has default constructor, which initializes and object, and will be lost when a specific constructor is defined manually.
      2. A class can have any number of constructors, with a difference in type/number of parameters is called constructor overloading
      3. If we have two constructor in a class, and we called the default constructor, then we want to invoke another constructor, we can use keyword: this()
         class Example1{
             Example1(){
        
             }
             Example1(int i){
        
             }
         }
        
      4. if we use this() to invoke another constructor, we must put this() in the first line, or we will get a syntax error.
      5. if we want to customize a constructor with parameters meanwhile, there is some obj using the default constructor, we need to write the default constructor, then write the new constructor(yes, we need to write 2 constructors).
      6. class G extend F{ ... } F’s default constructor is invoked first, then invoke G’s default or G(arg) constructor
  7. Polymorphism: In a class, if more than one method is defined with a same name, then there must be a difference in type/number of parameters is called as Polymorphism (Method Overloading).
    • In method overloading, if the return type is changed, then there must be a change in type/number of parameters also.
  8. toString
    1. The toString() method returns a textual representation of an object. A basic implementation is already included in java.lang.Object and so because all objects inherit from java.lang.Object it is guaranteed that every object in Java has this method.
    2. It is automatically invoked when the object is passed to println, print, printf, String.format() assert or the string concatenation operator.
    3. if we want print a specific format of an object, we need to override toString() method in class
  9. this
    1. to identify global variables within a local scope
    2. to invoke constructor of the same class from one constructor using this()
  10. overriding:if a subclass contains a method, which has the same name, return type and parameters as a super class method, it’s called method overriding
    1. private method of super class can not be overriding, it is just called redefined (because the private method is not visible in the subclass.).
    2. can not restrict it. eg: The default method of super class can be overridden by default, protected & public method of subclass; The protected method of super class can be overridden by protected & public method of subclass; The public method of super class can be overridden by only public method of subclass.
  11. overloading: define two method, same name but they have different parameters.

some english

  1. as per: both per and as per have existed in English in the sense “according to” for a very long time
  2. identified from : be identified from within the class
  3. instantiated: when the class is instantiated
  4. semicolon [‘sɛmɪkolən]
  5. : colon

Funny number roots in English

|

##Funny Numbers | Tables| 拉丁前缀| 希腊前缀 | | ———- |:———-:| :———:| | one|uni-:unique;uniform;unipolar(单极的)|mono-monologue(独白);monogamy(一夫一妻制);monochrome(单色的);monopolize(垄断)| | tow| bi-bilingual,bilateral(双边的):bimonthly(两月一次的) |di-dioxide;disyllable;digraph(双字一音;有向图)| | three|tri-:triangle;tricycle;trilogy(三部曲) | $1 | | four| quadr-;quart-quadrangle;quadruped(四足动物);quadruple(四倍);quarter;quartet(四重奏) |tetra-:tetragon(四边形);tetrahedrom(四面体);tetralogy(四部曲) | | five| quint-:quintuple(五倍);quintet(五重奏);quincentenary(五百周年纪念的) |pent-:pentagon(五角大楼);pentathlon(五项全能)pentad(五个一组) | | six| sex-:sexangle(六边形);sextet(六重奏);sexfiol(六折的)| hexa-:hexagon(六角形);hexahedron(六面体);hexapod(六足虫)| | seven|sept- : septangle(七边形);septennial 七年一度的 septavalent 【化】七价的 | hept- : heptagon 七边形    heptahedron 七面体    heptachord 七弦琴 | | eight|eight有点争议,也有种说法是:拉丁前缀 oct- :octopus 章鱼(章鱼有八条腿),octuple 八倍,octet 八人合唱团| octa- : octopus 章鱼(章鱼有八条腿) octapod 章鱼类生物 octuple 八倍 octagon 八边形 octet 八人合唱团 octahedron 八面体 | | nine|  non- : nonagon 九边形    nonet 九重奏    nonuple 九倍 | enne- : ennead 九个一组的 enneagon 九边形 enneasyllable 九音节| | ten|deci-:decimalism 十进制;decimeter 分米;decigran分克,decibel分贝,decimate取十分之一,严重破坏 | deca- : decade 十年 decagon 十边形 ,十角形 decaliter 十升 decathlon十项全能运动| |half| semi- : semicircle 半圆 semicolonial 半殖民地 semiconductor 半导体 semi-finals (半决赛) |  hemi- : hemisphere 半球    hemicycle 半圆    hemiplegia 偏瘫| | many|  non- : nonagon 九边形    nonet 九重奏    nonuple 九倍 | enne- : ennead 九个一组的 enneagon 九边形 enneasyllable 九音节| | hundred|   cent- : century 世纪 centigrade (C)摄氏度 centimeter 厘米(百分之一米 |  hect- : hectogram 百克    hectoliter 百升    hectometer 百米| |thousand|  mil-;milli-(千分之一): millennium 千年, 千周年纪念日 milligram 毫克 millipede 马陆,千足虫 millennial 一千年的,千禧年 | kilo-: Kilowatt(千瓦) kilometer(千米|

 mega- : megawatt(百万瓦特) megaton (百万吨

Core Java Interview Questions & Answers

|

Core Java Interview Questions & Answers

1. Basis:

1.1 concepts terminologies

  1. 语句— statement
  2. Instance variable
  3. Instance method(without static)
  4. func( parameter variables ){…}

1.2 Common Methods

1.2.1. String
  1. s.substring(0, 1);
  2. s.substring(1);
  3. s.equals(“b”);
  4. s = s.trim();
  5. s.indexOf(“a”);
  6. s.indexOf(“a”, 1); //indexOf(int ch, int fromIndex) Returns the index within this string of the first occurrence of the specified character, starting the search at the specified index.
  7. s.lastIndexOf(“a”); //Returns the index within this string of the last occurrence of the specified character, searching backward starting at the specified index.
  8. Integer.valueOf(s); // returns an Integer object
  9. Integer.parseInt(s); // returns an int primitive
  10. String.valueOf(s); // integer to string
  11. StringBuilder sb = new StringBuilder();
    sb.append("a");
    sb.insert(0, "a"); //(idx, str)
    sb.deleteCharAt(sb.length() ‐ 1);
    sb.reverse();
    sb.toString();
    
  12. //a weird representation: I saw indexOf(int ch) in java document, actually we always pass character like ‘a’… here. An explaination on StackOverFlow: The real reason is that indexOf(int) expects a Unicode codepoint, not a 16-bit UTF-16 “character”. Unicode code points are actually up to 21 bits in length. Characters in Java are stored in their unicode integer representation
1.2.2. Array Arraylist
  1. int max = Integer.MAX_VALUE;
  2. int min = Integer.MIN_VALUE;
  3. Arrays.sort()
  4. List list = new ArrayList();
  5. list.add(0);
  6. list.add(0, 1);
  7. list.get(0);
  8. list.size();
  9. list.remove(list.size() ‐ 1);
  10. Collections.sort(list);
  11. Collections.sort(list, Collections.reverseOrder());
  12. Collections.sort(list, new Comparator<Integer>() {
           @Override
            public int compare(Integer o1, Integer o2) {
                   return o1 ‐ o2;// 0‐>1
                   // return o2‐o1; 1‐>0
             }
     });
    //java8 lambda 
    Arrays.sort(points,(a,b)->(a[1]-b[1])); // int[][] points
    PriorityQueue<Map.Entry<Integer, Integer>> maxHeap =  new PriorityQueue<>((a,b)->(b.getValue()-a.getValue()));  
    // pq: pq.add(0); pq.remove(); pq.peek(); pq.isEmpty(); pq.size();
    
1.2.3. Stack
  1. Stack stack = new Stack();
  2. stack.push(0);
  3. stack.pop();
  4. stack.peek(); // The method call returns the object at the top of this stack. Thrown EmptyStackException if this stack is empty.
  5. stack.isEmpty();
  6. stack.size(); more:pop 和 peak 区别:peek(): This method looks at the object at the top of this stack without removing it from the stack.
1.2.4. Queue
  1. Queue q = new LinkedList();
  2. q.add(0);
  3. q.remove();
  4. q.peek();
  5. q.isEmpty();
  6. q.size();
1.2.5 Hashmap/ Hashset
  1. if (map.containsKey(‘c’)) {…}
  2. if (map.containsValue(1)) {…}
  3. for (Character d : map.keySet()){…}
  4. for (Integer i : map.values()) {…}
  5. map.isEmpty();
  6. map.size();
  7. set.add(0);
  8. set.remove(0);
  9. set.contains(0);
  10. set.isEmpty();

2. Interview Questions

2.1 interface vs abstract class
2.2 Pass by reference vs. pass by value
2.3 Final / finalize /finally
2.4 OOP
2.5 OOP concepts
2.6 overloading/overriding
2.7 hashmap vs. hash table vs. hashset
2.8 Array vs. ArrayList vs. LinkedList
2.9 stringbuilder vs string buffer
2.10 error vs. exception
2.11 between method and constructor
2.12 void main
2.13 Primitive types
2.14 when try catch? How will you handle the exception without using try-catch block?
2.15 access modifier
2.16 static
2.17 J2EE, J2SE, JSP
2.18 why do we need package the program
2.19 MVC
2.20 what is JDK,JRE,JVM
2.21 GC
2.22 Java里shared memory在哪儿

非重点:

2. HashSet vs. TreeSet vs. LinkedHashSet
2. HashMap vs. TreeMap vs. HashTable vs.

3. Anwers To Questions in 2

Most are from google,wiki, stackoverflow.

3.1 interface vs abstract class

we use them for different purposes

  1. We use abstract class when we want to share code among several closely classes.
  2. We use interface when we expect that unrelated classes would implement the interface.
  3. For example, the interface Comparable and Cloneable are implemented by unrelated class.

differences

  1. abstract class–extend, interface–implement
  2. interface is a a collection of abstract methods, which only contains method signatures and fields, not implementations. Abstract class can contain a mix of methods declared with or without implementation.
  3. with interface, all fields are automatic public, static, final, and all methods you declare or defined are public. But with abstract class, you can declare fields that are not static and final, and define public, protected, and private concrete method.
  4. we can extend only one class, whether or not it is abstract, whereas you can implement any number if interfaces.

3.2 Pass by reference vs. pass by value
  1. java is pass-by-value
  2. Pass by value (primitives): make a copy in memory of the actual parameter’s value that is passed in.
  3. Pass by reference (objects): pass a copy of the address of the actual parameter.

3.3 Final / finalize /finally
  1. Final
  2. final is a key word, used to apply restrictions on class, method and variable.
  3. final class can not be inherited,
  4. final method can not be overridden// [,əuvə’ridn]
  5. final variable value can not be changed
  6. used to declare constants
  7. Finally
  8. Finally is a block, used in try catch statement to place important code.
  9. it will be executed whether exception is handled or not
  10. it means that no matter what happened, the code in finally block will be executed
  11. Finalize
  12. Finalize is a method, used to perform clean up processing just before object is garbage collected.

3.4 OOP
  1. Object Oriented Programming: programming language model organized around objects rather than “actions” and data rather than logic
  2. Your program consists of a number of “objects”, which are combinations of data and operations that you can do with that data. We can sent “Messages” to objects, and the messages make them perform operations. that is call a method. The program consist of collections of objects that send messages to each other.

3.5 OOP concepts
  1. Abstraction: The process of picking out (abstracting) common features of objects and procedures.

  2. Class:
    1. A category of objects. The class defines all the common properties of the different objects that belong to it.
    2. A class, in the context of Java, are templates that are used to create objects, and to define object data types and methods.
  3. Encapsulation: // [ɪn,kæpsə’leʃən]
    1. Encapsulation enable programmers to hide the data of one class from another class. This is needed to protect the normal behavior of one class. We implemented it using key words including public, private, and protect
    2. Encapsulation in Java is a mechanism of wrapping the data (variables) and code acting on the data (methods) together as a single unit.
    3. In encapsulation, the variables of a class will be hidden from other classes, and can be accessed only through the methods of their current class
  4. Inheritance: // [in’heritəns] a feature that represents the “is a” relationship between different classes. Inheritance in OOP enable a programmer to extend the capabilities of class without changing the class.

  5. Interface: the languages and codes that the applications use to communicate with each other and with the hardware.

  6. Object: a self-contained entity that consists of both data and procedures to manipulate the data.

  7. Polymorphism: // [,pɔli’mɔ:fizm]
    1. Subclasses of a class can define their own unique behaviors and yet share some of the same functionality of the parent class.
    2. Polymorphism enables programmers to use a different object in place of another provided that object can do the task (implements the same interface).
  8. How will you access the properties of that class? !!!!!!!!!!!!!

3.6 overloading/overriding
  1. Overloading : define two method, same name but they have different parameters
  2. Overriding: When you redefine a method which has already define in parent class(using exact same paremeters)

3.7 hashmap vs. hash table vs. hashset
  1. HashMap
    1. is implemented as a hash table, and there is no ordering on keys or values.
    2. what happens when a duplicate key is putting into a hashmap? Overwrite that key if hashmap has the same key. the old value is simply replaced.
  2. HashSet is Implemented using a hash table, is backed up by a HashMap. Elements are not ordered. The add, remove, and contains methods have constant time complexity O(1).
    1. set: Set interface: A Set contains no duplicate elements. That is one of the major reasons to use a set. When and which to use is an important question. In brief, if you need a fast set, you should use HashSet;
  3. synchronize HashMap,HashSet explicitly:Set s = Collections.synchronizedSet(new HashSet(...));,Map m = Collections.synchronizedMap(new HashMap(...));
  4. Hashtable vs hashmap
    1. hashtable is synchronized, whereas HashMap is not (in contrast to HashMap). It has an overhead for synchronization. All methods of Hashtable are synchronized which makes them quite slow due to contention if a number of thread increases. This makes HashMap better for non-threaded applications, as unsynchronized Objects typically perform better than synchronized ones.
      • Synchronized: keyword prevents concurrent access to a block of code or object by multiple Threads
    2. Hashtable does not allow null keys or values. HashMap allows one null key and any number of null values.
    3. HashMap implementation LinkedHashMap maintains the insertion order and TreeMap sorts the mappings based on the ascending order of keys. Hashtable doesn’t guarantee any kind of order. It doesn’t maintain the mappings in any particular order.
    4. Initially Hashtable was not the part of collection framework it has been made a collection framework member later after being retrofitted to implement the Map interface. HashMap implements Map interface and is a part of collection framework since the beginning.
    5. Another difference between these classes is that the Iterator of the HashMap is a fail-fast and it throws ConcurrentModificationException if any other Thread modifies the map structurally by adding or removing any element except iterator’s own remove() method. Fail-fast means: When calling iterator.next(), if any modification has been made between the moment the iterator was created and the moment next() is called, a ConcurrentModificationException is immediately thrown. Enumerator for the Hashtable is not fail-fast.
      • example:
              //HashMap:
              HashMap hm= new HashMap(); 
              ....
              Set keys = hm.keySet();
              for (Object key : keys) {
              // throw the ConcurrentModificationException here           hm.put(object & value pair);
              } 
              //Hashtable:
              Hashtable ht= new Hashtable(); 
              .....
              Enumeration keys = ht.keys();
              for (Enumeration en = ht.elements() ; en.hasMoreElements() ; en.nextElement()) { 
                  //No exception would be thrown here
                  ht.put(key & value pair);
              }
        
        

3.8 Array vs. ArrayList vs. LinkedList
  1. Array
    1. Array is a container object that holds a fixed number of values of a single type.
    2. Array has fix size, and the size is set when we initialize an array.
    3. Array can contain primitive types, can be multi-dimensional, while ArrayList is resizable, cannot contain primitive types, only one-dimensional.
  2. ArrayList and LinkedList both implements List interface, maintain the insertion order, non-synchronized (can use Collections.synchronizedList to synchronize).
    1. Arraylist is implemented by array.
    2. Linked list is implemented by doubly linked list.
  3. Operations:
    1. Search: ArrayList search operation is pretty fast compared to the LinkedList search operation. get(int index) in ArrayList gives the performance of O(1) while LinkedList performance is O(n).
      • Reason: ArrayList maintains index based system for its elements as it uses array data structure implicitly which makes it faster for searching an element in the list. On the other side LinkedList implements doubly linked list which requires the traversal through all the elements for searching an element.
    2. Deletion: LinkedList remove operation gives O(1) performance while ArrayList gives variable performance: O(n) in worst case (while removing first element) and O(1) in best case (While removing last element).
      • Reason: LinkedList’s each element maintains two pointers (addresses) which points to the both neighbor elements in the list. Hence removal only requires change in the pointer location in the two neighbor nodes (elements) of the node which is going to be removed. While In ArrayList all the elements need to be shifted to fill out the space created by removed element.
    3. Inserts Performance: LinkedList add method gives O(1) performance while ArrayList gives O(n) in worst case. Reason is same as explained for remove.
    4. Memory Overhead: ArrayList maintains indexes and element data while LinkedList maintains element data and two pointers for neighbor nodes hence the memory consumption is high in LinkedList comparatively.
  4. When to use LinkedList and when to use ArrayList? 1) As explained above the insert and remove operations give good performance (O(1)) in LinkedList compared to ArrayList(O(n)). Hence if there is a requirement of frequent addition and deletion in application then LinkedList is a best choice. 2) Search (get method) operations are fast in Arraylist (O(1)) but not in LinkedList (O(n)) so If there are less add and remove operations and more search operations requirement, ArrayList would be your best bet.

3.9 stringbuilder vs string buffer
  1. String class is used to manipulate character strings that cannot be changed. Objects of type String are read only and immutable.
  2. The StringBuffer class is used to represent characters that can be modified.
  3. StringBuilder is faster than StringBuffer because it’s not synchronized. StringBuffer thread safe

3.10 error vs. exception
  1. An Error “indicates serious problems that a reasonable application should not try to catch.”
  2. An Exception “indicates conditions that a reasonable application might want to catch.”
  3. Error along with RuntimeException & their subclasses are unchecked exceptions. All other Exception classes are checked exceptions.
  4. (in another words)In Java exceptions under Error and RuntimeException classes are unchecked exceptions, everything else under throwable is checked.
  5. Checked exceptions are the exceptions that are checked at compile time; Unchecked exceptions are the exceptions that are not checked at compiled time.
  6. More about check exception and unchecked exception: http://netjs.blogspot.com/2015/05/difference-between-checked-unchecked-exception-java.html
    3.11 method vs. constructor.
  7. Constructors can’t be called directly; they are called implicitly when the new keyword creates an object. Methods can be called directly on an object that has already been created with new.
  8. Constructors must be named with the same name as the class name. They can’t return anything, even void (the object itself is the implicit return). Methods must be declared to return something, although it can be void.

3.12 void main
  1. Void is the return type of this method, indicating that this method doesn’t return anything.
  2. Main is the name of a function. main() is special because it is the start of the program.

3.13 Primitive types
  1. Byte: 8-bit signed two’s complement integer, [-128, 127]. The byte data type can be useful for saving memory in large arrays, where the memory savings actually matters.
  2. Short: 16-bit signed two’s complement integer. Save memory in large arrays of floating point numbers.
  3. Int: 32-bit signed two’s complement integer, [-231, 231-1]. In Java SE 8 and later, you can use the int data type to represent an unsigned 32-bit integer, which has a minimum value of 0 and a maximum value of 232-1. Static methods like compareUnsigned, divideUnsigned etc have been added to the Integer class to support the arithmetic operations for unsigned integers.
  4. Long: 64-bit two’s complement integer, [-263, 263-1]. In Java SE 8 and later, you can use the long data type to represent an unsigned 64-bit long, which has a minimum value of 0 and a maximum value of 264-1.
  5. Float: single-precision 32-bit IEEE 754 floating point. Save memory in large arrays of floating point numbers. This data type should never be used for precise values, such as currency. For that, you will need to use the java.math.BigDecimal class instead. Numbers and Strings covers BigDecimal and other useful classes provided by the Java platform.
  6. Double: double-precision 64-bit IEEE 754 floating point. For decimal values, this data type is generally the default choice. As mentioned above, this data type should never be used for precise values, such as currency. 7. Boolean: true / false. Use this data type for simple flags that track true/false conditions. This data type represents one bit of information, but its “size” isn’t something that’s precisely defined.
  7. Char: single 16-bit Unicode character. It has a minimum value of ‘\u0000’ (or 0) and a maximum value of ‘\uffff’ (or 65,535 inclusive).

3.14 when try catch? How will you handle the exception without using try-catch block?
  1. When you want to do any “work” after exception is thrown you will definitely go for using “Try/Catch” block.
  2. By default, the JVM handles uncaught exceptions by printing the stack-trace to System.err stream. Java allows us to customize this behavior by providing our own routine which implements Thread.UncaughtExceptionHandler interface.

3.15 access modifier

屏幕快照 2017-03-30 04.50.46.png

3.16 static
  1. Static indicates that this method can be called without creating an instance of this class
  2. In Java, a static member is a member of a class that isn’t associated with an instance of a class. Instead, the member belongs to the class itself. As a result, you can access the static member without first creating a class instance.
  3. static members belong to the class instead of a specific instance.
  4. It means that only one instance of a static field exists

3.17 J2EE, J2SE, JSP
  1. JavaSE (Standard Edition): For general-purpose use on desktop PCs,servers and similar devices.

  2. JavaEE (Enterprise Edition): Java SE plus various APIs useful for multi-tier client–server enterprise applications. The platform was known as Java2 Platform, Enterprise Edition or J2EE until the name was changed to JavaEEin version 5. The current version is called JavaEE 6.

  3. Java ServerPages (JSP) are server-side Java EE components that generate responses, typically HTML pages, to HTTP requests from clients. JSPs embed Java code in an HTML page by using the special delimiters<% and %>. A JSP is compiled to a Java servlet,a Java application in its own right, the first time it is accessed.After that, the generated servlet creates the response.

3.18 why do we need package the program.

A package is a namespace that organizes a set of related classes and interfaces

3.19 MVC

MVC: is a software architecture - the structure of the system MVC: (Model, View, Controller) is a pattern for organising code in an application to improve maintainability.

3.20 what is JDK,JRE,JVM
  1. JVM:
    1. The Java Virtual Machine (JVM) is an abstract computing machine. The JVM is a program that looks like a machine to the programs written to execute in it.
    2. (Java Virtual Machine) is an abstract machine. It is a specification that provides runtime environment in which java byte code can be executed
  2. JRE: is an acronym for Java Runtime Environment.It is used to provide runtime environment.It is the implementation of JVM. It physically exists.
  3. JDK: is an acronym for Java Development Kit.It physically exists.It contains JRE + development tools.

3.21 GC

Generational garbage collector

  1. because: most objects have short lifetimes, a few live very long
  2. 2 or more generations
  3. old generation: The objects that did not become unreachable and survived from the young generation are copied here. + young generation: Most of the newly created objects are located here.
  4. Composition of the Young Generation
    1. One Eden space
    2. Two Survivor spaces

3.22 Java里shared memory在哪儿

static heap stack, static和heap都可以,depends on your program

不太重要:

3.- HashSet vs. TreeSet vs. LinkedHashSet

Set interface: A Set contains no duplicate elements. That is one of the major reasons to use a set. When and which to use is an important question. In brief, if you need a fast set, you should use HashSet; if you need a sorted set, then TreeSet should be used; if you need a set that can be store the insertion order, LinkedHashSet should be used. HashSet is Implemented using a hash table. Elements are not ordered. The add, remove, and contains methods have constant time complexity O(1). TreeSet is implemented using a tree structure(red-black tree in algorithm book). The elements in a set are sorted, but the add, remove, and contains methods has time complexity of O(log (n)). It offers several methods to deal with the ordered set like first(), last(), headSet(), tailSet(), etc. LinkedHashSet is between HashSet and TreeSet. It is implemented as a hash table with a linked list running through it, so it provides the order of insertion. The time complexity of basic methods is O(1).

3.- HashMap vs. TreeMap vs. HashTable vs. LinkedHashMap vs. ConcurrentHashMap

HashMap is implemented as a hash table, and there is no ordering on keys or values. TreeMap is implemented based on red-black tree structure, and it is ordered by the key. LinkedHashMap preserves the insertion order HashMap methods are unsynchornized and it allows null key and null values unlike Hashtable. Hashtable is synchronized, in contrast to HashMap. It has an overhead for synchronization. All methods of Hashtable are synchronized which makes them quite slow due to contention if a number of thread increases. ConcurrentHashMap is thread safe without synchronizing the whole map. Reads can happen very fast while write is done with a lock. There is no locking at the object level. Unlike Hashtable and Synchronized Map, it never locks whole Map, instead, it divides the map into segments and locking is done on those. Though it performs better if a number of reader threads are greater than the number of writer threads.

3.- Vector

Vector implements List Interface. Like ArrayList it also maintains insertion order but it is rarely used in non-thread environment as it is synchronized and due to which it gives poor performance in searching, adding, delete and update of its elements.

  1. create vector class object
    • Vector vec = new Vector();
    • Vector object= new Vector(int initialCapacity)
      • Vector vec = new Vector(3); It will create a Vector of initial capacity of 3.
    • Vector object= new vector(int initialcapacity, capacityIncrement)
      • Vector vec= new Vector(4, 6); Here we have provided two arguments. The initial capacity is 4 and capacityIncrement is 6. It means upon insertion of 5th element the size would be 10 (4+6) and on 11th insertion it would be 16(10+6).

4.其他

4.1 For real-time video conference application, how do you choose between TCP and UDP?

TCP for stored video and UDP for live video 本题的关键在于比较TCP和UDP的特点,并且根据real-time video conference这个特定的应用场景进行选择。前面提到过,TCP的重传机制会增加延迟,所以不适用于当前场景。其次,视频音频编码本身可以容忍数据出错甚至数据丢失。因此,并不需要采用TCP进行可靠的数据传输。当某一视频帧出现丢包时,可以直接跳过这一帧或者继续播放上一帧。再次,一旦出现网络堵塞的状况,发送端应该主动丢弃一部分数据。原因是,即使这些视频帧发送到了接收端,也可能已经“过期”了,不会被解码显示。采用自己设计的UDP更便于实现对数据包的控制。然而,即使使用UDP,也需要实现TCP的某些模块:比如需要flow control和congestion control来判断接收端的播放情况和网络情况,并且也需要反馈机制判断接收端的接收状况。尽管对于当前场景我们不需要ACK每个数据包,但是接收端可以反馈当前收到的最新完整视频帧的序号。这样,如果一旦发生丢包,发送端可以以接收端收到的最新视频帧为基础,压缩后继的视频。

Video streaming meets with TCP in their nature. First, video streaming adopts pre-fetching and buffering to achieve smooth play-out. TCP provides such (network) buffer, as well as the reliable transmission guarantee for no loss of frame (a frame could still miss the play-out deadline and discarded, however). Second, TCP’s bandwidth probing and congestion control will attempt to use all of the available bandwidth between server and client, fetching content as quick as possible while being friendly to other (TCP) traffic on the same links. However, live streaming opts in UDP, because little pre-fetching can be done and buffering will add delay to the video play-out. Since UDP serves only the most basic transport layer functionality, it is used jointly with other application layer protocols such as RTSP  to do video streaming. Firewalls (from enterprise, ISPs) dislike these protocols, making video traffic difficult to traverse through or being throttled. In order to deliver videos, platforms adopt/rent Content Delivery Networks (CDN). Most of the CDN servers (e.g. Akamai’s) are configured to support web services as their primary course. Thus, streaming video over HTTP works out the box without setting up dedicated servers, and most of the firewalls won’t block HTTP traffic. In fact, Dynamic Adaptive Streaming over HTTP (DASH) has become a common practice. Although in theory HTTP can be encapsulated other protocols, they still need to provide reliable transfer, which again precludes UDP. Notably, for companies such as Google and Netflix, they build their own CDN.

Drawbacks of using TCP for live video:

  1. Typically live video-streaming appliances are not designed with TCP streaming in mind. If you use TCP, the OS must buffer the unacknowledged segments for every client. This is undesirable, particularly in the case of live events; presumably your list of simultaneous clients is long due to the singularity of the event. Pre-recorded video-casts typically don’t have as much of a problem with this because viewers stagger their replay activity; therefore TCP is more appropriate for replaying a video-on-demand.
  2. IP multicast significantly reduces video bandwidth requirements for large audiences; TCP prevents the use of IP multicast, but UDP is well-suited for IP multicast.
  3. Live video is normally a constant-bandwidth stream recorded off a camera; pre-recorded video streams come off a disk. The loss-backoff dynamics of TCP make it harder to serve live video when the source streams are at a constant bandwidth (as would happen for a live-event). If you buffer to disk off a camera, be sure you have enough buffer for unpredictable network events and variable TCP send/backoff rates. Note that if TCP loses too many packets, the connection dies; thus, UDP gives you much more control for this application since UDP doesn’t care about network transport layer drops. FYI, please don’t use the word “packages” when describing networks. Networks send “packets”.
4.2 What happens after you typed a URL in your browser and pressed return key?

如果要连到远程服务器,首先需要知道服务器的IP地址和端口。其次需要发送接入请求到服务器,服务器返回响应数据。因此,如何寻址和如何建立链接是本题的关键。本题属于知识性问题,没有太多的解题技巧,直接给出解答如下 1. 进行寻址:如果在浏览器缓存中存有URL的对应IP,则直接查询其IP;否则,访问DNS(Domain Name System)进行寻址(Domain Name Resolution)。 2. DNS或者URL cache返回网页服务器的IP地址。 3. 浏览器与网页服务器通过三次握手建立TCP连接。由于是网页浏览服务,故浏览器连接到服务器的80端口。 4. 浏览器与服务器建立HTTP会话(session),接收来自服务器的HTTP数据。 5. 浏览器解析HTTP数据,在本地窗口内渲染并显示网页。 6. 当浏览器页面被关闭时,终止HTTP会话并关闭链接。

In an extremely rough and simplified sketch, assuming the simplest possible HTTP request, no proxies, IPv4 and no problems in any step:

  1. browser checks cache; if requested object is in cache and is fresh, skip to #9
  2. browser asks OS for server’s IP address
  3. OS makes a DNS lookup and replies the IP address to the browser
  4. browser opens a TCP connection to server (this step is much more complex with HTTPS)
  5. browser sends the HTTP request through TCP connection
  6. browser receives HTTP response and may close the TCP connection, or reuse it for another request
  7. browser checks if the response is a redirect or a conditional response (3xx result status codes), authorization request (401), error (4xx and 5xx), etc.; these are handled differently from normal responses (2xx)
  8. if cacheable, response is stored in cache
  9. browser decodes response (e.g. if it’s gzipped)
  10. browser determines what to do with response (e.g. is it a HTML page, is it an image, is it a sound clip?)
  11. browser renders response, or offers a download dialog for unrecognized types Again, discussion of each of these points have filled countless pages; take this only as a short summary. Also, there are many other things happening in parallel to this (processing typed-in address, speculative prefetching, adding page to browser history, displaying progress to user, notifying plugins and extensions, rendering the page while it’s downloading, pipelining, connection tracking for keep-alive, checking for malicious content etc.) - and the whole operation gets an order of magnitude more complex with HTTPS (certificates and ciphers and pinning, oh my!).

You type in the URL and hit go. The browser needs to translate that URL www.somesite.com into an IP address so it knows what computer on the internet to connect to (That URL is just there to make it easier for us humans - kinda like speed-dial for phone numbers I guess). So your browser will see if it already has the appropriate IP address cached away from previous visits to the site. If not, it will make a DNS query to your DNS server (might be your router or your ISP’s DNS server) - see http://en.wikipedia.org/wiki/Domain_name… for more on DNS. Once your browser knows what IP to use, it will connect to the appropriate webserver and ask for the page. The webserver then returns the requested page and your browser renders it to the screen.

以上答案大部分来自google,wiki, stackoverflow。

HTML5 COURSERA-notes

|

course link 算是入门笔记,每周更 H5

  1. 大概念 HTML structure CSS style js behavior

  2. WEEK1 HTML annotates content defines document structure

3core web technologies:HTML CSS JS

WHATWG和W3C一起出的H5

##HTML

  1. element name
content </closing tag> 2. only have opening tag: `<\br>,
` 3. attribute name id = "dd" attribute value 4. value in quote, quote should be closed correctly 5. semantic change 不能自己close自己了,

---->

6. browser render html sequentially(top-bottom) 7. H5 seven models 8. traditional models: block-level element(div): render to begin on new line by default; may contain inline or other block-level element/inline element(span): render on the same line; only contain other inline elements 9. headings 和div+css实现可以看到一样的效果但是作用不一样,seo会依据h1这些tag执行搜索什么的,H1 you should always have it there 10. 有语义的element比如`

`比div这种有更大意义和功能 11. list ul/ol (unorder list/order list) list for navigation 12. avoid rendering issues: </>/&/ </>/&amp 如果想使用<>&要输入这些来防止当做html标记解析, copyright shows the copyright symbol /nbsp:(想把几个短语放在一起letcure7里讲到, 把这几个字符跟在一个单词后面,单词后面的空格就不能换行) 13. href relative links <\a> 是block-level也是inline flow content, H5: a标签可以surround在
外面了,点击整个区域都可以跳转 14. target = _bland new tab/new window 15. fragment identifier href = "#sections" 跳转到当前页的某处(jump to different parts of the same page),sections是某标签的id attribute的value `

`可以直接跳转到top SPA single page application 16. image inline element 写上宽高,方便浏览器预留空间,chrome developer tools,network no throttling里可以调别的,就是模拟网速慢的时候 ##Week2 CSS box model css layout 1. an interesting website: cssszengarden/219 2. user experience of content matters 3. anatomy of a css rule ``` selector { property:value; //declaration } p { color:blue; font-size:20px; } ``` 4. selector: specifying the element name class `className{}` //pound sign, only can use once id`#idName{}` html element we can group selector, separate selector with comma `div,.class1{}` 这些selector都有后面大括号里的属性 5. combining selector 1. `p.big{}`(element with class selector) every p that has class = "big", no space! 2. `article > p`(direct child selector) every p that is a **direct** child of article 3. `article p`(descendent selector) every p that is inside(at any level) of article 4. `.class1.class2`(这里也是no space?) select the element, who both have these two class 6. pseudo-class ``` selector: pseudo-class :link :visited :hover :active :nth-child //link can applied another style a:link, a:visited{ display:block; } a:hover, a:active{ } header li:nth-child(3){ } section div:nth-child(odd){ } section div:nth-child(4):hover{ } ``` 7. resolve conflict 1. simple rule: last declaration wins, (top to bottom, which the bottom declaration wins, external<internal declaration.) 2. even simple rule: declarations merge(different properties, merge to one) 8. specificity inner element style>id>classname>numbers of element ``` header.navigation p{}>p.blurb{}