JNI

什么是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] <=> buf

      printf("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
  • 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);//自己申请,还需要自己释放 

需要补录

你可能感兴趣的:(JNI)