2009-04-10 14 views
17

Jeder Programmierer endet nach einiger Zeit mit einer Reihe von Utility-Klassen. Einige von ihnen sind echte Programmierperlen und werden in mehreren Ihrer Projekte wiederverwendet. Zum Beispiel in Java:Was ist Ihre am meisten wiederverwendet Klasse?

class Separator { 

     private String separator; 
     private boolean called; 

     public Separator(String aSeparator) { 
      separator = aSeparator; 
      called = false; 
     } 

     @Override 
     public String toString() { 
      if (!called) { 
       called = true; 
       return ""; 
      } else { 
       return separator; 
      } 
     } 
    } 

und:

public class JoinHelper { 

    public static <T> String join(T... elements) { 
     return joinArray(" ", elements); 
    } 

    public static <T> String join(String separator, T... elements) { 
     return joinArray(separator, elements); 
    } 

    private static <T> String joinArray(String sep, T[] elements) { 
     StringBuilder stringBuilder = new StringBuilder(); 
     Separator separator = new Separator(sep); 

     for (T element : elements) { 
      stringBuilder.append(separator).append(element); 
     } 

     return stringBuilder.toString(); 
    } 
} 

Was ist Ihre meisten wiederverwendet Klasse?

+2

Fabrikat Dieses Community-Wiki bitte. Andernfalls riskieren Sie den Abschluss. – Randolpho

+2

Könnten Sie nicht einfach StringUtils # Join aus Apaches commons-lang verwenden? –

+0

das ist nur ein Beispiel für mögliche "homegrow" Dienstprogramm Klasse – dfa

Antwort

4

Eine Utility-Klasse, die Protokollierung und E-Mail-Funktionalität. Eine Erweiterungsklasse, die Erweiterungsmethoden enthält. Eine Berichts-Klasse, die im Grunde den Reporting Services Web-Service nutzen und macht es einfach, usw. Berichte als Excel, pdf, streamen

Beispielen ...
1.) Utility-Klasse (statisch)

public static void LogError(Exception ex) 
    { 
     EventLog log = new EventLog(); 
     if (ex != null) 
     { 
      log.Source = ConfigurationManager.AppSettings["EventLog"].ToString(); 
      StringBuilder sErrorMessage = new StringBuilder(); 
      if (HttpContext.Current.Request != null && HttpContext.Current.Request.Url != null) 
      { 
       sErrorMessage.Append(HttpContext.Current.Request.Url.ToString() + System.Environment.NewLine); 
      } 
      sErrorMessage.Append(ex.ToString()); 
      log.WriteEntry(sErrorMessage.ToString(), EventLogEntryType.Error); 
     } 
    } 

2.) Extensions Klasse

public static IEnumerable<TSource> WhereIf<TSource>(this IEnumerable<TSource> source, bool condition, Func<TSource, bool> predicate) 
    { 
     if (condition) 
      return source.Where(predicate); 
     else 
      return source; 
    } 
1

Logger-Klasse: Die protokolliert den Steuerungsfluss in einer Protokolldatei.

1

Configuration Reader/Setter: die die Konfiguration von ini/XML-Datei liest und stellt die Umgebung der Anwendung

1

meisten wiederverwendet? Hmmm ...

boost :: shared_ptr <> mit boost :: weak_ptr <>

wohl wiederverwendet (wahrscheinlich auch die meisten Knall-für-Dollar-Verhältnis)

1

Globals

Nur einfache Klasse mit statischem DBConnString und einigen anderen App-weiten Einstellungen.

Haben seit der Arbeit mit .Net

die einfachen Datei in etwa 2 Dutzend Projekten wiederverwendet
3

Die meisten wiederverwendet, aber langweilig:

public static void handleException(Exception e) throws RuntimeException { 
    if (e instanceof RuntimeException) { 
     throw (RuntimeException) e; 
    } 

    throw new RuntimeException(e); //NOPMD 
} 

Weniger langweilig (auch Methoden für Gebäude-Listen und Sets):

/** 
    * Builds a Map that is based on the Bean List. 
    * 
    * @param items Bean List items 
    * @param keyField Bean Field that will be key of Map elements (not null) 
    * @return a Map that is based on the Bean List 
    */ 
    @SuppressWarnings("unchecked") 
    public static <T, K> Map<K, T> buildMapFromCollection(final Collection<T> items, 
                 boolean linkedMap, 
                 final String keyField, 
                 final Class<K> keyType) { 
    if (items == null) { 
     return Collections.emptyMap(); 
    } 

    if (keyField == null) { 
     throw new IllegalArgumentException("KeyField is null"); 
    } 

    final Map<K, T> result; 

    if (linkedMap) { 
     result = new LinkedHashMap<K, T>(); 
    } else { 
     result = new HashMap<K, T>(); 
    } 

    BeanMapper mapper = null; 
    for (final T item : items) { 
     if (mapper == null) { 
     mapper = new BeanMapper(item.getClass()); 
     } 
     final K key = (K) mapper.getFieldValue(item, keyField); 
     result.put(key, item); 
    } 
    return result; 
    } 
+1

Sie sollten es umbenennen DoNotHandleException (...) :) –

+0

Oder verwenden Sie einfach Guava Throwables – takacsot

1

A ConcurrentDictionary Ich schrieb, die ich jetzt scheinen überall zu verwenden (Ich schreibe viele parallele Programme)

+0

Und wo ist es? – nawfal

+1

Es ist hier: http://concurrent.codeplex.com/ Ich schrieb das vor sehr langer Zeit und ich habe keine Ahnung, wie gut es ist. – Martin

3
public static short getLastDayOfMonth(short givenMonth, short givenYear) 
{ 
    short lastDay = 31; 
    switch (givenMonth) 
    { 
     case 4: 
     case 6: 
     case 9: 
     case 11: 
      lastDay = 30; 
      break; 
     case 2: 
      if ((int)givenYear % 4 == 0) 
      { 
       lastDay = 29; 
      } 
      else 
      { 
       lastDay = 28; 
      } 
      break;  
    } 
    return lastDay; 
} 
+5

Schade, das ist fehlerhaft. http://www.dataip.co.uk/Reference/LeapYear.php Ihre Algorithmen werden 29 für 1900 zurückgeben, wenn es 28 sein sollte. Warum nicht Joda Zeit oder etwas ähnliches verwenden? – I82Much

Verwandte Themen