0

我正在尝试下面的示例

#include <boost/thread.hpp>
#include <boost/thread/condition.hpp>
#include <iostream>

#include <string>
#include <stdio.h>

std::string exec(char* cmd, boost::uint16_t *piOutVid, boost::uint16_t *piOutPid) {
    boost::uint16_t uint_pid;
    boost::uint16_t uint_vid = 0x05e0;
    piOutVid = &uint_vid;

    FILE* pipe1 = popen(cmd, "r");
    if (!pipe1) return "ERROR";
    char buffer[128];
    unsigned int value;
    std::string result = "";
    while(!feof(pipe1)) {
        if(fgets(buffer, 128, pipe1) != NULL)

            if(strncpy(buffer, "1300", 4))
            {
                uint_pid = 0x1300;
                std::cout << "value: " << buffer << std::endl;
            }
            else if(strncpy(buffer, "1900", 4))
            {
                uint_pid = 0x1900;
                std::cout << "value: " << buffer << std::endl;
            }
            else if(strncpy(buffer, "0820", 4))
            {
                uint_pid = 0x0820;
                std::cout << "value: " << buffer << std::endl;
            }

            result += buffer;
    }
    pclose(pipe1);
    buffer[127] = '\0';


    return result;
}

int main()
{
    boost::uint16_t *piOutVid;
    boost::uint16_t *piOutPid;
    std::cout << "Boost threading..." << std::endl;
    //boost::thread *nwThread = new boost::thread(boost::bind(class::method, this));
    char *cmd = "lsusb|grep 'Symbol'|cut -d \":\" -f 3|cut -d \" \" -f 1";
    exec(cmd, piOutVid, piOutPid);

}

第一次运行这个程序时。它工作正常,但重用程序不能正常工作。我第一次使用设备(PID = 1300)进行测试,然后将其移除并插入新设备(PID = 0820)并再次运行程序。但仍然给出相同的输出。

Boost threading...
value: 1300

Process returned 0 (0x0)   execution time : 0.059 s
Press ENTER to continue.

pclose()返回 0

4

1 回答 1

1

您的if语句基于 a 的结果strncpy,它始终返回 的内存地址destination。所以根据定义,如果复制成功,它总是会返回一个计算结果为true. 因此总是击中你的0x1300障碍。

你的意思是使用strcmp

于 2014-06-11T13:11:33.177 回答