Ubuntu, vmWare
Linux
常量: 数字 十进制数(Dec) 20 八进制(Oct) 024 十六进制(Hex) 0x14 二进制数(Bin) 0b10100字符 ‘ ‘ man ascii :
转义字符 在字符中用\表示:
还有和八进制或者十六进制数字联合一起的转义字符,表示取对应的ASCII码值:
练习:定义一个char类型变量, 尝试用不同的方式给该变量赋值, 并打印结果;char x = ‘a’;char y = 97;printf(“x = %c , x=0x%x \n”, x, x );printf(“y = %c , y=0x%x \n”, y, y ); 字符串 “ ”“hello” 只要有双引号,在字符串的最后就会有一个空字符’\0’ ‘h’ ‘e’ ‘l’ ‘l’ ‘o’ ‘\0’
变量:在运行过程中数值会发生变化的变量名是由字母和下划线开头,由数字、字母、下划线组成的 定义一个字符型变量char c = ‘a’ ; // 用常量‘a’给变量c赋初值char _3c = ‘a’ ;char val = ‘a’ ;以上,实际写入到内存的是字符‘a’所对应的ASCII码值 Oct Dec Hex Char 141 97 61 a char c = ‘a’ ; ==等价于=> char c = 97 ; 变量的定义:按数据类型在内存中申请指定大小的字节空间1)【数据的作用域】 数据类型 变量名;2)【数据的作用域】 数据类型 变量名 = 初值;作用域: static 静态变量 ,按需求设置数据类型 : 是必须的基本数据类型有:
%d需要把这个数据当成是带符号的补码,需要显示出其原码:
思考: char a = 135; 和 unsigned char b = 135 ; 实际写入内存的有没有区别? (没有) 在使用的时候有没有区别?(自动类型转换 带符号转成无符号~)a+5 和 b+5的结果是否一致结果用打印没有区别 short 短整型 占用2个字节(2Byte , 2B)(-215~~ 215-1 ) unsigned short (0~~ 216-1 ) int 32位占用4个字节(4Byte , 4B) 64位占用4个字节(4Byte , 4B) unsigned int float 单精度浮点型 带有小数点 %f32位占用4个字节(4Byte , 4B) 64位占用4个字节(4Byte , 4B) unsigned floatfloat x = 0.01;float x = 1e-2 ;float y = 10000.0;float y = 1e4 ; long 长整型 %ld %lu %lx32位占用4个字节(4Byte , 4B) 64位占用8个字节(4Byte , 4B) unsigned long double 双精度浮点型 带有小数点的 %lf32位占用8个字节(4Byte , 4B) 64位占用8个字节(4Byte , 4B) unsigned double long double类型用%llf打印 bool / _Bool 需要加头文件#include
运算符int val = 100;赋值运算符:
算术运算符:
关系运算符 是用来描述两个数之间的关系:
练习:test1输入一个小写字符, ‘a’ ‘z’显示该字符对应大写字符,连续显示4次输入‘a’ ,输出是AAAA 字符的输入和显示 用%cchar c ;scanf(“%c” , &c);for( i=0; i<4; i++ )printf(“%c”, c-32); 逻辑运算符逻辑与 &&条件1 && 条件2只有这两个条件都满足(条件为真)整个表达式才为真只要有一个为假就是假如果条件1已经是假,不会处理条件2 例:判断输入的是否为小写字符:char c ; scanf(“%c” , &c); // ‘a’ ‘z’ ‘z’ >= c >= ‘a’ 数学上写法if( c >= ‘a’ && ‘z’ >= c ) 逻辑或 ||条件1 || 条件2只有有一个条件满足(条件为真)整个表达式就为真只有这两个条件都不满足(条件都为假)整个表达式才为假如果条件1已经是真,不会处理条件2 if ( 小写字符 || 大写字符 ) ‘a’ ~ ‘z’ ‘A’ ~ ‘Z’判断一个字符是否为英文字符if ( (c >= ‘a’ && ‘z’ >= c ) || (c >= ‘A’ && ‘Z’ >= c ) ) 练习 test2.c输入一个字符, 英文字符或者数字字符如果是小写字符就显示该字符对应大写字符,连续显示4次如果是大写字符或者数字字符就显示输入出错
---------------------------------------------------------------------------- scanf(“%c”, &ch) 不管键盘的缓冲区里面有什么数据 都会读取之并当成是字符如果需要清空缓冲区,常用
%d只取+-%x只取xXabcdefABCDEF%s 可以取键盘上所有键值,除了空格和回车-------------------------------------------------------------------------- 逻辑非 !单目运算符 !条件 如果条件为真, 整个表达式为假如果条件为假,整个表达式为真非零就是真分析: !val 如果val 的值为1 , 请问 !val 判断结果为假 如果val 的值为0 , 请问 !val 判断结果为真 分析 ! (a>b) 如果a的值为10 ,b的值为12, ! (a>b) a>b不成立 ,这个表达式是真的 如果a的值为15 ,b的值为12, ! (a>b) a>b成立 ,这个表达式是假的 位运算符 针对bit做操作 1Byte有8bits 位与运算符 & 对应位相与 都为1才为1 ,否则为0如 unsigned char val = 10; val & 0x01 ==》 0000 1010& 0000 0001 0000 0000 1) 用于判断某一位是为1还是0如 判断一个unsigned char数据的最低位是否为1 unsigned char val ; .........如果 val & 0x01 != 0 说明最后一位是1如果 val & 0x01 == 0 说明最后一位是0 2) 用来令某一位为0如 令unsigned char val 的第3位为0 val & 0b11110111 位或运算符 | 对应位相或 都为0才为0 ,否则为1如 unsigned char val = 10; val | 0x01 ==》 0000 1010| 0000 0001 0000 1011 用于把某一位置成1如 保证unsigned char val 的第4位为1 val | 0b 左移运算 << 把数据按要求向左移动指定位数 直接把高位移走, 低位补0 对数据逐位进行操作 在数据没有越界的情况下, 左移n位就相当于乘以2n 右移运算 >> 把数据按要求向右移动指定位数 直接把低位移走, 如果是带符号数 高位补符号位(负数补1, 正数补0) 如果是无符号数,直接高位补0 对数据逐位进行操作 在非负数进行操作的情况下, 右移n位就相当于除以2n 思考:如何把无符号char类型的数据对应的十六进制、十进制、八进制、二进制给输出? unsigned char val ; scanf(“%hhu” , &val ); printf(“ 0x%hhx , %hhu , 0%hho ”, val , val , val );二进制数: 1)用整除、模除2的方式 2)利用位与、位移操作得到各二进制的值 位异或 ^ 位反 ~ 其它运算符
“经验是茶,需要您去品!”如果您认为我写得还不错,请在页面上点击“红心”支持我,点击“月票投票”投我一票,如果您有疑问,请在页面下方评论框中指出,谢谢。