Is it possible to simplify the below condition using the null-coalescing operator or any other simplified code?
int? c,a,b;
if(a!=null)
{
c = a;
}
else if(b!=null)
{
c = b;
}
else
{
c = null;
}
Thanks in Advance
You mean something like:
int? c = a ?? (b ?? null)
Note that according to your if-else statement, c has to be int? type. For the same reason, it makes sense both a and b are of int? type.
Hence, as b may be null, the same expression can be rewritten as:
int? c = a ?? b;
c = a ?? b ?? null;
Although if your catch is null anyways then you only really need
c = a ?? b;
Edit: As other users have stated it's important that your int is nullable (int?) if you're working with them.
Assuming that they are all of Type int?
int? c = a ?? b; //no need for an explicit null. If b is null so will c be.
because the question doesn't make sense if they are of Type int.
Related
Is this possible in one line of code ? null : yourHelpfulAnswer
Thank you in advance.
var x = await Foo_Get() == null ? 123: Foo.SomeProperty;
Just seems like there is a much better way than:
var myVal = 123;
var foo = await Foo_Get();
if(foo != null) myVal = foo.SomeProperty;
That should do the trick:
var myVal = (await Foo_Get())?.SomeProperty ?? 123;
Simplified:
? = if value on left is null use null, otherwise use property
?? = if value on the left is null use the value on the right instead.
You can use the null coalescing operator to set myVal:
var myVal = (await Foo_Get())?.SomeProperty ?? 123;
I have a following GroupBy query:
var groups = ordered.GroupBy(k => new
{
a = k[SelectedFirstCategory],
b = k[SelectedSecondCategory],
c = k[SelectedThirdCategory]
});
The problem is that Categories can be null.
How can I modify my GroupBy to accomodate for this. I know I could go with multiple "if" but that is not elegant for me.
To make this clearer an example would be that if SelectedSecondCategory is null but other are filled than resulting grouping should be according to "a" and "c" property.
I thought about null coalescent like this:
a = SelectedFirstCategory != null ? k[SelectedFirstCategory] : DON'T KNOW WHAT TU PUT HERE.
Alternative value should be something that would be irrelevant to groupBy.
Thanks in advance.
I appears to be quite easy:
var groups = ordered.GroupBy(k => new {
a = !String.IsNullOrEmpty(SelectedFirstCategory) ? k[SelectedFirstCategory] : null,
b = !String.IsNullOrEmpty(SelectedSecondCategory) ? k[SelectedSecondCategory] : null,
c = !String.IsNullOrEmpty(SelectedThirdCategory) ? k[SelectedThirdCategory] : null
});
It appears that if some parameter of grouping is null it is not taken into consideration when creating a group so that is what I wanted.
Use a helper method, Just be aware that you grouping may not make any sense. Suppose you had you columns being "Fruit", "Color", "Shape". Grouping ["Apple", "Red", "Round"] with ["Banana", "Oval"] doesn't give good results.
static void Main(string[] args)
{
List<List<object>> ordered = new List<List<object>>();
int SelectedFirstCategory = 1;
int SelectedSecondCategory = 2;
int SelectedThirdCategory = 3;
var groups = ordered.GroupBy(k => MyGroup(
k[SelectedFirstCategory],
k[SelectedSecondCategory],
k[SelectedThirdCategory])
);
}
static List<object> MyGroup(object a, object b, object c)
{
List<object> results = new List<object>();
if (a != null) results.Add(a);
if (b != null) results.Add(b);
if (c != null) results.Add(c);
return results;
}
I'm creating some objects to return to a form via API, and the objects are derived from database values, including values that could be null in the database, but cannot be null in the context of my API (I am obtaining data from multiple tables, so I know that if a field is null in one table, I can obtain a legitimate value from another table):
List<ResultsByLineShiftSlot> returnResults = new List<ResultsByLineShiftSlot>();
foreach (LineShiftSlot ls in db.LineShiftSlots.OrderBy(ls => ls.ScheduledDateAndTime).Where(ls => ls.ProductionDate == slotDate &&
ls.ShiftId == shiftId &&
ls.LineId == lineId &&
ls.Quantity > 0 &&
ls.BlendId != null))
{
var recordedResult = db.LineShiftSlotResults.FirstOrDefault(r => r.LineShiftSlotId == ls.Id);
if (recordedResult != null)
{
ResultsByLineShiftSlot returnResult = new ResultsByLineShiftSlot
{
BlendId = recordedResult.BlendId
};
}
else
{
ResultsByLineShiftSlot returnResult = new ResultsByLineShiftSlot
{
BlendId = ls.BlendId ?? 0
};
}
}
return returnResults;
In the above example, BlendId can be null in LineShiftSlots, but not in LineShiftSlotResults.
In this context where a nullable variable is known to contain a non-null value, which is better?
Should I use the null coalescing operator:
BlendId = ls.BlendId ?? 0
Or should I use .Value():
BlendId = ls.BlendId.value()
Both compile, and seem to work.
Are they functionally equivalent in this context? Is using one over the other better practice? I know that .value() could potentially return an exception, whereas the null coalescing operator could not, but in this case .value can never be null.
In the general case, they're not semantically equivalent.
labelId = recordValue.labelId.Value;
This one means I know the value can't be null. Just throw if my assumption is wrong.
On the other hand,
labelId = recordValue.labelId ?? 0;
labelId = recordValue.labelId.GetValueOrDefault();
These two mean that the value may be null, and if that happens, just ignore it, considering it's normal, and substitute it with the default value.
I'd use GetValueOrDefault() in that case, it makes it somewhat more obvious (and the JIT will inline this method).
However, your code is equivalent to this simpler alternative:
labelId = recordValue.labelId ?? otherValue;
In this case the code would be the same however have you considered the following
labelId = recordValue.labelId ?? otherValue
which is essentially the following
if(recordValue.labelId != null){
labelId = recordValue.labelId.Value;
}
else
{
labelId = otherValue;
}
Hi I have some code here which I dont understand
public ObservableCollection<Packet> Items
{
get
{
this.items = this.items ?? this.LoadItems();
return this.items;
}
}
What does the ?? means?
?? is the null-coalescing operator. The value on the left is returned as long as it is not null. If it is null, then the value on the right is returned.
a = b ?? c;
Is equivalent to:
if (b != null)
a = b;
else
a = c;
That is the null coalescing operator.
It says; assign items to items unless items is null, in which case, call LoadItems and assign the result. It is shorthand for
if( this.items == null )
this.items = this.LoadItems();
return this.items;
The ?? operator returns the left-hand operand if it is not null, or else it returns the right operand.
Reference.
It's called the "null-coalescing operator", and is documented at http://msdn.microsoft.com/en-us/library/ms173224.aspx.
This question already has answers here:
Closed 12 years ago.
Possible Duplicate:
What do two question marks together mean in C#?
Hi, I was looking for some trainings of MVC 2 in C# and I found this sintax:
ViewData["something"] = something ?? true;
So, what is that '??' means ?.
It's the null-coalescing operator.
It returns the first argument unless it is null, in which case it returns the second.
x ?? y is roughly equivalent to this (except that the first argument is only evaluated once):
if (x == null)
{
result = y;
}
else
{
result = x;
}
Or alternatively:
(x == null) ? y : x
It is useful for providing a default value for when a value can be null:
Color color = user.FavouriteColor ?? defaultColor;
COALESCE
When used in a LINQ to SQL query the ?? operator can be translated to a call to COALESCE. For example this LINQ query:
var query = dataContext.Table1.Select(x => x.Col1 ?? "default");
can result in this SQL query:
SELECT COALESCE([t0].[col1],#p0) AS [value]
FROM [dbo].[table1] AS [t0]
It is the null coalescing operator. The return value is the left hand side if it is non-null and the right hand side otherwise. It works for both reference types and nullables
var x = "foo" ?? "bar"; // "foo" wins
string y = null;
var z = y ?? "bar"; // "bar" wins
int? n = null;
var t = n ?? 5; // 5 wins
If something is null, it returns true, otherwise it returns something.
See this link for more.