我开发了一个从 CRM 2011 检索数据的 ASP.NET 页面。有几个调用,页面需要几秒钟才能加载。
我想我可能会使用一些并行性来加快速度。
这是代码:
Task[] tasks = new Task[4];
tasks[0] = Task.Run(() =>
{
RetrieveAttributeRequest retrieveFreightTerm = new RetrieveAttributeRequest { };
retrieveFreightTerm.EntityLogicalName = "account";
retrieveFreightTerm.LogicalName = "address1_freighttermscode";
retrieveFreightTerm.MetadataId = Guid.Empty;
retrieveFreightTerm.RetrieveAsIfPublished = true;
RetrieveAttributeResponse retrieveFrieghtTermResponse = (RetrieveAttributeResponse)Service.Execute(retrieveFreightTerm);
PicklistAttributeMetadata retrievedPicklistAttributeMetadata = (PicklistAttributeMetadata)retrieveFrieghtTermResponse.AttributeMetadata;
OptionMetadata[] optionlist = retrievedPicklistAttributeMetadata.OptionSet.Options.ToArray();
if (!IsPostBack)
foreach (OptionMetadata oMD in optionlist)
{
FreightTermDropDownList.Items.Add(new ListItem(oMD.Label.UserLocalizedLabel.Label, oMD.Value.ToString()));
}
});
在我使用的任务之后
Task.WaitAll();
我一直在调试代码并检索到数据,但下拉列表无论如何都是空的。
改变
Task.WaitAll();
至
tasks[0].Wait(2000);
tasks[1].Wait(2000);
tasks[2].Wait(2000);
tasks[3].Wait(2000);
使代码工作(我有 4 个任务)。这两个选项有什么区别?