gpt4 book ai didi

c++ - 如何为进度条保留数据

转载 作者:太空宇宙 更新时间:2023-11-04 13:47:35 25 4
gpt4 key购买 nike

我的程序从服务器下载文件并解析它。

对于下载文件,我有一个栏,但我想为解析制作栏。

解析需要大量时间和能量,所以我的解决方案不必使用大量能量。

few servers -> few files -> line in file

我有一次从服务器下载文件(大约 4-5 个文件),下载后就开始解析。

但是当服务器超过 1 台时,我的程序会从两台服务器下载文件,所以我有 2 倍多的文件。服务器上的文件名是相同的,但是当我下载文件时,我将这些文件的名称更改为“world”+“orginalfile.txt”

我想过这样的事情: map<int server,std::map<int file(<make it enum),{current line, max lines} >> (struktura)

因为在读取文件时,我想发出发送数据到窗口。当开始阅读时,我想发送 (file,lines_in_file,server)阅读时发送 (file,current_line,world)然后在读取此数据的窗口中将此数据推送到某个变量(如上例)并运行第二个函数来计算进度条。

servers[] -> files [] -> thread download -> thread reading (these threads start per file, so if servers are 2 and files 4 these threads start 8x) -> emit init signal (send file,lines_in_file,server_number) + emit (currentLineWhenReading,file,server) signal when reading line-per-line

那么如何让它成为最好的,获取大量数据并保存它+使用小功率来计算呢?

最佳答案

在单独的线程中解析。在解析时增加(使用互斥量)一些计数器(或使用一些原子增量),例如在 this answer .

可能解析线程主要是 IO 绑定(bind)。所以它通常会等待磁盘 IO。在那种情况下,互斥锁定的小开销是微不足道的。

在主 GUI 线程中,设置东西(例如一些 Qt timer ...)以每秒读取解析计数器(使用互斥锁),并更新进度条

关于c++ - 如何为进度条保留数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25227071/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com