跳到主要內容

設計模式-Builder(建立者)

Builder 定義

  1. 使用物件有多參數輸入時,可以簡化多參數建立並初始化實例功能
  2. 強調物件屬性與物件建構可以分離,不同建構可以表示不同物件

Builder 使用情況

  1. 初始化參數因參數多,簡化參數建立過程
  2. 2.

Builder 案例

這是利用Buildr模式來簡化日期計算可以看到DateBuilder建立只有基本參數宣告,實際計算方法是建立在Builder物件中,最後載執行由Calendar做日期加減的計算。建立者分離的物件參數與計算方法,但是帶來良好封裝性

    /**
     * Name: builder
     * Description :  日期建立可以自由輸入年 月 日後,建立日期
     * Created by blackbryant on 2017/1/7.
     */
    public class DateBuilder {
        private Locale locale ; 
        private String format ; 
        private int day ; 
        private int month ; 
        private int year ; 
        private int hour ;
        private int minute ; 
        private int second ;
        private String date ; 

        //需要宣告為靜態類別
        public static class Builder{
            private Locale locale ; 
            private String format ; 
            private int day ; 
            private int month ; 
            private int year ; 
            private int hour ;
            private int minute ; 
            private int second ;
            private String date ; 

            public Builder(String calDate, String formate){
                this.date = calDate ;
                this.format = formate ;
            }

            public DateBuilder build(){
                return new DateBuilder(this) ;
            }

            public Builder addDay(int day){
                this.day = day  ; 
                return this;
            }

            public Builder addMonth(int month){
                this.month = month  ; 
                return this;
            }

            public Builder addYear(int year){
                this.year = year  ; 
                return this;
            }

            public Builder addHour(int hour){
                this.hour = hour;
                return this;
            }

            public Builder addMinute(int minute){
                this.minute = minute ; 
                return this ;
            }

            public Builder addSecond(int second){
                this.second = second ;
                return this;
            }

            public Builder setformat(String format){
                this.format = format ; 
                return this ;
            }
        }

        private DateBuilder(Builder builder){
            this.locale = builder.locale ;
            this.year = builder.year ; 
            this.month = builder.month ; 
            this.day = builder.day ; 
            this.hour = builder.hour ; 
            this.minute = builder.minute ; 
            this.second = builder.second ; 
            this.format = builder.format ;
            this.date = builder.date ;
        }


        public Locale getLocale() {
            return locale;
        }

        public String getFormat() {
            return format;
        }

        public int getDay() {
            return day;
        }

        public int getMonth() {
            return month;
        }

        public int getYear() {
            return year;
        }

        public int getHour() {
            return hour;
        }

        public int getMinute() {
            return minute;
        }

        public int getSecond() {
            return second;
        }

        public String getDate(){
            return date ;
        }

        @Override
        public String toString() {
            StringBuilder sb = new StringBuilder() ; 
            sb.append("locale="+this.locale) ; 
            sb.append("year="+this.year) ; 
            sb.append("month="+this.month) ; 
            sb.append("day="+this.day) ; 
            sb.append("hour="+this.hour) ; 
            sb.append("minute="+this.minute) ; 
            sb.append("second="+this.second) ; 
            sb.append("format="+this.format) ; 
            return sb.toString();
        }

        public  static  void main(String[] args){
            DateBuilder dateBuilder = new DateBuilder.Builder("2001-01-01","yyyy-MM-dd").addDay(2).build() ;

            SimpleDateFormat sdf = new SimpleDateFormat(dateBuilder.getFormat()) ;

            try {
                Date calDate = sdf.parse(dateBuilder.getDate());
                Calendar c = Calendar.getInstance() ;
                c.setTime(calDate);
                c.add(Calendar.YEAR,  dateBuilder.getYear());
                c.add(Calendar.MONTH, dateBuilder.getMonth());
                c.add(Calendar.DAY_OF_MONTH, dateBuilder.getDay());
                c.add(Calendar.HOUR, dateBuilder.getHour());
                c.add(Calendar.MINUTE, dateBuilder.getMinute());
                c.add(Calendar.SECOND, dateBuilder.getSecond());
                Date afterDate = c.getTime() ;
                System.out.print("add 1 day : " +afterDate.toString());
            } catch (ParseException e) {
                e.printStackTrace();
            }
        }
    }

