C++学习day--09 字符串比较、运算符
1、项目练习
第
1
节 项目需求、项目实现
项目实现:
#include <iostream>#include <Windows.h>#include <string>using namespace std;int main( void ) {string name;string pwd;std::cout << " 请输入账号: " ;std::cin >> name;std::cout << " 请输入密码: " ;std::cin >> pwd;if (name == "54hk" && pwd == "123456" ) {std::cout << "1. 网站 404 攻击 " << std::endl;std::cout << "2. 网站篡改攻击 " << std::endl;std::cout << "3. 网站攻击记录 " << std::endl;std::cout << "4.DNS 攻击 " << std::endl;std::cout << "5. 服务器重启攻击 " << std::endl;} else {cout << " 用户名或密码错误 !" << endl;}system( "pause" );return 0;}
2、 项目精讲-string 字符串的比较
复习字符串的比较规则:
按顺先从前往后比较同序号的字符按“ ASCII ”码值比较直到遇到对应字符不等或者字符串结束
字符串比较的“运算符”
==
>
<
>= (
大于或者等于
)
<= (
小于或者等于
)
!=
c++中,字符串的比较, 可以直接使用以上的”比较运算符”,这里仅只对string类型的字符串,对char数组是不能这样比较的。
C++
语言里是可以用运算符进行比较的,但是
C
语言只能用库函数进行比较,同时
java
语言里
也只能用库函数比较。
java
语言用运算符比较
字符串是比较字符串的首地址。
比如
:
str1 == str2
字符串比较的“结果”:
bool
类型
逻辑真
true
逻辑假
false
表示真假的布尔类型
C++
语言中,有两种
bool(
布尔
)
类型的表示方式:
1
)直接使用
bool
类型
bool x = true;
bool
类型
,
只有两个值
:
truefalse
2
)使用
0
和非
0
的任何值(
C
语言风格)
0: 表示假非 0: 表示真
特别注意:
1>3
是假
1>3 == false
是真
3>1
是真
3>1 == false
是假
bool x;
x = 1 < 3;
类似:
对你的女神
/
男神说:
我爱你
=>
是真
我爱你
== true
=>
是真
我爱你
== false
=>
是假
对你的备胎说:我爱你
=>
是假
我爱你
== true
=>
是假
我爱你
== false
=>
是真
常见错误:
3>2>1
是假
3>2>1 =>
true>1 => 1>1
=> false
3>2 && 2>1
使用“逻辑与”运算。
bool
类型使用场合:
if
语句
for
语句
while
语句
项目精讲
-C
语言字符串的比较
#include <string.h>
int strcmp( const char *str1, const char *str2 );
例如
:
int ret;
ret = strcmp(str1, str2);
返回值:
str1 < str2 时, 返回值< 0(有些编译器返回 -1)str1 > str2 时, 返回值> 0(有些编译器返回 1)str1 等于 str2 时, 返回值为 0
demo:
#include <stdio.h>#include <string.h>#include <Windows.h>int main( void ) {char addr[32];int ret;printf( " 美女,你是哪里人? " );scanf( "%s" , addr);if (strcmp(addr, " 湖南 " ) == 0) {printf( " 美女,我们是老乡啊! \n" );} else {printf( " 美女,你和我的同学是老乡啊! \n" );}system( "pause" );return 0;}
其它数据类型的比较运算
char, int, short, float, double
等数据类型,都可以使用比较运算:
大于: >
大于或等于
: >=
小于: <
小于或等于: <=
不等于: !=
等于: ==
(注意:不是
=
)
比较运算的结果:(
逻辑值
)
结果为“真”:
true
结果为“假”:
false
#include <iostream>#include <Windows.h>using namespace std;int main( void ) {int weight;printf( " 美女 , 你多重啊 ?\n" );cin >> weight;if (weight >= 120) {cout << " 美女 , 如此丰满 , 真有福气 !" << endl;} else {cout << " 美女 , 这么瘦 , 身材不错啊 !" << endl;}system( "pause" );return 0;}
注意:浮点数的相等比较不能直接用
==来比较,二是让他们作差,若这个差在某个范围内,则认为这两个数相等。
3、逻辑运算符
与
C
语言完全相同。
现实生活中,任何决策,都是根据多个因素,综合决策的!
有没有钱
,
有没有时间
,
实力允不允许
?
逻辑与
&&
都为真,逻辑与才是真 只要有一个是假, 逻辑与就是假相当于“而且”
应用场景:
当需要两个条件都满足时,就使用逻辑与
java
语言的
&&
和
&
都是与运算,但是
&&有短路功能,而
&
没有短路功能。同理||
和
|
也是如此。
特别注意:
条件
1 &&
条件
2
当条件
1
为真时,才去判断条件
2
当条件
1
为假时,就不再判断条件
2
多个条件
:
条件
1 &&
条件
2 &&
条件
3
#include <iostream>#include <Windows.h>using namespace std;int main( void ) {int money;int days;cout << " 你有多少钱 ?" ;cin >> money;cout << " 你看多少天的假期 ?" ;cin >> days;// 如果存款大于 10 万 , 而且假期大于 10 天 , 就去旅游if (money > 100000 && days > 10) {cout << " 我要去旅游 !" << endl;} else {cout << " 还是在家里呆着 " << endl;}system( "pause" );return 0;}
逻辑或 ||
只要有一个是真, 结果就是真,都为假时,结果才是假,相当于“或者”
多个条件
:
条件
1 ||
条件
2 ||
条件
3
应用场景:
只需要满足任意一个条件时,就使用逻辑或
特别注意:
条件
1 ||
条件
2
当条件 1 为真时,就不再判断条件 2当条件 1 为假时,才判断条件 2
和上面一样,
||
也有短路功能
#include <iostream>#include <string>#include <Windows.h>using namespace std;int main( void ) {int money;string love;cout << " 你有多少钱 ?" << endl;cin >> money;cout << " 你爱我吗 ?" << endl;cin >> love; // 回答 : 爱 或者 不爱if (money > 1000000 ||love == " 爱 " ) {cout << " 我们结婚吧 !" << endl;} else {cout << " 你是一个好人 !" << endl;}system( "pause" );return 0;}
逻辑非 !
是
”
单目运算符
”,
即
:
只有一个操作数 ,!条件
相当于“不”
应用场景:
当需要不满足某条件时,就使用逻辑非
特别注意:
逻辑非,只对一个条件进行运算!
是一种“单目运算符”
需求
:
如果月薪不到
3
万
,
那就努力修炼
.
否则
,
就可以去接外包
#include <iostream>#include <Windows.h>using namespace std;int main( void ) {int money;int days;cout << " 你的月薪多少 ?" ;cin >> money;if (!(money >= 30000)) {cout << " 我是菜鸟 , 薪资不到 3 万 , 我要努力修炼 !\n" << endl;} else {cout << " 我要接外包 \n" << endl;}system( "pause" );return 0;}
操作硬件的位运算
问题
:
把地址为
0x80040
的寄存器的最低
4
位设置为
0110
解决方案
:
使用位操作
什么是位
?
内存的基本单元是字节
,
一个字节有
8
位
.
位与
&
0 & 000 & 101 & 001 & 11
对应位
,
都是
1,
结果才是
1
// 00001000// 00000011// 00000000
cout <<
" 8 & 3 = "
<< (8 & 3) << endl;
位或
|
0 | 000 | 111 | 011 | 11
对应位
,
都是
0,
结果才是
0
只要有一位是
1,
结果就是
1
0 | x x// 00001000// 00000011// 00001011
cout <<
" 8 | 3 = "
<< (8 | 3) << endl;
位非
~
~ 10~ 01
取反
// 00001000// 11110111
unsigned char
x = ~8;
cout << (
int
)x << endl;
//247
异或
^
0 ^ 0 01 ^ 1 00 ^ 1 11 ^ 0 1
对应位不同
,
结果才是
1
// 00001000// 00000011// 00001011
cout << (8^3) << endl; //11
<<
左移
右边的位用
0
来填充
,
移动超出左边边界的位则直接抛弃。
向左移动
n
个位置,就等同于乘以
2
的
n
次方
只适用于
: int/short/long/char
等定点数类型
(float/double
浮点数类型不能使用)
// 00001000// 01000000
cout << (8<<3) << endl;
//8*2*2*2 = 64
>>
右移
如果左操作数是无符号类型,则左边多出来的位用
0
来填充。
如果左操作数是有符号类型,则左边多出来的位用 符号位
(
最高位
)
来填充。
向左移动
n
个位置,就等同于除以
2
的
n
次方
只适用于
: int/short/long/char
等定点数类型
(float/double
浮点数类型不能使用
)
// 00001000
// 00000001
cout << (8>>3) << endl;
//1
应用
:
把一个整数的的最低
4
位设置为
0110
cout << " 请输入一个整数 : " << endl;cin >> x;// 把 x 的最低 4 位清 0x = x & (~15);// 把 x 的最低 4 位设置为 0110x = x | 6;cout << "x=" << x << endl;
其它运算
已经学习了
:
x = 100;
== > >= < <= !=
&& || !
& |
~ ^ >> <<
算术运算
赋值运算
x = 10; //
把
x
的值
设置为
10,
把
10
写到变量
x
中。
x = 10 + a;
左边必须是变量
“优先级”很低,只比
","
(逗号元素符)高。
复合赋值运算
x += 10;
// x = x + 10
x -= 10;
// x = x - 10
类的还有:
*= , /=, %= 等。
自增自减运算
i++ => i = i+1
++i => i = i+1
i-- => i = i-1
--i => i = i-1
i = 100;
x = i++; // x = 100
i = 100;
x = ++i; // x= 101
1.
只能对变量做
++
和
--
运算,不能对变量和表达式做
++
和--运算
5++; //ERROR
(3+x)++; //ERRO
2.
建议尽量使用前缀自增(自减),以避免错误。
逗号运算符
优先级最低
#include <stdio.h>int main(void) {int x;// 先计算 x = 3+5, 再计算 3*5x = 3+5, 3*5, 10/5;printf("x=%d\n", x); //x=8// 取最后一个表达式的值,作为整个“逗号表达式”的值x = (3+5, 3*5, 10/5);cout << x << endl; //x=2return x;}
因为逗号表达式的优先级最低,比赋值运算符优先级还低,因此x=8,而不是
2
。
三目运算符
条件
?
表达式
1
:表达式
2
如果条件为真,就取表达式
1
作为整个表达式的值
如果条件为假,就取表达式
2
作为整个表达式的值
#include <iostream>#include <Windows.h>using namespace std;int main( void ) {int salary;printf( " 请输入您的月薪 : " );scanf( "%d" , &salary);cout << (salary > 30000 ? " 老鸟 " : " 菜鸟 " ) << ", 晚上好 !" << endl;system( "pause" );return 0;}
使用多个运算符时的优先级
一共有
15
个级别!
不需强制记忆,只需要掌握以下常用的优先级:
最高优先级:
( )
和
[ ]
最低优先级:逗号表达式
倒数第二低优先级:赋值和复合赋值
(=
,
+=, -= ...)
x = a+ b*c;
! > 算术运算符 > 关系运算符 > && > || > 赋值运算符
(3 + 4 < 5 && 6 > 7)
|| (
8 > 7)
;
4、数据类型之间的转换
类型转换的概念
为什么需要“类型转换”
参与运算的两个操作数的数据类型,必须相同!
类型转换的类别:
1. 隐式类型转换 ( 自动完成转换) 小范围内的数转为大范围 内数1 )算数转换2 )赋值转换3 )输出转换
2. 强制类型转化(
大范围内的数转为小范
围内的数)
隐式类型转换
算数转化
(+,-,*,/,%)
char , int, long, long long, float, double
15 + 3.14 => 15.0 + 3.14
赋值转换
#include <stdio.h>int main(void) {int x;// 计算结果 31.4 转换为 int 类型,因为赋值符号的左边变量的类型是 int 类型x = 3.14 * 10.0;cout << x << endl; //31return 0;}
输出转换(C 语言)
#include <stdio.h>int main(void) {printf("%c\n", 255+50); //305 -> 49 ('1');printf("%d\n", 255+50); //305return 0;}
int
类型数据, 按照
%f
格式输出时,将得到错误的输出
float
(或
double)
类型数据,按照
%d
格式输出时,将得到错误的输出
强制类型转化
简单强制类型转换
(
直接使用数据类型
)
int x = 257 + 100;cout << "x=" << x << endl; //357x = ( char )257 + 100; //100000001 -> 00000001cout << "x=" << x << endl; //101
高级强制类型转换
1) static_cast2) dynamic_cast3) const_cast4) reinterpert_cast
[
将在后续章节中
,
详细精讲]
C++
特有的强制类型转换
,现在这里打个预防针,
后续讲解。