C语言总结_2.符号

2.符号

  • 注释
    1.注释不可以嵌套,因为/总是与离它最近的/匹配。
    2.编译器预处理时会将注释剔除,用空格代替原来的注释。
    3.只要斜杠( /)和星号( *)之间没有空格,都会被当作注释的开始。
    4.注释的位置应与被描述的代码相邻,可以与语句在同一行,也可以在上行,但不可放在下方。

  • 接续符和转义符
    1.C 语言里以反斜杠( \)表示断行。编译器会将反斜杠剔除掉,跟在反斜杠后面的字符
    动接续到前一行。但是注意:反斜杠之后不能有空格,反斜杠的下一行之前也不能有空格。
    2.反斜杠除了可以被用作接续符,还能被用作转义字符的开始标识

  • 单引号、双引号
    双引号引起来的都是字符串常量,单引号引起来的都是字符常量。
    eg:1,‘ 1‘,“ 1”。
    第一个是整形常数, 32 位系统下占 4 个 byte;
    第二个是字符常量,占 1 个 byte;
    第三个是字符串常量,占 2 个 byte。

  • 逻辑运算符
    短路原则

    int i=0;
    int j=0;
    if((++i>0)||(++j>0))
    {
    //打印出 i 和 j 的值。
    }
    结果:i=1;j=0。
  • 位运算符
    1.包括:& 按位与 | 按位或 ^ 按位异或 ~ 取反 << 左移 >> 右移
    2.左移和右移
    左移运算符“<<”是双目运算符。其功能把“<< ”左边的运算数的各二进位全部左移若干
    位,由“<<”右边的数指定移动的位数,高位丢弃,低位补 0。
    移运算符“>>”是双目运算符。其功能是把“>> ”左边的运算数的各二进位全部右移若
    干位, “>>”右边的数指定移动的位数。但注意:对于有符号数,在右移时,符号位将随同
    移动。当为正数时, 最高位补 0;而为负数时,符号位为 1,最高位是补 0 或是补 1 取决
    于编译系统的规定。 Turbo C 和很多系统规定为补 1
    3.应用:实现不用第三个临时变量交换两个变量的值:
     1.加减操作 a=a+b; b=a-b; a=a-b;
     2.按位异或操作 a ^= b; b ^= a;a ^= b

  • 运算符优先级 P60
    简单:单目运算符 > 算术运算符 > 关系运算符 > 位运算符 > 逻辑运算符 > 赋值运算符
    单目运算符、赋值运算符和三目运算符从右到左,双目运算符从左到右

  • i++,++i 运算符
    eg:
    1.int i = 3;
    ( ++i) +( ++i) +( ++i);
    解析:有点编译器计算出来为 18,因为 i 经过 3 次自加后变为 6,然后 3 个 6 相加得 18;
    而有的编译器计算出来为 16(比如 Visual C++6.0),先计算前两个 i 的和,这时候 i 自加两次, 2 个 i 的和为 10,然后再加上第三次自加的 i 得 16。
    2.
    A) j =(i++,i++,i++);
    B) for( i=0;i<10;i++) {  //code } C)  k = ( i++) + ( i++) + ( i++); 解析:a 结果为 2例子为逗号表达式,i 在遇到每个逗号后,认为本计算单位已经结束,i 这时候自加,逗号运算符以最后一个为所要赋的值 b 结果为 10 c 结果为 0 遇到分号才认为要++,应理解为三个i相加 3.
    for( i=0, printf( “ First=%d”, i) ;
    i<10, printf( “ Second=%d”, i) ;
    i++, printf( “ Third=%d”, i))
    {
      printf( “ Fourth=%d”, i);
    }

    解析:结果无限死循环,循环条件i<10,逗号表达式以最后一个为返回值,printf的返回值为输出字符的个数,是一个整型值。去掉second语句,则正常输出。
    4.++i+++i+++i 和 a+++++b 的括号问题
    解析: 贪心法。
    C 语言有这样一个规则:每一个符号应该包含尽可能多的字符。也就是说,编译器将程
    序分解成符号的方法是,从左到右一个一个字符地读入,如果该字符可能组成一个符号,
    那么再读入下一个字符,判断已经读入的两个字符组成的字符串是否可能是一个符号的组
    成部分;如果可能,继续读入下一个字符,重复上述判断,直到读入的字符组成的字符串
    已不再可能组成一个有意义的符号。
<think>好的,我现在需要解决用户的问题:C语言中-15的8位二进制补码存储形式,以及具有相同存储形式的二进制数对应的十进制值。首先,我要回顾一下补码的相关知识,确保自己理解正确。 根据引用[1],负数的补码是其原码各位取反(符号位除外)再加1。所以,我需要先写出-15的原码,再转换为补码。 -15的原码应该是符号位为1,其余位为绝对值的二进制。15的二进制是0001111,所以8位原码是10001111。接下来,取反符号位以外的位,得到11110000,再加1,得到补码11110001。所以,-15的补码应该是11110001。 接下来,用户还问相同存储形式的十进制数值。这里需要注意,当这个补码被当作无符号数解释时,它的值是多少。11110001转换成十进制是1*128 + 1*64 + 1*32 + 1*16 + 0*8 + 0*4 + 0*2 + 1*1 = 241。因此,这个二进制数作为无符号数时,对应的十进制是241。 不过,我需要确认是否正确。比如,引用[2]中提到补码的范围,8位补码的范围应该是-128到127。而241超过了127,所以作为有符号数,它会被解释为负数。根据补码的转换规则,241的二进制确实是11110001,对应的负数可以通过补码转换回来:取反加1。即11110001取反是10001110,加1得10001111,即-15,所以作为有符号数时确实是-15,而无符号数是241。 另外,用户可能存在的疑问是,为什么同样的二进制数可以代表不同的十进制值,这取决于如何解释它(有符号还是无符号)。引用[3]中的代码可以输出二进制补码,帮助验证结果是否正确。 总结:-15的8位补码是11110001,相同二进制作为无符号数的十进制是241。</think>### 分步解答 #### 第一步:求-15的原码 原码由符号位(最高位)和数值位组成: - 正数15的二进制形式为$0001111$ - 8位原码形式为$1$(符号位)$0001111$(数值位),即$10001111$ #### 第二步:原码转补码 根据补码规则: 1. **保留符号位**,其他位取反:$11110000$ 2. **加1**得到补码:$11110001$ 因此,-15的8位补码为$11110001$[^1][^2]。 #### 第三步:相同存储形式的十进制数值 将补码$11110001$视为**无符号整数**时: $$ 1 \times 2^7 + 1 \times 2^6 + 1 \times 2^5 + 1 \times 2^4 + 0 \times 2^3 + 0 \times 2^2 + 0 \times 2^1 + 1 \times 2^0 = 241 $$ #### 最终答案 1. **-15的8位补码**:$11110001$ 2. **相同二进制对应的无符号十进制值**:241 --- ### 验证方法 通过C语言代码输出验证: ```c #include <stdio.h> void print_binary(int n) { for(int i=7; i>=0; i--) putchar((n & (1<<i)) ? '1' : '0'); } int main() { int x = -15; unsigned char y = x; // 截断为8位 printf("补码形式:"); print_binary(y); printf("\n无符号值:%d", y); return 0; } ``` 运行结果: ``` 补码形式:11110001 无符号值:241 ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值