C语言学习笔记——2(数据类型,运算符)
数据类型机器中每个字节都有地址CPU通过地址访问字节空间#include stdio.h int main() { int a 0xEEAABAAA; printf(%#x, %d\n,a,a); unsigned int b 0xEEAABAAA; printf(%#x, %u\n,b,b); return 0; }运行结果0xeeaabaaa, -290800982 0xeeaabaaa, 4004166314整数数据类型ai总结*注long类型在32位系统中为4字节在64位Linux/macOS中为8字节在64位Windows中为4字节#include stdio.h #include limits.h int main() { printf(char:%d---%d, %ld \n,SCHAR_MIN,SCHAR_MAX,sizeof(char)); printf(short:%d---%d, %ld \n,SHRT_MIN,SHRT_MAX,sizeof(short)); printf(int:%d---%d, %ld \n,INT_MIN,INT_MAX,sizeof(int)); printf(long:%ld---%ld, %ld \n,LONG_MIN,LONG_MAX,sizeof(long)); return 0; }运行结果char:-128---127, 1 short:-32768---32767, 2 int:-2147483648---2147483647, 4 long:-9223372036854775808---9223372036854775807, 8sizeof单位返回的是字节数byte八位一个字节不需要括号对变量名使用时可以省略括号但对类型名必须使用括号字符型计算机如何处理字符计算机存储数据是01二进制数据计算机存储字符数据也需要把字符数据按照特定的编码格式转换成二进制数据进行存储。ASCII字符数据在机器内也被变换成二进制编码的形式。国际上普遍采用的一种编码是美国国家信息交换标准代码简称ASCII字符数据类型1.char类型字节大小1字节8位取值范围signed char-128 ~ 127unsigned char0 ~ 2552的八次方默认情况char可能是有符号或无符号取决于编译器和平台注意字符常量要用单引号括起来也可以用字符对应的ASCII码值进行赋值;printf对应的格式符是%c2.列出常见ascll字符十进制字符十进制048空格32A65a973. ASCII码规律数字字符0-9 连续值48-57大写字母A-Z 连续值65-90小写字母a-z 连续值97-122大小写转换同一字母的大小写相差32大写 → 小写32小写 → 大写-324.代码练习大小写字母转换#include stdio.h int main() { int a97; char AA; printf(a%c32\n,a-32); printf(A%c-32\n,A32); return 0; }运行结果aA32 Aa-32数字的整数类型和字符类型#include stdio.h int main() { char a 1; int b2; printf(1---ASCII:%d,字符表示%c\n,a,a); printf(2---ASCII:%d,字符表示%c\n,b48,b48); }运行结果1---ASCII:49,字符表示1 2---ASCII:50,字符表示2字节序小字节序低位数据在低地址大字节序低位地址在高地址比如int a0x12345678,一共四字节78属于低位数据小字节序大字节序运算符一、算术运算符1. 基本算术运算符运算符名称示例说明加法a b两数相加-减法a - b两数相减*乘法a * b两数相乘/除法a / b两数相除%取模取余a % b求两数相除的余数2. 除法运算的特殊性#include stdio.h int main() { // 情况1两端都是整数 → 整数除法截断小数部分 int a 7, b 2; printf(7 / 2 %d\n, a / b); // 输出: 3 // 情况2至少一端是浮点数 → 浮点数除法 float c 7.0, d 2; printf(7.0 / 2 %f\n, c / d); // 输出: 3.5 return 0; }3. 取模运算%#include stdio.h int main() { printf(7 %% 3 %d\n, 7 % 3); // 1 printf(-7 %% 3 %d\n, -7 % 3); // -1 printf(7 %% -3 %d\n, 7 % -3); // 1 printf(-7 %% -3 %d\n, -7 % -3); // -1 return 0; }4. 应用示例示例1判断闰年#include stdio.h int main() { int year; printf(请输入年份: ); scanf(%d, year); // 闰年条件能被4整除但不能被100整除或者能被400整除 if ((year % 4 0 year % 100 ! 0) || year % 400 0) { printf(%d年是闰年\n, year); } else { printf(%d年不是闰年\n, year); } return 0; }示例2分离数字数码管显示#include stdio.h int main() { int num 1234; // 分离各位数字 int thousand num / 1000; // 千位: 1 int hundred (num % 1000) / 100; // 百位: 2 int ten (num % 100) / 10; // 十位: 3 int unit num % 10; // 个位: 4 printf(数字: %d\n, num); printf(千位: %d\n, thousand); printf(百位: %d\n, hundred); printf(十位: %d\n, ten); printf(个位: %d\n, unit); return 0; }二、关系运算符1. 基本关系运算符运算符名称示例说明大于a b判断a是否大于b小于a b判断a是否小于b大于等于a b判断a是否大于等于b小于等于a b判断a是否小于等于b等于a b判断a是否等于b!不等于a ! b判断a是否不等于b2.与的区别#include stdio.h int main() { int a 5; int b 3; // 常见错误误把 写成 if (a 10) { // 这是赋值不是比较a被赋值为10表达式值为10非零条件为真 printf(这个总是会执行\n); } // 正确写法 if (a 10) { // 比较a是否等于10 printf(a等于10\n); } // 防御性编程常量放左边 if (10 a) { // 如果把 误写为 编译器会报错 printf(a等于10\n); } // 变量与变量比较无法防御 if (a b) { printf(a等于b\n); } return 0; }3. 连续比较的陷阱#include stdio.h int main() { int a 3; // 数学写法1 a 5 // C语言错误写法 if (1 a 5) { // 实际执行(1 a) 5 printf(这总是会执行为什么\n); } // 解释 // 1 a 结果为 1真 // 然后 1 5 结果为 1真 // 正确写法使用逻辑运算符 if (1 a a 5) { printf(a在1和5之间\n); } // 判断a是否在范围[1, 5]之外 if (a 1 || a 5) { printf(a不在1到5之间\n); } return 0; }三、逻辑运算符1. 基本逻辑运算符运算符名称示例说明逻辑与a ba和b都为真时结果为真||逻辑或a || ba或b至少一个为真时结果为真!逻辑非!aa为假时结果为真四、赋值运算符1. 简单赋值#include stdio.h int main() { // 基本赋值形式 int a; a 10; // 变量 常数 printf(a %d\n, a); int b a; // 变量 变量 printf(b %d\n, b); int c a b * 2; // 变量 表达式 printf(c %d\n, c); // 连续赋值 int x, y, z; x y z 100; // 从右向左结合: z100, yz, xy printf(x%d, y%d, z%d\n, x, y, z); return 0; }2. 复合赋值运算符运算符等价形式示例a a ba 3-a a - ba - 3*a a * ba * 3/a a / ba / 3%a a % ba % 3a a ba 3|a a | ba | 3^a a ^ ba ^ 3a a ba 3a a ba 3#include stdio.h int main() { int a 10; a 5; // a a 5 → 15 printf(a 5: %d\n, a); a - 3; // a a - 3 → 12 printf(a - 3: %d\n, a); a * 2; // a a * 2 → 24 printf(a * 2: %d\n, a); a / 4; // a a / 4 → 6 printf(a / 4: %d\n, a); a % 4; // a a % 4 → 2 printf(a %% 4: %d\n, a); return 0; }3. 自增自减运算符运算符名称示例说明自增a或a变量值增加1--自减a--或--a变量值减少1前缀与后缀的区别c #include stdio.h int main() { int a, b; printf( 自增自减运算符 \n\n); // 示例1前缀自增 a 5; b a; // 先增加a再赋值给b printf(b a; 执行后: a%d, b%d\n, a, b); // a6, b6 // 示例2后缀自增 a 5; b a; // 先赋值给b再增加a printf(b a; 执行后: a%d, b%d\n, a, b); // a6, b5 // 示例3前缀自减 a 5; b --a; // 先减少a再赋值给b printf(b --a; 执行后: a%d, b%d\n, a, b); // a4, b4 // 示例4后缀自减 a 5; b a--; // 先赋值给b再减少a printf(b a--; 执行后: a%d, b%d\n, a, b); // a4, b5 return 0; }五、位运算符1. 基本位运算符运算符名称示例说明按位与a b两位都为1时结果为1|按位或a | b两位至少一个为1时结果为1^按位异或a ^ b两位不同时结果为1~按位取反~a0变11变0左移a n所有位左移n位右侧补0当于数值扩大为原来的倍。右移a n所有位右移n位左侧补符号位或0,当于数值缩小为原来的倍。2. 位运算详解#include stdio.h int main() { unsigned char a 0x3A; // 二进制: 00111010 unsigned char b 0x1F; // 二进制: 00011111 // 按位与 printf(a b 0x%02X\n, a b); // 00111010 // 00011111 // -------- // 00011010 0x1A // 按位或 | printf(a | b 0x%02X\n, a | b); // 00111010 // 00011111 // -------- // 00111111 0x3F // 按位异或 ^ printf(a ^ b 0x%02X\n, a ^ b); // 00111010 // 00011111 // -------- // 00100101 0x25 // 按位取反 ~ printf(~a 0x%02X\n, ~a 0xFF); // 掩码确保只显示8位 // 00111010 // -------- // 11000101 0xC5 // 左移 printf(a 2 0x%02X\n, a 2); // 00111010 2 11101000 0xE8 // 右移 printf(a 2 0x%02X\n, a 2); // 00111010 2 00001110 0x0E return 0; }六、其他运算符1. 三目运算符条件运算符语法条件 ? 表达式1 : 表达式2#include stdio.h int main() { int a 10, b 20; // 基本用法 int max (a b) ? a : b; //如果ab则maxa,否则maxb printf(最大值: %d\n, max); return 0; }2. 逗号运算符语法表达式1, 表达式2, ..., 表达式n#include stdio.h int main() { // 逗号运算符示例 int a (1, 2, 3, 4, 5); // a 5最后一个表达式的值 printf(a %d\n, a); return 0; }3.sizeof运算符七、运算符优先级
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2472815.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!