我想将字符文字与字符串的第一个元素进行比较,以检查文件中的注释。为什么要用炭?我想把它变成一个函数,它接受注释的字符var。我不想允许字符串,因为我想将它限制为单个字符的长度。
考虑到这一点,我认为简单的方法是解决角色并将其传递给std :: string的compare函数。然而,这给了我意想不到的结果。
我的代码如下:
#include <string>
#include <iostream>
int main ( int argc, char *argv[] )
{
std::string my_string = "bob";
char my_char1 = 'a';
char my_char2 = 'b';
std::cout << "STRING : " << my_string.substr(0,1) << std::endl
<< "CHAR : " << my_char1 << std::endl;
if (my_string.substr(0,1).compare(&my_char1)==0)
std::cout << "WOW!" << std::endl;
else
std::cout << "NOPE..." << std::endl;
std::cout << "STRING : " << my_string.substr(0,1) << std::endl
<< "CHAR : " << my_char2 << std::endl;
if (my_string.substr(0,1).compare(&my_char2)==0)
std::cout << "WOW!" << std::endl;
else
std::cout << "NOPE..." << std::endl;
std::cout << "STRING : " << my_string << std::endl
<< "STRING 2 : " << "bob" << std::endl;
if (my_string.compare("bob")==0)
std::cout << "WOW!" << std::endl;
else
std::cout << "NOPE..." << std::endl;
}
给我......
STRING : b
CHAR : a
NOPE...
STRING : b
CHAR : b
NOPE...
STRING : bob
STRING 2 : bob
WOW!
为什么函数认为子字符串和字符不相同。正确比较chars和std :: string vars的最短方法是什么?
(对我的问题避免重新分类的短暂咆哮......随意跳过)
当我说最短时,我的意思是出于对编码口才的渴望。请注意,这不是一个家庭作业问题。我是化学工程博士候选人,正在编写独立研究的一部分。当我询问效率时,我的最后一个问题被用户msw重新归类为“家庭作业”(我也考虑了效率),我认为这是在滥用的边界。我的代码可能会或可能不会被其他人重用,但我试图让它易于阅读和维护。我也有一种奇怪的愿望,即尽可能使我的代码尽可能高效。因此,关于效率和口才的问题。
答案 0 :(得分:14)
这样做:
if (my_string.substr(0,1).compare(&my_char2)==0)
无法正常工作,因为你“欺骗”了字符串,认为它正在获取指向以null结尾的C字符串的指针。这将产生奇怪的效果,包括崩溃你的程序。相反,只需使用正常的相等性来比较字符串的第一个字符和my_char:
if (my_string[0] == my_char)
// do stuff
答案 1 :(得分:4)
为什么不在字符串上使用索引运算符?它将返回一个char类型。
if (my_string[0] == my_char1)
答案 2 :(得分:3)
您可以使用字符串的运算符[]将其与单个字符
进行比较// string::operator[]
#include <iostream>
#include <string>
using namespace std;
int main ()
{
string str ("Test string");
int i; char c = 't';
for (i=0; i < str.length(); i++)
{
if (c == str[i]) {
std::cout << "Equal at position i = " << i << std::endl;
}
}
return 0;
}
答案 3 :(得分:1)
前两个比较调用的行为完全取决于随机内存内容跟随每个char的地址。您正在调用basic_string::compare(const char*)
,并且此处的param假定为C-String(以null结尾),而不是单个char。 compare()调用将比较你想要的char,然后是char之后的内存中的所有内容,直到下一个0x00字节,手中有std :: string。
Otoh&lt;&lt;运算符确实具有char输入的正确重载,因此您的输出不会反映您实际比较的内容。
将and和b的decls转换为const char[] a = "a";
,您将得到您想要发生的事情。
答案 4 :(得分:1)
非常标准,c ++中的字符串以null结尾;字符不是。因此,通过使用标准比较方法,您确实检查“b \ 0”=='b'。
我使用了这个并获得了所需的输出:
if (my_string.substr(0,1).compare( 0, 1, &my_char2, 1)==0 )
std::cout << "WOW!" << std::endl;
else
std::cout << "NOPE..." << std::endl;
这说的是从子字符串的第0位开始,使用长度为1,并将其与长度为1的字符引用进行比较。Reference