for (; *p == '@'; p++) {
if ((*p >= 'a' && *p <= 'z') || (*p >= 'A' && *p <= 'Z') || (*p >= '1' && *p <= '9') || (*p == '_')) {
len1++;
}
else {
cout << "请输入数字、字母或下划线!" << endl;
break;
}
}
if (len1 > 20) {
cout << "位置x处的字符数量不能超过20个!" << endl;
}
就是我读取了一串字符串,然后我要从字符串的开始读到有@的地方(我前面设置了一定会有@存在),执行花括号里的语句,但是我调试的时候发现它直接跳过for里的语句,跳到了下面那个if上,这是哪里有问题?
你这个代码逻辑有些问题。
如果*p
是'@'
,那么执行for
循环里面的语句,既然*p=='@'
,那么for
里面的if
语句条件不成立,执行else
里的break
退出循环
如果*p
不是'@'
,那么for
循环条件不成立,直接执行for
后面的if
语句
少了个后大括号吧