c# - Fixing 'method group' issue for delegate -


inspired cleanest way write retry logic? made this

    public static t retry<t>(int numretries, int timeout, delegate method, params object[] args)     {         if (method == null)             throw new argumentnullexception("method");          var retval = default(t);                 {             try             {                 retval = (t) method.dynamicinvoke(args);                 return retval;             }             catch (timeoutexception)             {                 if (numretries <= 0)                     throw; // avoid silent failure                 thread.sleep(timeout);             }         } while (numretries-- > 0);          return retval;     } 

however i've run method group problem.

test setup

    private int add(int x, int y)     {         return x + y;     }      public static void main(string[] args)     {         var r = retry<int>(5, 10, add, 1, 1);     } 

is there no better way fix other retry<int>(5, 10, new func<int, int, int>(add), 1, 1);

you can change retry to

public static t retry<t>(int numretries, int timeout, func<t> method) {     if (method == null)         throw new argumentnullexception("method");      var retval = default(t);         {         try         {             retval = method();             return retval;         }         catch (timeoutexception)         {             if (numretries <= 0)                 throw; // avoid silent failure             thread.sleep(timeout);         }     } while (numretries-- > 0);      return retval; } 

and call as

var result = retry(5, 10, ()=>add(1,1)); 

Comments

Popular posts from this blog

c++ - Function signature as a function template parameter -

algorithm - What are some ways to combine a number of (potentially incompatible) sorted sub-sets of a total set into a (partial) ordering of the total set? -

How to call a javascript function after the page loads with a chrome extension? -