C语言学习笔记
2016-01-04 15:19
330 查看
基本数据类型的精度:
char 1字节
short 2字节
int 4字节
long 8字节
float 4字节
double 8字节
float和double默认保留小数点多少位?为什么?
float类型数据在内存中占4个字节,2^16,其中符号位1位,指数位8位,尾数23位,小数点后保留6位
double类型数据在内存中占8个字节,2^32,小数点后保留16位。
取余运算 结果的正负性只看左边,例:
-3%5=-3 5%-2=5
浮点数不能取余
++ —-
浮点数、char都可以自增自减
char 为1个字节
不要在scanf函数里输入\n换行符
day03
逻辑运算符|| 断路问题 前面为真 后面的表达式就不再判断
sizeof(int) 实际是unsignded long类型
sizeof(char类型的常量)占4个字节,因为char类型的常量在内存中时当int类型存储的
!取反运算符的优先级比算数运算符高
在面对需要输入char类型的数据时,千万要注意缓冲区的问题
解决办法,在%c前面+空格
C语言中/运算,得到的结果和正常除运算不同,例如1/2的结果不是0.5,而是0,即取了整数部分。1.00/2的结果才是0.50
,总而言之,要得到一个浮点型的结果,参与运算的一个数必须为浮点数。
数组篇
数组作为函数参数,可以省略元素个数
数组作为函数参数,传递是整个数组的地址,修改函数形参数组元素的值,会影响到外面的实参数组
数组当做函数参数传递时,会当做指针变量来使用,指针变量在64bit编译器环境下,占据8个字节
例:
void printElement(int arr[]){
int length=sizeof(arr);
printf("数组长度为:%d\n",length);
for (int i=0; i<length; i++) {
printf("a[i]=%d ",arr[i]);
}
}
int main(int argc, const char * argv[]) {
// insert code here...
int a[6]={66666,5555,4444,333,22,1};
printf("排序前的数组为\n");
printElement(a);
return 0;
}
排序前的数组为
数组长度为:8
a[i]=66666 a[i]=5555 a[i]=4444 a[i]=333 a[i]=22 a[i]=1 a[i]=-862682905 a[i]=905990086
为什么会出现上面的现象?
因为数组作为函数参数传递,会当作指针变量使用,指针长度为8
a=97 A=65
产生随机数
int num = arc4random_uniform(11)
取极小数和极大数
int max = INT32_MIN; //用一个极度小的数
int min = INT32_MAX; //用一个极度大的数
<limits.h>
char 1字节
short 2字节
int 4字节
long 8字节
float 4字节
double 8字节
float和double默认保留小数点多少位?为什么?
float类型数据在内存中占4个字节,2^16,其中符号位1位,指数位8位,尾数23位,小数点后保留6位
double类型数据在内存中占8个字节,2^32,小数点后保留16位。
取余运算 结果的正负性只看左边,例:
-3%5=-3 5%-2=5
浮点数不能取余
++ —-
浮点数、char都可以自增自减
char 为1个字节
不要在scanf函数里输入\n换行符
day03
逻辑运算符|| 断路问题 前面为真 后面的表达式就不再判断
sizeof(int) 实际是unsignded long类型
sizeof(char类型的常量)占4个字节,因为char类型的常量在内存中时当int类型存储的
!取反运算符的优先级比算数运算符高
在面对需要输入char类型的数据时,千万要注意缓冲区的问题
解决办法,在%c前面+空格
C语言中/运算,得到的结果和正常除运算不同,例如1/2的结果不是0.5,而是0,即取了整数部分。1.00/2的结果才是0.50
,总而言之,要得到一个浮点型的结果,参与运算的一个数必须为浮点数。
数组篇
数组作为函数参数,可以省略元素个数
数组作为函数参数,传递是整个数组的地址,修改函数形参数组元素的值,会影响到外面的实参数组
数组当做函数参数传递时,会当做指针变量来使用,指针变量在64bit编译器环境下,占据8个字节
例:
void printElement(int arr[]){
int length=sizeof(arr);
printf("数组长度为:%d\n",length);
for (int i=0; i<length; i++) {
printf("a[i]=%d ",arr[i]);
}
}
int main(int argc, const char * argv[]) {
// insert code here...
int a[6]={66666,5555,4444,333,22,1};
printf("排序前的数组为\n");
printElement(a);
return 0;
}
排序前的数组为
数组长度为:8
a[i]=66666 a[i]=5555 a[i]=4444 a[i]=333 a[i]=22 a[i]=1 a[i]=-862682905 a[i]=905990086
为什么会出现上面的现象?
因为数组作为函数参数传递,会当作指针变量使用,指针长度为8
a=97 A=65
产生随机数
int num = arc4random_uniform(11)
取极小数和极大数
int max = INT32_MIN; //用一个极度小的数
int min = INT32_MAX; //用一个极度大的数
<limits.h>
相关文章推荐
- C++入门(8):类的继承(1)
- C语言如何 计算程序运行时间?
- GB2312中汉字字符的编码在C语言中的输出测试
- QML解析C++的QVariantList、QVariantMap
- C语言概述【重学C之一】
- c语言中同一函数下不可以重复定义变量
- 整数变换问题和N皇后问题解析(C语言)
- c语言中数组中的地址和指针的关系
- C++界面库
- 利用C++11实现一个自动注册的工厂
- C++ friend keyword
- C语言项目答辩总结
- C++ 11 可变参数宏结合可变参数模板使用!
- C++ string 用法詳解
- c++静态成员变量的使用
- 分享C++寫blueprint block的方法
- 两条未知曲线,求其最短距离
- 介绍Unreal Engine 4中的接口(Interface)使用C++和蓝图
- c++中this指针的用法小结
- 将那些对称的字符串按从小到大的顺序输 出。字符串先以长度论大小,如果长度相同,再以 ASCII 码值为排序标准。