मैं एक वास्तविक समय सॉफ्टवेयर बना रहा हूं जहां मेरे पास main()
पर मुख्य अनंत लूप हैं और डेटा पढ़ने और संसाधित करने के लिए उपयोग किए जाने वाले धागे हैं।सी ++ std :: स्वतंत्र std :: threads
इनमें से एक समस्या std::vector
को थ्रेड चलाने के लिए सिग्नल भेजने और निष्पादन की निगरानी करने के लिए रख रही है।
#include <iostream>
#include <string>
#include <vector>
#include <thread>
#include <chrono>
namespace readerThread {
void start(int id)
{
while (1)
{
std::cout << "Reader " << id << " running..." << std::endl;
std::this_thread::sleep_for(std::chrono::milliseconds(1000));
}
}
}
int main()
{
int readers[] = { 1, 2, 3 };
std::vector<std::thread> readerThreads;
for (int &reader : readers)
{
std::thread th(readerThread::start, reader);
readerThreads.push_back(th);
}
while(true)
{
std::cout << "Waiting..." << std::endl;
std::this_thread::sleep_for(std::chrono::milliseconds(10000));
}
return 0;
}
यह संकलन भी नहीं करता है, यह त्रुटि मिल रही:: तो मैं एक साथ इस कोड को
In file included from /usr/local/include/c++/5.1.0/x86_64-unknown-linux-gnu/bits/c++allocator.h:33:0,
from /usr/local/include/c++/5.1.0/bits/allocator.h:46,
from /usr/local/include/c++/5.1.0/string:41,
from /usr/local/include/c++/5.1.0/bits/locale_classes.h:40,
from /usr/local/include/c++/5.1.0/bits/ios_base.h:41,
from /usr/local/include/c++/5.1.0/ios:42,
from /usr/local/include/c++/5.1.0/ostream:38,
from /usr/local/include/c++/5.1.0/iostream:39,
from main.cpp:1:
/usr/local/include/c++/5.1.0/ext/new_allocator.h: In instantiation of 'void __gnu_cxx::new_allocator<_Tp>::construct(_Up*, _Args&& ...) [with _Up = std::thread; _Args = {const std::thread&}; _Tp = std::thread]':
/usr/local/include/c++/5.1.0/bits/alloc_traits.h:256:4: required from 'static std::_Require<std::allocator_traits<_Alloc>::__has_construct<_Tp, _Args ...> > std::allocator_traits<_Alloc>::_S_construct(_Alloc&, _Tp*, _Args&& ...) [with _Tp = std::thread; _Args = {const std::thread&}; _Alloc = std::allocator<std::thread>; std::_Require<std::allocator_traits<_Alloc>::__has_construct<_Tp, _Args ...> > = void]'
/usr/local/include/c++/5.1.0/bits/alloc_traits.h:402:16: required from 'static decltype (_S_construct(__a, __p, (forward<_Args>)(std::allocator_traits::construct::__args)...)) std::allocator_traits<_Alloc>::construct(_Alloc&, _Tp*, _Args&& ...) [with _Tp = std::thread; _Args = {const std::thread&}; _Alloc = std::allocator<std::thread>; decltype (_S_construct(__a, __p, (forward<_Args>)(std::allocator_traits::construct::__args)...)) = <type error>]'
/usr/local/include/c++/5.1.0/bits/stl_vector.h:917:30: required from 'void std::vector<_Tp, _Alloc>::push_back(const value_type&) [with _Tp = std::thread; _Alloc = std::allocator<std::thread>; std::vector<_Tp, _Alloc>::value_type = std::thread]'
main.cpp:37:30: required from here
/usr/local/include/c++/5.1.0/ext/new_allocator.h:120:4: error: use of deleted function 'std::thread::thread(const std::thread&)'
{ ::new((void *)__p) _Up(std::forward<_Args>(__args)...); }
^
In file included from main.cpp:4:0:
/usr/local/include/c++/5.1.0/thread:126:5: note: declared here
thread(const thread&) = delete;
^
धागे areindependent, तो मैं मुख्य कार्यक्रम पर join
कॉल करने की आवश्यकता नहीं है और न ही
मेरी कोड क्यों संकलन नहीं करता है: किसी भी धागे पर ...
तो, यहाँ मेरी संदेह कर रहे हैं?
क्या धागे के वेक्टर को स्टोर करने का सही तरीका है?
मदद के लिए धन्यवाद ...
पुनश्च: Original code here:
यदि आप अपने आवेदन को सही तरीके से रोकने की योजना बना रहे हैं, तो आपको थ्रेड ऑब्जेक्ट को नष्ट करने से पहले 'join()' को कॉल करना चाहिए। या ऑब्जेक्ट से अलग थ्रेड के लिए 'detach() 'को कॉल करें। अन्यथा आपको थ्रेड विनाशक में 'समाप्त() 'कॉल मिलेगी। – gomons
गोमन्स, आपका अंक नहीं मिला। शामिल हों() मुख्य थ्रेड निष्पादन को पकड़ लेगा, और यह यहां वांछित नहीं है ... – Mendes
आप 'readerThreads.emplace_back (रीडर थ्रेड :: स्टार्ट, रीडर) का भी उपयोग कर सकते हैं;', क्या गोमन्स का मतलब है कि आपको या तो 'जुड़ना होगा() 'या' डिटेच() 'इसके विनाशक निष्पादन से पहले एक धागा उदाहरण, अन्यथा 'समाप्त()' कहा जाता है। लेकिन आपके धागे हमेशा के लिए दौड़ने के लिए काफी खुश लगते हैं, इसलिए यह ऊपर दिए गए उदाहरण में कोई समस्या नहीं है। – Praetorian