留言

這個網誌中的熱門文章

JavaBean 和POJO

前言 今天介紹JavaBean和POJO的不同,這兩個名詞在JAVA文章常常被拿來使用以及討論。在JDK1.1時候釋出才有的一個標準架構,很多時候常常被搞混,所以我們特別開闢一章來加以討論。POJO規範在企業級應用已經廣大的被使用的規範。 解釋 POJO : 全名為Plain-old-Java-object,只需要繼承Object就可以,沒有特定規定,只要建立的類別有setter/getter方法都可以稱為POJO JavaBean: JavaBean通常用來封裝多個物件成為單獨物件使用,規範比較嚴格,規則如下 規則 說明 1 需要實作序列(Serializable/Externalizable) 2 不能有參數的建構子( no-arg constructor) 3 需要有公用setter/getter 4 屬性必須要私人(private) 5 屬於特定POJO規則 比較 所有的JavaBean都為POJO,但是所有的POJO不一定為JavaBean 都可以當作重複元件 都必須序列化 特性都為可用性、易用性和持久化使用 - 應用 由圖我們可以知道POJO在應用程式中,主要用來存取資料庫資料達到持久化的目的,並提供給商業邏輯流程處理使用。這種POJO的架構提供程式人員開發時的可以很有規則將資料封裝並加以使用。 範例1. JavaBean(以員工為實例) JavaBean建立員工物件,可以發現Employee物件建構子沒有任何參數,屬性為私有化並setter/getter的命名方式。 //實作序列化 public class Employee implements java.io.Serializable{ private int id; private String name; //無參數建構子 public Employee(){} //以下實作setter/getter public void setId(int id){this.id=id;} public int getId(){return id;} public void setName(String ...

Python AI-問題集

Python AI-問題集 問題集 Jupyter Notebook執行ipywidgets會出現kernel死掉的錯誤發生(The kernel appears to have died) 解決方法 (1) 根據log檔來判斷問題: 例如:log訊息出現OMP: Error #15: Initializing libiomp5.dylib, but found libiomp5.dylib already initialized. (2) 根據問題關鍵字找出問題所在: 利用google查詢所遭遇到的問題,例如我把上面的問題上google查詢可以找到這篇的解法 https://blog.csdn.net/bingjianIT/article/details/86182096 (3)實作解法: 我實作下面解法後,就可以順利執行手寫辨識的程式. //在Python宣告時加入 import os os.environ["KMP_DUPLICATE_LIB_OK"]="TRUE" 參考 https://blog.csdn.net/bingjianIT/article/details/86182096

GSON 進階教學

GSON進階教學 完成 基礎教學 後,本章節教你如何處理在非正常情況下,如何完成反序列與序列動作。 泛型轉換 序列化與反序列化時,客製化輸入出JOSN字串@SerializedName 忽略物件屬性輸出@Expose 泛型轉換 泛型做Json序列/反序列時,比較麻煩地方是泛型在運行期間相關的參數就會被抹除所以無法知道原來的類別。我們建立一個播放器(Play)類別,它為泛型的類型,它可撥放MP3、CD等等,所以建立一個CD媒介(CD)類別。Play使用類型為泛型T, 物件 屬性 播放器 Play 類型 type CD媒介 CD 歌 songs /**' * 播放器 * @param */ public class Play { T type ; public Play(T t){ this.type = t; } @Override public String toString() { return this.type.toString(); } } /** * CD 音樂物件 */ public class CD { private List songs ; public CD(String ...songs){ this.songs = new ArrayList() ; for(String song : songs){ this.songs.add(song) ; } } @Override public String toString() { StringBuilder sb = new StringBuilder() ; sb.append(""); for(String s:songs){ sb.append(""+s+",\r\n"); } sb.append("")...