草庐IT

QT多线程

全部标签

http - 多线程Go for HTTP get

我在一个API中使用Go来获取我所在城市的公交车频率,但是当我尝试使HTTPGet访问许多URL时,我有点卡在了线程上。如果没有并发,程序需要超过16分钟才能完成1500个url调用以获取HTTP状态代码,我试图使用并发,但在阅读了很多帖子后我不明白goroutines是如何工作的......想法是制作一个函数并更改请求的数量,如下所示:gogetBusPostStatus(600,800)但我完全坚持...代码如下:packagemainimport("fmt""net/http""strconv""time")variint=0varconvStrstringvarmessage=

Qt安卓开发:调用java代码的获取usb权限

最近换了工作,新工作是负责用qml做qt安卓开发。工作中遇到一个问题:安卓设备有USB口,需要插入一个U盘在程序里读写U盘中的文件,由于安卓系统的安全性的问题导致QFile、c++的文件操作相关方法都不能读写成功,想要读写成功只能调用java代码,在java代码里面使用安卓的DocumentFile库。经过一番探索,成功解决了问题。qt如何添加java代码不说了,网上有。下面是具体的java代码:packagecom.example.myapplication;importandroid.annotation.TargetApi;importandroid.content.Context;im

go - 测试在后台线程中运行的函数的结果

我有一个WebSocket服务器,我正在尝试正确测试它的一些功能。我有以下场景:我正在接受WebSocket连接并调用一个channelregisterConn在新连接上通知typehubstruct.这是中心:typehubstruct{clientsmap[client]boolregisterConnchanclient//someotherfieldsbelow...}//Thisfunctionrunsinitsownthreadforeverfunc(h*hub)run(){for{select{//Aclientconnectsonthischannelcaseclien

go - 如何使变量成为线程安全的

我是Go的新手,我需要创建一个线程安全的变量。我知道在Java中您只能使用synchronized关键字,但是go中似乎不存在这样的内容。有什么方法可以同步变量? 最佳答案 Java中的synchronized是仅允许单个线程(在任何给定时间)执行代码块的方法。在Go中,有许多构造可以实现该目标(例如mutt,channel,waitgroups,sync/atomic中的原语),但是Go的谚语是:“不要通过共享内存进行通信;而是通过通信来共享内存。”因此,与其锁定和共享变量,不如不要这么做,而要在goroutines之间传递结果,

qt - 是否可以在 Qt(Golang 绑定(bind))应用程序中使用 Sparkle?

我们构建一个Qt应用程序使用:https://github.com/therecipe/qt.现在我们需要一个自动更新程序并找到这个:https://sparkle-project.org看起来它正在被我机器上的多个应用程序使用:/Applications/VLC.app/Contents/Frameworks/Sparkle.framework/Applications/Adium.app/Contents/Frameworks/Sparkle.framework/Applications/TeamViewer.app/Contents/Frameworks/Sparkle.fram

multithreading - 阅读缓存DIY书时的一个Go map线程安全问题

我正在读一本书,它教我如何编写像Redis这样的简单缓存。以实现分布式哈希为目标,项目必须有key迁移,这需要一个迭代器。而且我认为可能存在一些问题。他的书是关于迭代map的,但是在迭代的同时,读取锁的保持不是连续的。原因是尽量不影响主缓存进程。我相信一定存在线程安全问题,因为主缓存线程仍在写入映射。我写了一个演示,但不确定。//bookcodetypeinMemoryScannerstruct{pairpairChan*paircloseChchanstruct{}}func(c*inMemoryCache)NewScanner()Scanner{pairCh:=make(chan*

image - qml qt grabToImage 获取图像字节

出于某种原因,直接从qml中保存png是行不通的。我在Golang应用程序之上有一个qmlUI。当我做的时候source.grabToImage(function(result){console.log("image:",result.url)if(!result.saveToFile(urlNoProtocol)){console.error('Unknownerrorsavingto',urlNoProtocol);}else{console.log("savedto"+urlNoProtocol)}保存时出错。保存文件的位置来自fileDialog,我对其进行预处理以删除file

qt - Qt无框透明窗口中的文字碎片

我正在尝试使用Qt及其go-bind(https://github.com/therecipe/qt)创建一个无框透明窗口。我遇到的问题是文字碎片残留在无框透明窗口中。请看Gif(https://i.imgur.com/47OC7ps.gif)。我确认的问题的特征如下。问题只出现在调整大小的窗口中。(但不是100%)最初只有文本显示在窗口中的将保留为碎片。这个问题可以通过在QMainWindow本身显式调用Hide()、Show()来避免,但是会出现性能问题。我预计会考虑调整应用程序的大小,因为问题仅发生在调整大小的窗口中。有什么想法吗?我的环境如下:Qt:5.12.0我的应用源代码:

google-app-engine - Golang、App Engine、 channel 和线程安全

http://blog.golang.org/go-and-google-app-engine“此外,尽管存在goroutine和channel,但当Go应用程序在AppEngine上运行时,在给定实例中仅运行一个线程。也就是说,所有goroutine都在单个操作系统线程中运行,因此没有CPU并行性可用于给定的客户请求。我们希望在某个时候可以取消此限制”那是在2011年5月。现在仍然如此吗?我有一个应用程序,它除了利用Golang的速度之外什么都不做;获取一些输入数据,对其执行内存计算,返回结果。切勿接触数据存储区或任何其他AppEngineAPI。我需要应用程序执行许多计算,最好是具

memory - 为什么使用单独的线程原子操作更快?

我有两段代码,桌面上有32个内核。代码A使用32个线程并执行以下操作,1)将值写入内存中的一些随机位置2)原子地向全局变量添加一个值。代码B使用16个线程将值写入随机位置,并使用另外16个线程以原子方式将值添加到全局变量。我想知道为什么代码B在每秒对全局变量执行多少原子操作方面更快。这里是代码Avarauint64=0constN=10*1024*1024vardata[N]uint64funcmain(){fori:=0;i这里是代码Bvarauint64=0constN=10*1024*1024vardata[N]uint64funcmain(){fori:=0;i