黑马程序员_C语言进制学习

来源:互联网 发布:vissim交通仿真软件 编辑:程序博客网 时间:2024/06/03 03:54
---------------------- ASP.Net+Unity开发、.Net培训、期待与您交流! ----------------------




1. printf 函数 参数说明
 1.1 %d 按整型数据输出
 1.2 %ld 按照长整型数据输出
 1.3 %x 按照十六进制输出
 1.4 %s 按照字符串输出
 1.5 %o 按照八进制输出
 1.6 %p 按照指针形式输出
 1.7 %c 按照char字节输出
 1.8 %u 按照无符号十进制整数形式输出
 1.9 %f 以小数形式输出单、双精度数输出




2. 各种进制
 2.1默认就是10进制
     int num =12;
 2.2 在前面加上一个0就代表八进制
     int num1 =014;
 2.3 在数值前面加上0b就代表二进制
     int num2 =0b1100;
 2.4 在数值前面加上0x就代表十六进制
     int num3 =0xc;


3. 十进制转二进制原理
比如 302
302/2 = 151 余0 
151/2 = 75 余1 
75/2 = 37 余1 
37/2 = 18 余1 
18/2 = 9 余0 
9/2 = 4 余1 
4/2 = 2 余0 
2/2 = 1 余0 
换成二进制就是:100101110 


4. 二进制转十进制原理
比如 01101011
        第0位:1乘20次方=1 
        1乘2的1次方=2 
        0乘2的2次方=0 
        1乘2的3次方=8 
        0乘2的4次方=0 
        1乘2的5次方=32 
        1乘2的6次方=64 
        0乘2的7次方=0 
1+2+0+8+0+32+64+0=107. 
        二进制01101011=十进制107.


5. 下面是一些基本知识
   // 自动类型转换(double --> int)
    int a1 = 10.8;
    // 强制类型转换(double --> int)
    int b1 = (int) 10.8;
    
    // 自动类型提升,(int --> double )
    double c = 10.6 + 8; // 这个8会自动转换为double类型
    printf("%f\n",c);
    
    // 复合赋值运算符: *=  +=  /=  -= %=
    a*=5; // a = a * 5;
    a+=5; // a = a + 5;
    a/=5; // a = a / 5;
    a-=5; // a = a - 5;
    a%=5; // a = a % 5;
    
    // 自增自减运算符 ++ --
    a++; // 这表示后置运算符
    a--;
    
    --a;//这表示前置运算符
    a--;
    // 前置 和 后置 运算符的区别就是,前置运算符在参加运算的时候,会先计算自己
    // 比如:
    int a = 3;
    int b = 3;
    printf("%d",a++);// 这句话会打印出4
    printf("%d",++b);// 这句话会打印出4
    
    // scanf 让用户输入一个数字给一个变量
    // 看例子:
    int a;
    printf("请输入一个数字:\n");
    scanf(&a);// 这里一定要加&号,表示取这个变量的内存地址
    
    // gets 让用户输入一个字符串给一个变量
    // 看例子:
    char buff[1024] = {0};
    float f=12.2f;
    gets(&buff);
    
    // printf 里的参数详解
    // printf("%d",a);// %d表示打印出十进制数字
    // printf("%X",a);// %X表示打印出十六进制数字
    // printf("%o",a);// %o表示打印出八进制数字
    // printf("%s",buff);//%s表示打印出数字
    // printf("%f",f);//%f表示打印出浮点数
    
    
    // sizeof 的使用,sizeof可以计算出一个类型所占用的内存字节数大小
    
    int size = sizeof(double); //8
    int size1 = sizeof(int); //4
    int size2 = sizeof(float); //4
    // 还可以这样使用:
    printf("a变量所占用的字节数==%d\n",sizeof(a));
    
    
    // C语言里面的真假判断
    // C语言里面的非0都表示真
    if(-1)
    {
        printf("我是真");
    }
    if(0)
    {
        printf("我是假");
    }
    
    // 关系运算符,比较大小,  > < >= <= !=
    if (a > b) {
        printf("a比b大");
    }
    if (a => b) {
        printf("a等于或者大于b");
    }
    if (a < b) {
        printf("a比b小");
    }
    if (a <= b) {
        printf("a等于b或者小于b");
    }
    if (a != b) {
        printf("a不等于b");
    }
    
    // ()号优先级运算
    int a = 2+2*5;
    // 我们可以给这个2+2可以括起来,这样就可以先计算这两个数的和
    int a = (2+2)*5;
    
    // 逻辑运算符 && 与 ||   !(取反运算符)
    // && 的作用表示同时成立才为真
    // || 表示 有一个成立就为真
    if (1==1 && 2==1) {
        printf("&&条件成立");
    }
    if (1==1 || 2==1) {
        printf("||条件成立");
    }
    if (!1) { // 这个时候!表示取反,1为真,使用!表示取反,则为假
        printf("!条件成立");
    }
    
    // 三目运算符
    int a = 2>3?1:2;//如果2>3那么就给a赋值为1,否则赋值为2
    
    // 无符号整数类型与有符号整数类型
    // unsigned 表示无符号整数类型,32个字节,他不能表示整数
    // signed 表示无符号整数类型,32个字节,他的最高位用来表示正数和负数,正数的最高位是1,负数的最高位为0
    // 如果不像下面这样显示的声明,那么他就默认表示 signed
    unsigned int a = 3;
    signed int b = 3;
    
    
    
    // 位运算符, 直接对二进制位进行操作
    // & 如果两个位等于1,那么他就等于1
    // | 如果两个位有一个为1,那么他就等于1
    // ^ 两个位不相同的时候为1,否则为0
    // ~ 按位取反,每个二进制取反
    // >>  右移运算符
    // <<  左移运算符
    int a = 22; // 10110  ,前面的0省略
    int b = 33; // 10001
    int c = a & b; // 相当于10110
                           10001
     ---------------------------------
                           10000
    
    int c = a | b; // 相当于  10110
                             10001
    ---------------------------------
                             10111
    
    
    int c = a ^ b; // 相当于  10110
                             10001
    ---------------------------------
                             00111
    
    a = ~a;// 相当于          10110
    ---------------------------------
                             01001
    
    a = a << 2;// 相当于          10110
    ---------------------------------
                             1011000
    
    a = a >> 2;// 相当于          10110
    ---------------------------------
                                 00101
    
    return 0;





 ---------------------- ASP.Net+Unity开发、.Net培训、期待与您交流! ---------------------- 
0 0