亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

防止到String類的不恰當的類型轉換

2019-11-18 11:13:56
字體:
來源:轉載
供稿:網友

  作者:Fernando Ribeiro
  
  充分利用 java 語言多態性
  
  級別:中級
  
  在 Java 編程中,將對象轉換為字符串(或字符串化)可能引起問題,除非您記住在純粹的面向對象應用程序中很少使用字符串表示法。在本文中,系統分析員兼程序員 Fernando Ribeiro 以 Eric Allen 的錯誤模式概念為基礎建立了其觀點,并說明了錯誤的字符串化是如何成為錯誤模式的;他討論了對這種難以捉摸的缺陷的診斷并解釋了類型安全的好處。
  字符串化是從對象到字符串的轉換,而對于本文,錯誤的字符串化是指對 String 類的不恰當的類型轉換。例如,本文中的示例將向您展示產品代碼很少是字符串,但許多開發人員會將其類型轉換為 String 類,因而將危及面向對象編程中的多態性的廣泛用途。
  
  盡管看起來只是樣式問題(因為錯誤字符串化“錯誤模式”的一個隱蔽屬性就是:它在任何時候(即使是測試時)都不引起任何錯誤),但避免對 String 類進行不恰當的類型轉換可以使您充分利用 Java 語言內在的多態性特性。在實踐方面,避免這種模式是防止它的最佳方法,而避免它的最佳方法是為您代碼中的大多數元素定義一個特定的類型。通過這樣做,您確保了每個類的類型適合于其任務,從而確保了系統的可靠性。這個解決方案會對您的系統性能增加一些開銷,但換來的是一個可靠得多的系統。
  
  在本文中,我們將在企業系統環境中討論這個模式,并且將研究一種檢測這種錯誤的方法:方法的錯誤重載。(我們不會在本文中過多地討論修改錯誤,因為,簡單地避免使用字符串表示是解決該問題最佳和最常見的方法。)
  
  聚焦 String 不恰當的類型轉換
  我喜歡和研究錯誤模式一樣來研究不恰當地將類型轉換為 String 類這一問題。因此,讓我們將這種問題稱為錯誤字符串化錯誤模式。(有關錯誤模式的更多信息,請參閱參考資料中 Eric Allen 的診斷 Java 代碼專欄文章。)
  
  幾個定義
  對于不熟悉本文中使用的所有術語的讀者,這些定義應該有助于您跟上進度:
  UML(統一建模語言):通過制定計劃或“藍圖”來簡化軟件設計過程,以此來明確說明、可視化、構造和文檔化軟件系統構件的語言。
  
  OCL(對象約束語言):統一建模語言(UML)的表達語言;它具有純表達語言(不能更改模型中的任何東西)、建模語言(所有實現問題均超出范圍并無法表達)和形式語言(所有構造都有形式定義的意義)的特征。
  
  類型安全的、類型安全:指定類型的 UML 模型元素(如字段或操作),其結構和行為最貼切地符合元素規范。
  
  字符串化:將對象轉換成字符串。
  
  多態性:在面向對象編程中,編程語言根據對象的類型以不同方式處理它們的能力。
  
  方法重載:在面向對象應用程序中重新定義派生類的方法的能力,其中方法名稱保持相同,但參數的類型更改了。
  
  在我們繼續討論之前,請答應我迅速討論一下類型安全的概念。當 UML 模型元素是類型安全的時,其結構和行為貼切地與其規范相匹配,或者換句話說,它是明確地為其用途開發的。有助于您理解的示例是:搜索索引列表的操作的“鍵”參數不是一個字符串,而只是一個對象,類似于其它 Java 對象,可以通過調用 toString() : String 方法將它字符串化。差異在于字符串可以求子字符串、連接等;但鍵不能。它們是鍵,不是字符串。
  
  在類型安全的應用程序中,color 字段的類型、getColor(): String 方法的返回類型和 setColor(color : String) : void 方法的 color 參數的類型都是 Color 而不是 String ― 它返回車輛的顏色而不是其字符串表示。清單 1 提供了示例。
  
  在本文的代碼示例中,我們將使用一個假想的企業系統,該系統包括汽車工業產品的運輸和跟蹤功能。我們將為這個系統定義類,包括 Vehicle 類(當我們討論單個車輛細節時使用)和更普通的 PRodUCt 類(作為一般企業產品目錄的示例)。
  
  清單 1. 錯誤字符串化的車輛
  /**
  * The vehicle
  **/
  public class Vehicle {
  
   /**
   * Construct a vehicle
   **/
   public Vehicle() {
   }
  
   /**
   * The color of a vehicle
   **/
   private String color;
  
   /**
   * Get the color of a vehicle
   * @return The color of a vehicle
   **/
   public String getColor() {
   return this.color;
   }
  
   /**
   * Set the color of a vehicle
   * @param color A color
   **/
   public void setColor(String color) {
   this.color = color;
   }
  
  }
  
  這種錯誤模式出現在許多企業系統(包括產品目錄)中。研究下列代碼以獲得示例(這個示例也定義了 Product 類):
  
  清單 2. 錯誤字符串化的產品
  /**
  * The product
  **/
  public class Product {
  
   /**
   * Construct a product
   **/
   public Product() {
   }
  
   /**
   * Construct a product
   * @param code A code
   **/
   public Product(String code) {
   this.setCode(code);
   }
  
   /**
   * The code of a product
   **/
   private String code;
  
   public boolean equals(Object b) {
   if (!(b instanceof Product))
   return false;
   return this.getCode().equals(((Product)b).getCode());
   }
  
   protected void finalize() {
   this.setCode(null);
   }
  
   /**
   * Get the code of a product
   * @return The code of a product
   **/
   public String getCode() {
   return this.code;
   }
  
   public int hashCode() {
   String code = this.getCode(); // defensively copies
   if (code == null)
   return 0;
   return code.hashCode();
   }
  
   /**
   * Set the code of a product
   * @param code A code
   **/
   public void setCode(String code) {
   this.code = code;
   }
  
   public String toString() {
   return new String();
   }
  
  }
  
  
  關于上述代碼中 Product 類設計的幾點注釋:
  
  第一個構造函數是空的并且不獲取任何參數。
  第二個構造函數獲取一段代碼。
  這些代碼組成(屬于)產品。
  產品的字符串表示是空字符串。
  產品按其代碼來比較是否相等。
  產品的散列碼是其代碼的散列碼。
  讓我們研究一下用于最后兩項的一些代碼示例。
  
  產品按其代碼來比較是否相等
  以下是說明這一點的 OCL 約束:
  
  
  context Product::equals(b : Object) : boolean
   pre: b.oclISKINdOf(Product);
   post: result = self.getCode().equals(b.oclAsType(Product).getCode());
  
  
  產品及其代碼的散列碼相同
  以下是說明這一點的 OCL 約束:
  
  context Product::hashCode() : int post:
   let code : String = self.getCode() in
   if code.oclIsUndefined() then
   result = 0;
   else
   result = code.hashCode();
   end if
  
  
  以下是發生錯誤字符串化錯誤模式能夠削弱您產生良好代碼的能力的原因 ― 產品代碼不是字符串,因為它所需要的結構和行為可能超出 String 類所答應的范圍。
  
 ?。ū疚闹?OCL 約束是基于 OCL 2.0 建議的 ― 例如,在 OCL 1.4 中不存在“oclIsNew”。有關 OCL 的更多信息,請參閱參考資料。)
  
  產品代碼還可能需要專門化(如銷售或工程產品代碼)。并且某些產品可能被多次編碼 ― 工程代碼可能被用于后勤系統;后勤代碼可能被用于銷售系統;工程、后勤和銷售代碼都可能被用于電子商務系統。產品代碼的用法需求有幾分象指揮開發人員的紅旗,把他們引向為每種產品代碼開發新的特定類型的方法。
  
  那么為什么會發生這種問題呢?而我們又應該如何修正或避免它?
  
  問題和一些解決方案
  問題之所以會發生,是因為大多數程序員沒有在面向對象應用程序中利用類型安全。(請記住,我們認為值得另外花一些力氣去定義一個特定于需求的新類型而不是依靠現有的類型,因為現有類型可能不夠匹配并可能引起問題。)下列車輛問題嘗到了類型安全應用程序的甜頭,其中車輛(轎車和卡車)是由不同的船運輸的。請研究下列代碼:
  
  /**
  * Deliver a vehicle
  * @param vehicle A vehicle
  **/
  public void deliver(String vehicle) {
   // is it a car or a truck?
  }
  
  deliver(vehicle : String) : void 方法實現了字符串的傳遞(令人沮喪但事實如此)而不是車輛的傳遞,因為任何字符串都可以指定給 vehicle 參數。這實際上不是該問題的

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品精品久久久久久| 欧美成人免费一级人片100| 91麻豆国产精品| 日韩在线www| 亚洲国产精品久久久久秋霞蜜臀| 成人网页在线免费观看| 亚洲国产另类久久精品| 中文字幕日韩精品在线观看| 亚洲人成网站色ww在线| 97国产在线视频| 精品女同一区二区三区在线播放| 国产精品18久久久久久首页狼| 中文字幕亚洲一区二区三区| 91欧美日韩一区| 亚洲第一在线视频| 日韩美女在线观看一区| 亚洲午夜av久久乱码| 国产视频精品一区二区三区| 青青草99啪国产免费| 日本一区二区在线播放| 欧美激情2020午夜免费观看| 亚洲综合中文字幕在线| 国产欧美一区二区三区视频| 亚洲人成电影网站色…| 日韩精品电影网| 日韩免费在线观看视频| 欧美一级淫片videoshd| 国产午夜精品全部视频在线播放| 亚洲精品久久久久久下一站| 日韩av在线影院| 2019国产精品自在线拍国产不卡| 中文字幕视频一区二区在线有码| 欧美日韩在线视频首页| 欧美日韩国产精品| 91精品成人久久| 欧美日韩综合视频网址| 91久久久久久久久久| 国产精品久久久久久久久粉嫩av| 国产欧美在线看| 欧美洲成人男女午夜视频| 永久免费毛片在线播放不卡| 成人av电影天堂| 69av在线视频| 91精品啪在线观看麻豆免费| 欧美激情欧美激情在线五月| 精品亚洲男同gayvideo网站| 在线视频国产日韩| 亚洲日韩中文字幕在线播放| 亚洲女人被黑人巨大进入al| 精品久久香蕉国产线看观看gif| 国产一区二区三区视频在线观看| 国产精品久久av| 国产精品一二三在线| 国产欧美久久久久久| 国产精品永久免费在线| 伦伦影院午夜日韩欧美限制| 亚洲a成v人在线观看| 日本道色综合久久影院| 亚洲色图欧美制服丝袜另类第一页| 久久天天躁狠狠躁夜夜躁| 久精品免费视频| 久久不射热爱视频精品| 欧美极品美女视频网站在线观看免费| 日韩极品精品视频免费观看| 最新中文字幕亚洲| 亚洲自拍高清视频网站| 日韩久久免费视频| 日韩av在线看| 超碰91人人草人人干| 日韩欧美一区二区三区| 色综合久久中文字幕综合网小说| 日本中文字幕久久看| 色视频www在线播放国产成人| 日韩欧美国产激情| 色综合久久天天综线观看| 久久久久久久久国产精品| 黄色91在线观看| 一区二区三区精品99久久| 一本色道久久综合狠狠躁篇怎么玩| 97视频免费在线观看| 亚洲欧美日韩成人| 亚洲视频在线播放| 国产精品无码专区在线观看| 97免费视频在线播放| 亚洲www在线观看| 92裸体在线视频网站| 久久久之久亚州精品露出| 欧美日韩国产激情| 国产精品观看在线亚洲人成网| 在线观看91久久久久久| 欧美俄罗斯乱妇| 亚洲香蕉av在线一区二区三区| 亚洲美女视频网| 一本久久综合亚洲鲁鲁| 91日本视频在线| 日本一区二区在线免费播放| 欧美日韩国产成人在线| 日韩成人高清在线| 国产精品影院在线观看| 亚洲欧美综合另类中字| 亚洲精品永久免费精品| 中文字幕久久亚洲| 97精品国产aⅴ7777| 欧美日韩人人澡狠狠躁视频| 日韩在线国产精品| 成人午夜两性视频| 久久精品国产成人精品| 国产在线精品自拍| 久久久久亚洲精品成人网小说| 欧美大人香蕉在线| 欧美精品生活片| 亚洲国产精品电影在线观看| 亚洲精品一区av在线播放| 欧洲午夜精品久久久| 91精品免费看| 人人爽久久涩噜噜噜网站| 精品成人国产在线观看男人呻吟| 国产精品久久久久久久久久尿| 91久久国产精品| 久久精品视频在线| 97婷婷大伊香蕉精品视频| 亚洲高清久久网| 日韩va亚洲va欧洲va国产| 日韩亚洲第一页| 色偷偷噜噜噜亚洲男人| 伊人久久久久久久久久久| 中文字幕九色91在线| 精品一区精品二区| 国产97人人超碰caoprom| 欧美一级淫片丝袜脚交| 一夜七次郎国产精品亚洲| 亚洲成人亚洲激情| 韩国三级电影久久久久久| 国产精品69久久| 日本亚洲精品在线观看| 欧美黑人极品猛少妇色xxxxx| 亚洲区一区二区| 欧美精品中文字幕一区| 这里只有精品在线观看| 久久国产精品久久国产精品| 色小说视频一区| 日本精品一区二区三区在线播放视频| 九九久久国产精品| 亚洲欧美日韩一区二区在线| 国产精品日日摸夜夜添夜夜av| 久久九九免费视频| 91中文精品字幕在线视频| 亚洲性视频网站| 最近2019中文字幕第三页视频| 一本大道香蕉久在线播放29| 精品久久久一区二区| 国产午夜精品视频免费不卡69堂| 92福利视频午夜1000合集在线观看| 亚洲爱爱爱爱爱| 久久久精品网站| 欧美一级成年大片在线观看| 亚洲综合色激情五月| 91精品国产高清| 欧美高清视频免费观看| 亚洲欧洲第一视频| 91免费福利视频| 国产成人精品一区| 欧美自拍大量在线观看| 午夜精品99久久免费|