------<a href="http://www.itheima.com" target="blank">Java培训、Android培训、iOS培训、.Net培训</a>、期待与您交流! -------
long long a=1; char b = 2; int c =3; printf("%ld%d%d",a,c,b);
char类型和int类型的都是用%d的
在64位环境下,xcode . char类型1字节,short 2字节 , int 4字节, long 8字节,long long 8字节。
其实4字节以下的都用%d的原因是编译器把参数里的char short 都拉长到4字节,也就是做了转换,成int类型。
-----------------------------------------------------------------------------------------------------------
我发现C语言的常数默认是int类型。
常数和常数运算还是常数,所以如果
2147483647+2147483647 这是int最大整数
会溢出,得到-2,如果是64位的long 就不会是-2,再如果是unsinged int 得到的也是
4294967294。
-----------------------------------------------------------------------------------------------------------
<pre name="code" class="objc">int copy_something(char *buf, int len) { #define MAX_LEN 256 char mybuf[MAX_LEN]; if(len > MAX_LEN){ // <---- [1] return -1; } return (int)memcpy(mybuf, buf, len); } int main() { char s[]="abc"; copy_something(s,3);//运行正常 copy_something(s,600);//因为函数里有if(len > MAX_LEN)成立,所以返回-1,不复制 copy_something(s,-99);//运行这里程序会输出Abort trap: 6 跳出 return 0; }
当输入-99时,函数里的判断没成立,所以没有及时退出。
memcpy接受的len参数是size_t,也就是unsinged int ,所以len传到memcpy就变成正数
因为int的-99,如果用无符号表示就是超大正数。mybuff后面的数据会被重写,因为把一个超长的字符串写进去了。
当一个有符号数和无符号数运算,有符号数会转成无符号数参与运算。
-----------------------------------------------------------------------------------------------------------
4.9 移位运算符
两个原因会令使用移位运算符的人感到烦恼:
在右移运算中,空出的位是用0填充还是用符号位填充?
移位的数量允许使用哪些数?
第一个问题的答案很简单,但有时是实现相关的。如果要进行移位的操作数是无符号的,会移入0。如果操作数是带符号的,则实现有权决定是移入0还是移入符号位。如果在一个右移操作中你很关心空位,那么用unsigned来声明变量。这样你就有权假设空位被设置为0。
第二个问题的答案同样简单:如果待移位的数长度为n,则移位的数量必须大于等于0并且严格地小于n。因此,在一次单独的操作中不可能将所有的位从变量中移出。
例如,如果一个int是32位,且n是一个int,写n << 31和n << 0是合法的,但n << 32和n << -1是不合法的。
注意,即使实现将符号为移入空位,对一个带符号整数的右移运算和除以2的某次幂也不是等价的。为了证明这一点,考虑(-1) >> 1的值,这是不可能为0的。[译注:(-1) / 2的结果是0。]
http://www.amobbs.com/thread-4630924-1-1.htmlc语言陷阱
------<a href="http://www.itheima.com" target="blank">Java培训、Android培训、iOS培训、.Net培训</a>、期待与您交流! -------