我有一个程序,通过单击 DataGridView 中的项目请求用户输入数据,并自动请求给定股票代码的新信息。当从 api 服务器收到数据时,它会排队,后台工作人员处理数据并通过文本框、图表和各种风险分析更新 UI。
我编写了一个更新序列来更新股票的热度、利润率和当前价格。这就是我的问题所在。我无法更改服务器的内容,并且响应仅包含一个请求 ID。
我尝试将请求 ID 存储到列表中,然后在列表中搜索以确定它是用户输入还是更新序列。通过这样做,我可以在我的一端添加一个标签来告诉应用程序将数据发送到哪里进行处理。然而,这给整个过程增加了 3-5 秒。
当发送请求数据时,这里是正在使用的代码:
private void QuoteRequest_Click(object sender, EventArgs e)
{
if (CheckSymbolValidity() == false)
return;
string[] symbols = new string[1];
symbols[0] = this.textBoxSymbol.Text.ToUpper();
short[] quoteFields = new short[4];
quoteFields[0] = (short)ActiveTickFeedLib.ATQuoteFieldEnum.ATQuoteFieldLastPrice;
int requestId = ActiveTickFeed.feed.SendQuoteDbRequest(symbols, quoteFields);
Stored_ID(requestId+",[UI]");
}
然后对于更新序列,它使用相同的代码,除了 symbol[0]= sender.ToString();和 Stored_ID(requestID+",[UP]");从而更改应用程序的存储标签。
Queue worker 抓取 Response 数据,匹配请求 id 获取 Tag。 然后从该标记中获取要使用的存储方法,例如:
string[] split = data.Split(new string[] {","}, stringsplitoptions.None);
if(split[1] == "[UI]")
{
UI_Data(Res_Data); // method for using the data within the UI
}
//method for the update methods
if(split[1] == "[UP]")
{
UP_Data(Res_Data);
}
所有这一切都是为了让工作人员知道如何处理数据。更新序列被触发 3 次后,开始需要 15-30 秒,UI 数据才会显示在 UI 上。这是工作人员完成工作后从存储列表中删除的 requestID。
每次触发更新序列时,它都会在 15 秒内收到 8,000 个响应。
我的问题是,有没有更好的方法来做到这一点?我可以使用后台线程运行仅更新计时器序列的重复修改版本吗?
任何建议都会有帮助!!我已经尝试了 4 种不同的方法,从只存储 UI 请求,然后如果不在列表中自动更新方法。
所有 Update 方法所做的就是更新 UI 使用的数据库。然后,UI 每 5 分钟加载一次新数据库。
提前致谢!
最佳答案
如此多的响应可能是迭代编码风格与基于集合的编码风格的表现。如果涉及 Linq2SQL 或 EF,我会四处检查以确保使用预加载(或强制使用 .ToList() 或 .AsEnumerable() 进行早期评估,同时避免使用 .AsQueryable())。
关于C# Winforms .NET 框架数据处理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47996530/
作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack
是的,我知道最好使用webmock,但我想知道如何在RSpec中模拟此方法:defmethod_to_testurl=URI.parseurireq=Net::HTTP::Post.newurl.pathres=Net::HTTP.start(url.host,url.port)do|http|http.requestreq,foo:1endresend这是RSpec:let(:uri){'http://example.com'}specify'HTTPcall'dohttp=mock:httpNet::HTTP.stub!(:start).and_yieldhttphttp.shou
有时我需要处理键/值数据。我不喜欢使用数组,因为它们在大小上没有限制(很容易不小心添加超过2个项目,而且您最终需要稍后验证大小)。此外,0和1的索引变成了魔数(MagicNumber),并且在传达含义方面做得很差(“当我说0时,我的意思是head...”)。散列也不合适,因为可能会不小心添加额外的条目。我写了下面的类来解决这个问题:classPairattr_accessor:head,:taildefinitialize(h,t)@head,@tail=h,tendend它工作得很好并且解决了问题,但我很想知道:Ruby标准库是否已经带有这样一个类? 最佳
我目前正在使用以下方法获取页面的源代码:Net::HTTP.get(URI.parse(page.url))我还想获取HTTP状态,而无需发出第二个请求。有没有办法用另一种方法做到这一点?我一直在查看文档,但似乎找不到我要找的东西。 最佳答案 在我看来,除非您需要一些真正的低级访问或控制,否则最好使用Ruby的内置Open::URI模块:require'open-uri'io=open('http://www.example.org/')#=>#body=io.read[0,50]#=>"["200","OK"]io.base_ur
我正在尝试使用Curbgem执行以下POST以解析云curl-XPOST\-H"X-Parse-Application-Id:PARSE_APP_ID"\-H"X-Parse-REST-API-Key:PARSE_API_KEY"\-H"Content-Type:image/jpeg"\--data-binary'@myPicture.jpg'\https://api.parse.com/1/files/pic.jpg用这个:curl=Curl::Easy.new("https://api.parse.com/1/files/lion.jpg")curl.multipart_form_
无论您是想搭建桌面端、WEB端或者移动端APP应用,HOOPSPlatform组件都可以为您提供弹性的3D集成架构,同时,由工业领域3D技术专家组成的HOOPS技术团队也能为您提供技术支持服务。如果您的客户期望有一种在多个平台(桌面/WEB/APP,而且某些客户端是“瘦”客户端)快速、方便地将数据接入到3D应用系统的解决方案,并且当访问数据时,在各个平台上的性能和用户体验保持一致,HOOPSPlatform将帮助您完成。利用HOOPSPlatform,您可以开发在任何环境下的3D基础应用架构。HOOPSPlatform可以帮您打造3D创新型产品,HOOPSSDK包含的技术有:快速且准确的CAD
本教程将在Unity3D中混合Optitrack与数据手套的数据流,在人体运动的基础上,添加双手手指部分的运动。双手手背的角度仍由Optitrack提供,数据手套提供双手手指的角度。 01 客户端软件分别安装MotiveBody与MotionVenus并校准人体与数据手套。MotiveBodyMotionVenus数据手套使用、校准流程参照:https://gitee.com/foheart_1/foheart-h1-data-summary.git02 数据转发打开MotiveBody软件的Streaming,开始向Unity3D广播数据;MotionVenus中设置->选项选择Unit
文章目录一、概述简介原理模块二、配置Mysql使用版本环境要求1.操作系统2.mysql要求三、配置canal-server离线下载在线下载上传解压修改配置单机配置集群配置分库分表配置1.修改全局配置2.实例配置垂直分库水平分库3.修改group-instance.xml4.启动监听四、配置canal-adapter1修改启动配置2配置映射文件3启动ES数据同步查询所有订阅同步数据同步开关启动4.验证五、配置canal-admin一、概述简介canal是Alibaba旗下的一款开源项目,Java开发。基于数据库增量日志解析,提供增量数据订阅&消费。Git地址:https://github.co