ads = ads.Where(x => (x.Amount - x.Price) / (x.Amount / 100) >= filter.Persent);
if x.Amount == 0 I have error "Divide by zero error encountered."
like me in this request is to avoid?
update:
this helped, but I do not like the decision:
ads = ads.Where(x => (x.Amount - x.Price) / ((x.Amount / 100)==0?0.1:(x.Amount / 100)) >= filter.Persent);
there is another way?
Of course, you can always implement a generic safe division method and use it all the way
using System;
namespace Stackoverflow
{
static public class NumericExtensions
{
static public decimal SafeDivision(this decimal Numerator, decimal Denominator)
{
return (Denominator == 0) ? 0 : Numerator / Denominator;
}
}
}
I have chosen decimal type because it addresses all non nullable numeric types that I am aware of.
Usage:
var Numerator = 100;
var Denominator = 0;
var SampleResult1 = NumericExtensions.SafeDivision(Numerator , Denominator );
var SampleResult2 = Numerator.SafeDivision(Denominator);
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With