什么是JNI
- JNI Java Native interface 一种协议 提供一套编程框架,java和本地代码相互调用
为什么需要JNI
1.操作底层硬件,Android平台上传感器
2.应用程序对运行效率有要求,图形渲染,音视频解码
3.复用成熟C开源软件,OpenGL,OpenSSL,SQLite3,FFmpeg
4.安全性要求,本地C代码反编译困难
C基本数据类型
- c里面char占1byte,而java占2bytes;
*C里面的long占4bytes ,java中占8bytes - c里面没有boolean类型,可以用unsigned char代替
C语言输入输出函数
都需要包含头文件stdio.h
-
格式化输出函数printf d u o x 整数,c s,f
%d 十进制有符号 int
%u 十进制无符号 unsigned int
%o 八进制无符号 unsigned int
%x 十六进制无符号 unsigned int
在%o和%x中间加#,输出前导0,0x
%c 输出一个字符
%s 输出一个字符串,若干个
若要输出long和double类型,在相应字符前l
%ld %lf
输出short类型用%hd
%p输出变量的地址
-
格式化输入函数scanf d c s f
-
输入其它数据
printf("请输入整数:");
scanf("%d",&i);//&i告诉scanf输入数据存到哪 -
输入字符串写法
char buf[10];//字符数组,可以保存字符串 '\0'作为字符串的结束标志
printf("输入字符串:");
scanf("%s",buf);//数组名代表数组首元素首地址 buf[0] &buf[0] <=> bufprintf("buf:%s\n",buf);
-
什么是指针
- 1.内存:最小单位1byte,8bits,一维线性分布
- 32cpu 4G内存的地址空间
1k = 1024bytes 2^10
1M = 1024k = 1024 * 1024 bytess 2^20
1G = 1024M = 1024 * 1024 * 1024 bytes 2^30
4G = 4 * 1G = 2^2 * 2^30 = 2^32
- 32cpu 4G内存的地址空间
- 2.内存单元:通过内存编号来区分管理,内存单元的编号可以作为内存单元的地址
- 3.指针:在C中把内存单元的编号称指针
指针变量
- 普通变量:一般数据
- 指针变量:保存内存单元地址,可以利用指针运算符*访问内存
*的三种应用含义
- 3 * 5 : *剩法
- int *p; : 定义指针变量,区分了变量类型
- *p = i; *取对象运算符
指针的指向
-
指向:如果一个指针变量保存了一个对应类型变量的首地址,指针变量指向这个变量,可以用指针运算符*访问指向变量。
int i = 20; char c = 'k'; int *p; char *q; p = &i;//指针变量p指向i q = &c; //p = &c; //p = (int *)&c;//如果真要保存需要强转 (要转的指针类型) //*p <=> i printf("i = %d\n",*p);
指针
- 地址,指针变量在不影响理解时,都称为指针
指针的误用
- 指针没有合法指向,初始值NULL
- 混用指向不同类型的指针,如果真要把不同类型的地址赋给指针变量,需要强转
关于C字符串存储和操作
- char buf[10];字符数组用来保存字符串;
- char *p = buf;字符指针可以保存字符串首地址,从而找到并处理字符串
指针变量运算
- 指针变量加减一个整数n,指针向高地址或低地址移动n个对象,要求在一段连续内存空间上移动
数组
数组:相同数据类型变量的集合。
-
C不会检查数组下标越界!!!
int arr[20]; arr[19];
数组的特点:
1.元素数据类型相同
2.元素在内存中连续的
3.数组名代表首元素首地址 arr <=> &arr[0]
指针与数组的关系
a[i] <=> *(a + i) <=> *(p + i) <=> p[i]
p[i] => *(p + i)
堆区内存的申请及释放
int *pid = (int *)malloc(num * sizeof(int)); //在堆区分配学生学号数组
pid = (int *)realloc(pid,num * sizeof(int));
free(pid);//自己申请,还需要自己释放