I am using a std::vector
to store some strings, later I try to std::find
them but passing through strdup, as shown in the sample code, It does not work, std::find
returns last, which means it did not find the string, but I can see that it is there, as I access it through the std::vector::at
function, and it is displayed correctly. What is the problem?
#include <iostream>
#include <stdio.h>
#include <vector>
#include <algorithm>
#include <stdint.h>
#include <string.h>
int main()
{
std::vector<char*> signal_list;
std::vector<char*>::iterator it;
char *temp;
char *temp2;
signal_list.push_back("DDF_LTEsyn__CALLER");
signal_list.push_back("DDF_LTEsyn__FFT_ctrl");
signal_list.push_back("DDF_LTEsyn__IFFT_ctrl");
signal_list.push_back("DDF_LTEsyn__ae_ctrl");
signal_list.push_back("DDF_LTEsyn__cwp_ctrl");
signal_list.push_back("DDF_LTEsyn__decision_ctrl");
signal_list.push_back("DDF_LTEsyn__ovelap_ctrl");
signal_list.push_back("DDF_LTEsyn__pilots_ctrl");
signal_list.push_back("DDF_LTEsyn__pre_ctrl");
signal_list.push_back("DDF_LTEsyn__rep_ctrl");
temp2 = strdup(signal_list.at(3));
printf("There is %s at position %d\n",temp2, 3);
it = find(signal_list.begin(), signal_list.end(), temp2);
printf("i found %s at position %d ",temp2, it - signal_list.begin());
}
You're comparing pointer addresses, not strings. You should use a
std::vector<std::string>
or usestd::find_if()
and pass it a predicate that can compare char pointers.Here is how you could do the second of those: