关于学习NDK基础知识这些就够了(六)
来源:互联网 发布:港澳游怎么样知乎 编辑:程序博客网 时间:2024/05/18 02:23
最近一直没有更新我的博客,因为我也是初步进行学习,感觉这一块的东西有点摸不着头脑,而且最近一直在加班,不过今天我仔细捋了捋,将以下知识点写出来。
1、联合体(共用体):
关键字:union
不同类型的变量共同占用一段内存(相互覆盖),联合变量任何时刻只有一个成员存在,节省内存
联合体变量的大小=最大的成员所占的字节数:
union MyValue{ int x; int y; double z;};//这段代码中,我们的联合体的大小为最大成员所占的字节数,int(4字节)double(8字节),所以我们这个联合体的大小就是8字节,这个是为了更加的节省内存的开销void main(){ union MyValue d1; d1.x = 90; d1.y = 100; //最后一次赋值有效 //d1.z = 23.8; printf("%d,%d,%lf\n",d1.x,d1.y,d1.z); system("pause");}//这里,我们一共进行了三次赋值,但是只有第三次的赋值赋值成功了,第一次和第二次的赋值都被顶掉了,因为他们公用一块内存typedef union jvalue { jboolean z; jbyte b; jchar c; jshort s; jint i; jlong j; jfloat f; jdouble d; jobject l;} jvalue;//这段代码我们用了一个别名可以代表很多类型
2、枚举
关键字:enum
和java中的枚举差不多,作用就是限定值,保证取值的安全性
enum Day{ Monday,//默认为1 Tuesday,//默认为2 Wednesday,//默认为3 Thursday,//默认为4 Friday,//默认为5 Saturday,//默认为6 Sunday//默认为7 //这些值都可以进行更改};void main(){ //枚举的值,必须是括号中的值 enum Day d = Monday; printf("%#x,%d\n",&d,d); getchar();}
3、IO流
这个我觉得不需要太多的解释了,和我们java中的IO流其实是差不多的
直接看代码
读取文本文件:
void main(){ char *path = "E:\\dongnao\\vip\\ndk\\08_08_C_05\\files\\friends.txt"; //打开 FILE *fp = fopen(path,"r");//注意这里的“r”,r为读w为写 if (fp == NULL){ printf("文件打开失败..."); return; } //读取 char buff[50]; //缓冲 while (fgets(buff,50,fp)){ printf("%s",buff); } //关闭 fclose(fp); system("pause"); getchar();}
写入文本文件
void main(){ char *path = "E:\\dongnao\\vip\\ndk\\08_08_C_05\\files\\friends_new.txt"; //打开 FILE *fp = fopen(path, "w"); char *text = "hchmily@sina.com,程华才,学清路 8\n号科技财富中心 A"; fputs(text,fp); //关闭流 fclose(fp); getchar();}
文件复制
void main(){ char *read_path = "E:\\dongnao\\vip\\ndk\\08_08_C_05\\files\\liuyan.png"; char *write_path = "E:\\dongnao\\vip\\ndk\\08_08_C_05\\files\\liuyan_new.png"; //读的文件 b字符表示操作二进制文件binary FILE *read_fp = fopen(read_path, "rb"); //写的文件 FILE *write_fp = fopen(write_path, "wb"); //复制 int buff[50]; //缓冲区域 int len = 0; //每次读到的数据长度 while ((len = fread(buff, sizeof(int), 50, read_fp)) != 0){ //将读到的内容写入新的文件 fwrite(buff,sizeof(int),len,write_fp); } //关闭流 fclose(read_fp); fclose(write_fp); getchar();}
获取文件的大小
void main(){ char *read_path = "E:\\dongnao\\vip\\ndk\\08_08_C_05\\files\\liuyan.png"; FILE *fp = fopen(read_path, "r"); //重新定位文件指针 //SEEK_END文件末尾,0偏移量 fseek(fp,0,SEEK_END); //返回当前的文件指针,相对于文件开头的位移量 long filesize = ftell(fp); printf("%d\n",filesize); getchar();}
注意:
1、计算机的文件存储在物理上都是二进制
2、文本文件和二进制之分,其实是一个逻辑之分
3、C读写文本文件与二进制文件的差别仅仅体现在回车换行符
4、写文本时,每遇到一个’\n’,会将其转换成’\r\n’(回车换行)
5、读文本时,每遇到一个’\r\n’,会将其转换成’\n’
阅读全文
0 0
- 关于学习NDK基础知识这些就够了(六)
- 关于学习NDK基础知识这些就够了(一)
- 关于学习NDK基础知识这些就够了(二)
- 关于学习NDK基础知识这些就够了(三)
- 关于学习NDK基础知识这些就够了(四)
- 关于学习NDK基础知识这些就够了(五)
- 关于学习NDK基础知识这些就够了(七)
- ES6这些就够了
- ES6这些就够了
- ES6这些就够了
- Swift3.0 关于reduce函数,知道这些就够了
- 入门机器学习,看这些材料就够了
- retrofit详细教程(有这些就够了)
- makefile掌握这些就够了
- 前端sublime-text3 这些就够了
- git,掌握这些就够了
- vim编辑器会这些就够了
- 关于地产信息化“大佬”们说了什么?看完这些就够了
- Java8接口变化-静态方法&默认方法
- 拓扑排序
- CentOS7安装mono
- 如何使用C语言实现递归调用
- Windows服务安装异常:System.Security.SecurityException: 未找到源,但未能搜索某些或全部事件日志。不可 访问的日志: Security
- 关于学习NDK基础知识这些就够了(六)
- psql命令
- 写QT程序遇到的一些麻烦的解决方法
- 数字三角形II
- 实验吧ctf-web题:简单的sql注入
- 兔子与星空&&丛林中的路
- 合唱团-网易python
- 二叉搜索树的后序遍历序列
- [[Prototype]]--浅析