シリアル ポートからデータを読み取って解析するクラスを作成しようとしていますが、インスタンス化されたエラーが発生し続け、その理由がわかりません。このクラスは、シリアル ポートとその io_service を受け取ります。ブーストを使用しています。大量のエラーが発生していますが、それは累積的なものだと思います(それが正しいかどうかはわかりません)。これが最初のものです:
/usr/include/boost/bind.hpp:22:0 からインクルードされたファイルでは、../Sources/Magnetic Compensator Core.cpp:17 から:
/usr/include/boost/bind/bind.hpp: 'boost::_bi::result_traits&, const boost::system::error_code&, unsigned int)>' のインスタンス化: /usr/include/boost/bind/bind_template .hpp:15:48: 'boost::_bi::bind_t&、const boost::system::error_code&、unsigned int)、boost::_bi::list4、boost::reference_wrapper >、boost::arg<からインスタンス化1>、boost::arg<2> > >'</p>
クラスのコードは次のとおりです。
class mag_serial
{
bool data_available;
boost::asio::serial_port& ser_port;
boost::asio::deadline_timer timeout;
char my_buffer[1];
std::string str;
std::string st;
void read_callback(bool& data_available, boost::asio::deadline_timer& timeout, const boost::system::error_code& error, std::size_t bytes_transferred)
{
data_available = true;
if(str.length() > 1)
{
if (!(str.at(str.length() - 1) == temp))//&str.at(str.length() - 1) != "#")
{
str.append(my_buffer,bytes_transferred);
if(str.at(str.length() - 1) == quit)
{
cout << "I am quitting";
Stop();
ser_port.cancel();
ser_port.close();
return;
}
i++;
}
else if (str.at(str.length() - 1) == temp)
{
st = str;//.substr(1, str.size());
// Processing Functions
}
}
else
{
str.append(my_buffer,bytes_transferred);
if(str.at(0) == quit)
{
cout << "I am quitting";
Stop();
ser_port.cancel();
ser_port.close();
return;
}
}
ser_port.async_read_some(boost::asio::buffer(my_buffer),
boost::bind(&mag_serial::read_callback, boost::ref(data_available),
boost::ref(timeout),boost::asio::placeholders::error(),
boost::asio::placeholders::bytes_transferred()));
data_available = true;
}
void wait_callback(boost::asio::serial_port& ser_port, const boost::system::error_code& error)
{
if (error)
{
// Data was read and this timeout was cancelled
return;
}
}
public:
mag_serial(boost::asio::serial_port& ser_port, boost::asio::io_service& io_svc): ser_port(ser_port), timeout(ser_port.get_io_service()){}
void read_mag_serial_thread()
{
bool data_available = false;
ser_port.async_read_some(boost::asio::buffer(my_buffer),
boost::bind(&mag_serial::read_callback, boost::ref(data_available),
boost::ref(timeout),boost::asio::placeholders::error(),
boost::asio::placeholders::bytes_transferred()));
timeout.expires_from_now(boost::posix_time::seconds(1));
timeout.async_wait(boost::bind(&mag_serial::wait_callback, boost::ref(ser_port),boost::asio::placeholders::error()));
io_svc.run();
if(!data_available)
{
ser_port.close();
cout << "ser_port was closed";
}
}
};