我想通過使用線程來優化性能。我們可以在循環中使用異步方法調用
public delegate int DelegateGetMarkOfSubject(int subjectid, int studentid);
int TotalMark = 0;
public void GetTotalMark(int StudentId)
{
TotalMark = 0;
List<Subjects> lstSubj = GetSubjectList(StudentId);
Waithandle[] waitHandler = new waitHandler[10];
DelegateGetMarkOfSubject delmarkOfSubj = new DelegateGetMarkOfSubject(GetMark);
foreach(var subject in lstSubj)
{
IAsync result_subject.id = delmarkOfSubj.BeginInvoke(subject.id, StudentId, new AsyncCallBack(GetMarkComplete), null);
waitHandler.add(result_subject.id.AsyncHandle);
}
WaitHandle.WaitAll(waitHandler);
return TotalMark;
}
GetMarkComplete(Iasynch argument)
{
DelegateGetMarkOfSubject del = (DelegateGetMarkOfSubject)((Asynchresult ar)).AsynDelegate;
newMark = del.EndInvoke(argument)
if(LockingCondition)
{
//PutLock
TotalMark += newMark;
//Release Lock
}
}
我無法看到問題。 – robrich
http://codereview.stackexchange.com/ –
聽起來像一個完美的適合.NET 5 ...等待()! –