七段

          無論怎樣,請讓我先感謝一下國家。

          BlogJava 首頁 新隨筆 聯系 聚合 管理
            35 Posts :: 2 Stories :: 7 Comments :: 0 Trackbacks

          #

          posted @ 2010-02-22 10:00 sevenduan 閱讀(248) | 評論 (0)編輯 收藏

          Navigation Practice Agenda:
          1, forward & redirect; Get & Post:
          How to choose between them? How to apply by JSF/JSP? what's default in JSF?
          How to resolve issue about resources not found caused by forward navigation?
          Does the request scope objects still available after redirect?
          2, done back
          How to done back in client side? browser history back; js history back manager
          How to done back at server side? JSF
          3, How to navigation only inside of page?
          scroll bar navigation: anchor? scroll bar ?
          focus on different DOM elements?
          4, How to do not navigate?
          refresh page, ajax refresh
          Could you make your page support Refresh with right navigate behavior?
          5, How to navigate among tabs and windows?
          form submit target:_blank,_self,_parent,_top,frameName
          6, JSF navigation management
          referrence: http://java.sun.com/dtd/web-facesconfig_1_1.dtd
          How does JSF choose navigation rule case when match mutiple cases?
          7, How to pass parameters during navigation?
          page, request, session, application

          posted @ 2010-02-08 14:45 sevenduan 閱讀(301) | 評論 (0)編輯 收藏

          I was told something about js module framework two years ago. But without a deep dive into it, so that I have to ride out large bundles of js files in a mess on our projects for a long time. After kejun’s YUI presentation on D2 2009, I thought that it’s time to change.

          Why use js module?

          1, better js organization, readable + flexible + dependencies ordering

          2, better performance, asynchronize loading JIT

          How we did it before?

          1, inline script in jsp : hard to unittest, make the file looks tedious and ugly

          2, separated js script file: bad organization, too many ugly import tag <script>

          What is the existed solution?

          1, YUI module: http://developer.yahoo.com/yui/yuiloader/

          2, Jawr: a tunable packaging solution for Javascript and CSS written in java

          3, jQuery getSscript: http://ejohn.org/blog/degrading-script-tags/

          4, jspkg: http://jspkg.sourceforge.net/docs/index.html

          5, module.js http://ajaxian.com/archives/modulesjs-a-new-stand-alone-javascript-module-loader

           to do ...

          posted @ 2010-01-04 23:41 sevenduan 閱讀(1571) | 評論 (0)編輯 收藏

          Pros and Cons:

          Pros:

          1, reduce configuration xml files

          2, readable by self-documenting

          Cons:

          1, it adds deployment context to classes, which should be generic enough.

          2, interfere with design principles such as IOC and dependency injection, because you need to introduce imports

          Usage (annotation works only when handled by related annotation processor):

          • Information for the compiler — Annotations can be used by the compiler to detect errors or suppress warnings.
          • Compiler-time and deployment-time processing — Software tools can process annotation information to generate code, XML files, and so forth.
          • Runtime processing — Some annotations are available to be examined at runtime.

            1 import java.io.IOException;
            2 import java.io.PrintStream;
            3 import java.lang.reflect.AnnotatedElement;
            4 import java.lang.annotation.Annotation;
            5 
            6 import java.util.Date;
            7 import java.lang.annotation.Documented;
            8 import java.lang.annotation.Inherited;
            9 import java.lang.annotation.Retention;
           10 import java.lang.annotation.RetentionPolicy;
           11 
           12 public class ReflectionTester {
           13 
           14   public ReflectionTester() {
           15   }
           16 
           17   public void testAnnotationPresent(PrintStream out) throws IOException {
           18     Class c = Super.class;
           19     boolean inProgress = c.isAnnotationPresent(InProgress.class);
           20     if (inProgress) {
           21       out.println("Super is In Progress");
           22     } else {
           23       out.println("Super is not In Progress");
           24     }
           25   }
           26 
           27   public void testInheritedAnnotation(PrintStream out) throws IOException {
           28     Class c = Sub.class;
           29     boolean inProgress = c.isAnnotationPresent(InProgress.class);
           30     if (inProgress) {
           31       out.println("Sub is In Progress");
           32     } else {
           33       out.println("Sub is not In Progress");
           34     }
           35   }
           36 
           37   public void testGetAnnotation(PrintStream out) 
           38     throws IOException, NoSuchMethodException {
           39 
           40     Class c = AnnotationTester.class;
           41     AnnotatedElement element = c.getMethod("calculateInterest"
           42                                   float.classfloat.class);
           43 
           44     GroupTODO groupTodo = element.getAnnotation(GroupTODO.class);
           45     String assignedTo = groupTodo.assignedTo();
           46 
           47     out.println("TODO Item on Annotation Tester is assigned to: '" + 
           48         assignedTo + "'");
           49   }
           50 
           51   public void printAnnotations(AnnotatedElement e, PrintStream out)
           52     throws IOException {
           53 
           54     out.printf("Printing annotations for '%s'%n%n", e.toString());
           55 
           56     Annotation[] annotations = e.getAnnotations();
           57     for (Annotation a : annotations) {
           58       out.printf("    * Annotation '%s' found%n"
           59         a.annotationType().getName());
           60     }
           61   }
           62 
           63   public static void main(String[] args) {
           64     try {
           65       ReflectionTester tester = new ReflectionTester();
           66 
           67       tester.testAnnotationPresent(System.out);
           68       tester.testInheritedAnnotation(System.out);
           69 
           70       tester.testGetAnnotation(System.out);
           71 
           72       Class c = AnnotationTester.class;
           73       AnnotatedElement element = c.getMethod("calculateInterest"
           74                                     float.classfloat.class);      
           75       tester.printAnnotations(element, System.out);
           76     } catch (Exception e) {
           77       e.printStackTrace();
           78     } 
           79   }
           80 }
           81 
           82 class Sub extends Super {
           83 
           84   public void print(PrintStream out) throws IOException {
           85     out.println("Sub printing");
           86   }
           87 }
           88 
           89 @InProgress class Super {
           90 
           91   public void print(PrintStream out) throws IOException {
           92     out.println("Super printing");
           93   }
           94 }
           95 
           96 @Documented
           97 @Retention(RetentionPolicy.RUNTIME)
           98 @interface GroupTODO {
           99 
          100   public enum Severity { CRITICAL, IMPORTANT, TRIVIAL, DOCUMENTATION };
          101 
          102   Severity severity() default Severity.IMPORTANT;
          103   String item();
          104   String assignedTo();
          105   String dateAssigned();
          106 }
          107 
          108 /**
          109  * Marker annotation to indicate that a method or class
          110  *   is still in progress.
          111  */
          112 @Documented
          113 @Inherited
          114 @Retention(RetentionPolicy.RUNTIME)
          115 @interface InProgress { }
          116 
          117 class AnnotationTester {
          118 
          119   @InProgress
          120   @GroupTODO(
          121     severity=GroupTODO.Severity.CRITICAL,
          122     item="Figure out the amount of interest per month",
          123     assignedTo="Brett McLaughlin",
          124     dateAssigned="04-26-2004"
          125   )
          126   public void calculateInterest(float amount, float rate) {
          127     // Need to finish this method later
          128   }
          129 }
          130 
          posted @ 2010-01-04 11:28 sevenduan 閱讀(1656) | 評論 (0)編輯 收藏

           Introduction:
          JSF:  MVC framework as Struts
          DWR: java Ajax framework
          Json: a data format definition like XML, YAML. We could use DWR or jsonlib to marshal/unmarshal between json and objects.

          How to use?
          1, when should we use json or not?
          do JSF as much as possible;
          only when dynamic collection size on page, do Json
          2, when should we use DWR json convertor configuration or customize json convertor by java?
          page scope update, do Ajax by DWR as much as possible;
          otherwise, do JSF action by json convertor (consolidate convertor by jsonlib or dwr?)


          DWR convertor VS Jsonlib convertor:
              DWR:
              convertor setting by xml, annotation or java;

              Jsonlib:
              convertor setting by java (only check @Transient), but more professional overall;

          Requirement:
          1, simple convertion, no VO or DTO:
              PO to json: 1, cycle detect; 2,include/exclude;
              Json to PO: 1, the same js handle; 2, ajax by dwr; jsf by hidden string
          2, one PO map into two JSON model for different domains (e.g. bind different convertor by spring to different domain serviceImpl)

          Not to do list:
          1, do not use duplicated convertors definition in java/xml/annotation
          2, do not DTO or VO when convert between json and objects
          3, do not parse or transfer useless fields, e.g. use include / exclude configuration instead during convert objects into json; use "delete" during convert json into object
          4, do not use json if could use JSF

          posted @ 2010-01-04 08:58 sevenduan 閱讀(1856) | 評論 (0)編輯 收藏

           1 var alltrue = [truetruetrue];// false
           2             var allfalse = [falsefalsefalse];// false
           3             var chaos = [truefalsetruefalse];// true
           4             //1,logic operation;2,shorten-cycle;
           5             function LogicXOR(){
           6                 var args = arguments;
           7                 if (args.length == 1) {
           8                     if (args[0].length) {
           9                         args = args[0];
          10                     }
          11                     else {
          12                         return args[0];
          13                     }
          14                 }
          15                 
          16                 var count = args.length;
          17                 while (--count > 0) {
          18                     if (!args[count] !== !args[count - 1]) 
          19                         return true;
          20                 }
          21                 return false;
          22             }
          23             
          24             alert(LogicXOR(alltrue))
          25             alert(LogicXOR(allfalse))
          26             alert(LogicXOR(chaos))
          27             alert(LogicXOR(truetruetrue))
          28             alert(LogicXOR(falsefalsefalse))
          29             alert(LogicXOR(truefalsetruefalse))
          posted @ 2009-12-22 15:59 sevenduan 閱讀(1269) | 評論 (0)編輯 收藏

          Collection>
              boolean contains(Object o):return true only if has (o==null ? e==null :o.equals(e))
              boolean removeAll(Collection<?> c); remove elements in c
              boolean retainAll(Collection<?> c); remove elements not in c
              Queue VS List VS Set
              List>
                  ListIterator<E> listIterator();| Iterator<E> iterator();
                  next() & previous()|only has next()
                  add() & remove()|only has remove()
                  * you can not use list.add() during both two iteration, otherwise,ConcurrentModificationException

          RandomAccess>
                  Marker interface used by List implementations to indicate that they support fast (generally constant time) random access. e.g.
                  for (int i=0, n=list.size(); i < n; i++)
                           list.get(i);
                  runs faster than this loop:
                       for (Iterator i=list.iterator(); i.hasNext(); )
                           i.next();

          HashMap, HashSet, HashTable>
              HashMap(int initialCapacity, float loadFactor)        resize()
              HashSet(int initialCapacity, float loadFactor) {map = new HashMap<E,Object>(initialCapacity, loadFactor);}
              Hashtable(int initialCapacity, float loadFactor) extends Dictionary<K,V>  ; synchronized ;  rehash();
              hash = hash(key.hashCode());
              *TreeMap Red-black mechanics
          posted @ 2009-12-21 23:04 sevenduan 閱讀(831) | 評論 (0)編輯 收藏

          String>
              String|StringBuffer|StringBuilder
              immutable|mutable|mutable  <-- depends on the char[] value is final or not;
              thread-safe|thread-safe|single thread

          1, compile phase:
              constance will be directly written. OuerClass.constance not refer to it during runtime.
              + =after compiled=> StringBuilder

          2, Performance:
              usually, StringBuilder>StringBuffer>+; but need  to make sure the real generated class file.
              String.intern() is better if too many duplicated string instance.

          3, String <--> bytes
          decode: String(byte bytes[], int offset, int length, Charset charset)
          encode: String.getBytes(Charset charset)

          4, StringTokenizer | String.split
              better performance | RegEx
          posted @ 2009-12-21 22:36 sevenduan 閱讀(1346) | 評論 (0)編輯 收藏

          當IE中發生js對象與dom對象直接的循環引用,并且之后沒有引用指向他們,
          如果是IE 6, 內存泄漏,直到關閉IE進程為止
          如果是IE 7,內存泄漏, 直到離開當前頁面為止
          如果是IE 8, GC回收器回收他們的內存,無論當前是不是compatibility模式。

          為什么有內存泄漏?
          之前的IE js引擎里的GC回收器只能處理js對象,不能處理DOM對象。

          refer to: http://msdn.microsoft.com/en-us/library/dd361842%28VS.85%29.aspx#compat

          posted @ 2009-12-16 16:07 sevenduan 閱讀(1366) | 評論 (0)編輯 收藏


          1、 說話的時機:成事不說、遂事不諫、既往不咎
          2、 不同事情,不同說法:好事情,用播新聞的方式;壞事情,先說結果
          3、 試探性的說話:放話出去
          4、 見人說人話,見鬼說鬼話,不人不鬼說胡話
          摘選自:http://blog.csdn.net/zhaowei001/archive/2008/04/10/2279172.aspx
          posted @ 2009-12-15 22:34 sevenduan 閱讀(157) | 評論 (0)編輯 收藏

          僅列出標題
          共4頁: 上一頁 1 2 3 4 下一頁 
          主站蜘蛛池模板: 枣强县| 娱乐| 内丘县| 康定县| 建昌县| 牡丹江市| 沾化县| 宁波市| 岐山县| 房产| 聊城市| 鲁山县| 泸溪县| 南宁市| 五华县| 始兴县| 潼关县| 左贡县| 延边| 澄江县| 增城市| 延津县| 塘沽区| 乌什县| 金堂县| 新巴尔虎右旗| 洪江市| 清徐县| 大姚县| 山东省| 大兴区| 镇远县| 调兵山市| 平塘县| 克山县| 南雄市| 江津市| 宁蒗| 乐平市| 五华县| 慈利县|