Ben (12.10 64 bit ubuntu olan) benim platformda düzgün çalıştığını doğrulamak için, gerçek kodda kullanmadan önce izolasyon std::async
test ediyorum.Linux'ta gc 4.7'de std :: async bozuk mu?
(Biraz nadiren çalışır) ve genellikle yalnızca askıda kalıyor. Eğer senin için çalışırsa, sonuçlara atlamayın. Birkaç kez daha dene, muhtemelen asılacak. Ben pthread_mutex testi kaldırırsanız
, bu takılmaz. Bu, asmayı çoğaltmak için alabildiğim en küçük kod. C pthread kodunu C++ async koduyla karıştırmanın bazı nedenleri var mı?
g++ -Wextra -Wall --std=c++11 -pthread mutexperf/main.cpp
hiçbir yapı çıkış mesajı vardır: İşte
#include <iostream>
#include <pthread.h>
#include <chrono>
#include <future>
#include <iomanip>
#include <sstream>
#include <type_traits>
template<typename T>
std::string format_ns(T &&value)
{
std::stringstream s;
if (std::is_floating_point<T>::value)
s << std::setprecision(3);
if (value >= 1000000000)
s << value/1000000000 << "s";
else if (value >= 1000000)
s << value/1000000 << "ms";
else if (value >= 1000)
s << value/1000 << "us";
else
s << value << "ns";
return s.str();
}
template<typename F>
void test(const std::string &msg, int iter, F &&lambda)
{
std::chrono::high_resolution_clock clock;
auto st = clock.now();
int i;
for (i = 0; i < iter; ++i)
lambda();
auto en = clock.now();
std::chrono::nanoseconds dur = std::chrono::duration_cast<
std::chrono::nanoseconds>(en-st);
std::cout << msg << format_ns(dur.count()/i) << std::endl;
}
int test_pthread_mutex()
{
pthread_mutex_t m = PTHREAD_MUTEX_INITIALIZER;
test("pthread_mutex_lock/pthread_mutex_unlock: ", 1000000000,
[&]()
{
pthread_mutex_lock(&m);
pthread_mutex_unlock(&m);
});
pthread_mutex_destroy(&m);
return 0;
}
int test_async()
{
test("async: ", 100,
[&]()
{
auto asy = std::async(std::launch::async, [](){});
asy.get();
});
return 0;
}
int main()
{
test_pthread_mutex();
test_async();
}
inşa komut satırı olduğunu. İşte
çıkışı olan g ++ -v
Using built-in specs.
COLLECT_GCC=g++
COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-linux-gnu/4.7/lto-wrapper
Target: x86_64-linux-gnu
Configured with: ../src/configure -v --with-pkgversion='Ubuntu/Linaro 4.7.2-2ubuntu1' --with-bugurl=file:///usr/share/doc/gcc-4.7/README.Bugs --enable-languages=c,c++,go,fortran,objc,obj-c++ --prefix=/usr --program-suffix=-4.7 --enable-shared --enable-linker-build-id --with-system-zlib --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --with-gxx-include-dir=/usr/include/c++/4.7 --libdir=/usr/lib --enable-nls --with-sysroot=/ --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --enable-gnu-unique-object --enable-plugin --enable-objc-gc --disable-werror --with-arch-32=i686 --with-tune=generic --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu
Thread model: posix
gcc version 4.7.2 (Ubuntu/Linaro 4.7.2-2ubuntu1)
Sizinle aynı derleyici ve kurulum var. Ben çoğaltamıyorum. Kod iyi görünüyor. –
@johan Yeniden üretemeyeceğini düşündüm. Diğer bazı makinelerde deneyeceğim ve ne olduğunu göreceğim. Teşekkürler. – doug65536