我正在使用目前完全是單線程的中型C ++代碼庫。但是,現(xiàn)在是追求并發(fā)和并行性以提高性能的時候了。我對Google的Go編程語言的并發(fā)模型非常感興趣,該模型具有非常輕巧的goroutine和通信通道系統(tǒng)??杀氖?,由于各種完全合理的原因,該項目需要保留在C ++中。所以我的問題是:是否有一個C ++庫近似于并行性的Go范例?具體來說,是否存在適用于C ++的goroutine或go通道的近似值?我的后備計劃只是使用boost :: thread。該應(yīng)用程序是針對財務(wù)預(yù)測領(lǐng)域的長期專有仿真。它通常受CPU限制,但在有新數(shù)據(jù)可用時也會在IO上受阻。所涉及的許多計算不依賴于先前的結(jié)果,并且可以很容易地并行運行。能夠在分布式上下文中運行應(yīng)用程序是一個長期目標(biāo),但不是一個需要立即解決的目標(biāo)。
3 回答

冉冉說
TA貢獻(xiàn)1877條經(jīng)驗 獲得超1個贊
這個問題,一般來說,在Google上搜索“ C ++協(xié)程”應(yīng)該可以使您接近。SO問題建議嘗試使用Boost ::協(xié)程。
如果您不介意包裝C,則可以嘗試libtask。在Go開始工作之前,這是Russ Cox(Go開發(fā)的官方團隊之一)寫的。我只在C語言中使用過它,所以我不知道它是否適用。
順便說一下,Go通道被實現(xiàn)為鎖定隊列,因此您可以使用常規(guī)線程并入類似的機制。

倚天杖
TA貢獻(xiàn)1828條經(jīng)驗 獲得超3個贊
libgolang提供go
并提供了包括工作在內(nèi)的渠道select
。這是用法示例:
chan<int> ch = makechan<int>(); // create new channel go(worker, ch, 1); // spawn worker(chan<int>, int) ch.send(1) j = ch.recv() _ = select({ _default, // 0 ch.sends(&i), // 1 ch.recvs(&j), // 2 }); if (_ == 0) // default case selected if (_ == 1) // case 1 selected: i sent to ch if (_ == 2) // case 2 selected: j received from ch defer([]() { printf("leaving...\n"); }); if (<bug condition>) panic("bug");
go
根據(jù)激活的運行時生成線程或基于gevent的協(xié)程。
- 3 回答
- 0 關(guān)注
- 246 瀏覽
添加回答
舉報
0/150
提交
取消