2009-04-10 9 views
17

Ogni programmatore termina con un set di classi di utilità dopo un po '. Alcuni di questi sono vere perle di programmazione e vengono riutilizzati in molti dei tuoi progetti. Ad esempio, in Java:Qual è la tua classe più riusata?

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; 
      } 
     } 
    } 

e:

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(); 
    } 
} 

Qual è il tuo classe più riutilizzati?

+2

Effettuare questo wiki della comunità, per favore. Altrimenti, rischi la chiusura. – Randolpho

+2

Non potresti semplicemente usare StringUtils # join dal common-lang di Apache? –

+0

che è solo un esempio di possibile classe di utilità "homegrow" – dfa

risposta

4

una classe di utilità che ha funzionalità di registrazione e-mail. Una classe di estensioni che contiene metodi di estensione. Una classe di segnalazione che, in fondo sfruttare il servizio di servizi di web reporting e rende facile streaming rapporti come Excel, PDF, ecc

Esempi ...
1.) Utility Class (statico)

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.) estensioni Classe

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

classe Logger: che registra il flusso di controllo in un file di log.

1

Configurazione Lettore/Setter: che legge la configurazione dal file ini/xml e imposta l'ambiente dell'applicazione

1

La maggior parte riutilizzati? Hmmm ...

boost :: shared_ptr <> con boost :: weak_ptr <>

probabilmente la maggior parte riutilizzati (anche probabilmente la maggior parte bang-per-dollaro ratio)

1

Globali

Solo un classe semplice con DBConnString statico e alcune altre impostazioni dell'applicazione.

riutilizzato il semplice file in circa 2 dozzina di progetti in quanto si lavora con .Net

3

La maggior parte riutilizzati ma noioso:

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

    throw new RuntimeException(e); //NOPMD 
} 

meno noioso (anche i metodi per gli elenchi di costruzione e set):

/** 
    * 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

Si dovrebbe rinominarlo doNotHandleException (...) :) –

+0

O semplicemente usare Guava Throwables – takacsot

1

Un ConcurrentDictionary che ho scritto, che ora mi sembra di usare ovunque (I scrivere un sacco di programmi paralleli)

+0

E dov'è? – nawfal

+1

È qui: http://concurrent.codeplex.com/ Ho scritto che un * molto * molto tempo fa e non ho idea di quanto sia bello. – 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

Peccato che questo sia bacato. http://www.dataip.co.uk/Reference/LeapYear.php I tuoi algoritmi restituiranno 29 per 1900, quando dovrebbe essere 28. Perché non usare il tempo di Joda o qualcosa del genere? – I82Much

Problemi correlati