0

我正在使用 DDE 客户端来附加和收听股票市场价格。该客户端有一个回调方法,我实现了当它收到价格变化时要做什么。问题是我得到 StackOverflowException (定期而不是在同一时间间隔)。我发现了一些关于 Thread.BeginCriticalRegion() 的信息,但我不确定它是否会有所帮助。距离市场开放还有几个小时我可以测试它。如果有人能给我一个如何覆盖这个异常的想法,我会非常感激。

提前致谢, 亚历山大

IList<SymbolObject> _symbols; //initialized when the app runs for the first time

void _ddeClient_Advise(object sender, DdeAdviseEventArgs args)
    {
        if (!IsReady)
            return;

        if (string.IsNullOrEmpty(args.Text))
        {
            _logMessages.LogMessagesAdd("advise dde symbol", string.Format("args.Text is empty or NULL for {0}", args.Item), true);
            return;
        }

        try
        {
            string[] argsArray = args.Text.Replace("\0", "").Replace('\0'.ToString(), "").Split(' '); // sometimes happens here

            var list = _symbols.Where(s => s.DDESymbol == args.Item).ToList();
            if (list.Count == 0)
                return;

            decimal? val = null;
            try
            {
                var stringParts = StringUtils.CleanProphitXUrl(argsArray[0]).Split('.');
                argsArray = null;

                if (stringParts.Length >= 2)
                    val = decimal.Parse(stringParts[0] + "." + (stringParts[1].Length > 2 ? stringParts[1].Substring(0, 2) : stringParts[1]));
                else
                    val = decimal.Parse(stringParts[0]);

                stringParts = null;
            }
            catch (Exception ex)
            {
                _logMessages.LogMessagesAdd("call Price Alerts application service", ex.Message, true);
                return;
            }

            foreach (var l in list)
            {
                if (_lastPrices[l.DDESymbol] == null)
                    continue;

                if (_lastPrices[l.DDESymbol].ToString() != val.ToString())
                {
                    try
                    {
                        _quotePublishingService.PublishQuote(l.DDESymbolId, l.Symbol, args.Item, val, WebSyncPublisherUrl,
                            PublishingChannel); // a call to wcf service
                    }
                    catch (Exception ex)
                    {
                        _logMessages.LogMessagesAdd("call the service", ex.Message, true); // save to sql db
                        return;
                    }

                    _lastPrices[l.DDESymbol] = val.ToString();
                }
            }
            list = null;
            val = null;
        }
        catch
        {
        }            
    }

 public static string CleanProphitXUrl(string value) // StringUtils.CleanProphitXUrl snippet
    {
        StringBuilder sb = new StringBuilder();
        sb.Append(value.Substring(0, value.LastIndexOf(".") + 1));

        try
        {
            value = value.Replace('\r'.ToString(), "").Replace('\t'.ToString(), "").Replace('\n'.ToString(), "");
            for (int i = sb.Length; i < value.Length; i++)
            {
                if (char.IsNumber(value[i]))
                    sb.Append(value[i]);
            }
        }
        catch
        {

        }

        return sb.ToString();
    }
4

1 回答 1

0

AStackOverflowException是由于进行了许多方法调用而导致的,这些调用通常是由意外递归引起的。根据对您发布的代码的粗略检查,我认为这不是罪魁祸首。问题可能出在其他地方。

于 2011-05-05T15:43:05.137 回答