C语言简介

system()是提供C语言调用系统命令的函数

C语言基本数据类型

C语言中的整数类型:char/short/int/long

C中使用ASCII保存字符,所以char所占用的字节数为1

Java中使用Unicode编码,char所占的字节数为2

C中long类型在32位操作系统中占用4个字节,在64为操作系统中占用8个字节

Java中long类型默认占用8个字节

sizeof()是运算符,用来计算一个类型占的字节数,如果括号内是变量,则计算的是该变量所对应数据类型所占的字节数

signed/unsigned:用来修饰整数类型,表示有符号/无符号,缺省为signed有符号类型,加上该关键字不会影响整数类型所占的字节数

C语言中没有boolean类型,可以使用unsigned char代替

C语言中的float/double类型和Java中的float/double类型所占字节数相同

float:4个字节,4bytes

double:8个字节,8bytes

C语言输入输出函数

都需要包含头文件:stdio.h

格式化输出函数:printf(f代表format)

输出整数:

%d 十进制有符号 int

%u 十进制无符号 unsigned int

%o 八进制无符号 unsigned int

%x 十六进制无符号 unsigned int

%ld    输出long类型
%hd 输出short类型 在%o和%x中间加#,可以输出前导,八进制自动加0,十六进制自动加0x

输出字符:

%c 输出一个字符

%s 输出一个字符串,即若干个字符

输出长整形和浮点数:

%f 输出float类型

%lf 输出double类型

输出变量的内存地址:

%p

备注:C语言中要想输出关键字符,需要重复该字符即可,例如输出%d,使用printf("%%d")

输入函数:

输入普通数据:

scanf("%d",&i); // &i告诉scanf输入的数据存放在哪里,取出变量i的内存地址,并将数据保存到那块内存空间中

输入字符串的写法:

char buf[10];//字符数组,可以保存字符串 '\0'作为字符串的结束标志 默认占一个长度,所以buf[10]中最多保存9个输入的字符

printf("输入字符串:");

scanf("%s",buf);//数组名代表数组首元素首地址 buf[0] &buf[0] <=> buf

printf("buf:%s\n",buf);

备注:数组名代表数组首元素的首地址,等价于&buf[0]

C语言中的指针

号的作用:

1.乘法运算 i
j

2.定义指针变量 int *p; *只是为了区分变量类型,不是普通变量,等价于(int *)p;

3.取对象云算法 *p

指针的指向

如果一个指针变量保存了一个对应类型变量的首地址,指针变量指向这个变量,可以用指针运算符*访问指向变量

指针变量在不影响理解时,都称为指针

指针的误用

1.指针没有合法的指向(野指针),初始值NULL

2.混用指向不同类型的指针,如果真要把不同类型的地址赋给指针变量,需要强转

指针的两个关键属性:地址和(指向)类型

C语言中的引用传递

include <stdio.h>

void swap(int *pa, int *pb) {

printf("swap start\n");

printf("a = %p, b = %p\n", pa, pb);

printf("a = %p, b = %p\n", &pa, &pb);

int temp = 0;

temp = *pa;

*pa = *pb;

*pb = temp;

printf("a = %p, b = %p\n", pa, pb);

printf("a = %p, b = %p\n", &pa, &pb);

printf("swap end\n");

}

int main() {

int a = 10;

int b = 20;

printf("a = %d, b = %d\n", a, b);

printf("a = %p, b = %p\n", &a, &b);

swap(&a, &b);

printf("a = %d, b = %d\n", a, b);

printf("a = %p, b = %p\n", &a, &b);

return 0;

}

输出结果:

结果分析:

通过操作内存地址,交换指向内存的指针,从而达到交换数据的目的

操作内存地址,相当于操作变量

Java中的引用传递,类似于C中的地址传递

通过调用Java中的函数,传递一个对象作为参数,在函数执行过程中,可以修改对象内部的属性数据,在函数执行完毕以后,再读取该数据,就能实现Java的引用传递

关于C字符串存储和操作

C语言中没有字符串类型,需要用字符数组来表示字符串

char buf[10];字符数组用来保存字符串

char *p = buf;字符指针可以保存字符串首地址,从而找到并处理字符串,长度是根据字符串的结束标志'\0'来判断

运算符sizeof()只能获取字符数组所占用的内存空间,而不能获取字符数组中字符串的长度

可以使用string.h库中的函数strlen()来获取字符数组中字符串的长度,获取的长度不包括'\0'

局部变量存储在堆空间,用的时候需要申请,用完以后自动释放

指针变量运算

指针变量加减一个整数n,指针向高地址或低地址移动n个对象,要求在一段连续的内存空间上移动

数组

C语言的编译器不会检查数组的下标越界,需要特别注意,历史上有很多缓冲区越界带来的漏洞

数组首地址和数组元素首地址的区别

1.它们的地址值是相等的;

2.第1个元素的地址如果是p,则p+1就是第2个元素的地址;

3.数组的首地址如果是p,则p+1就跳过这个数数组而指向这个数组最后一个元素最后一个字节的下一字节。

指针和数组的关系

a[i] <=> *(a + i) <=> *(p + i) <=> p[i]

C语言运行时的内存分配

内存分为四个区段:代码段、静态区、堆区、栈区

代码段(从低地址向高地址扩展)

code/text

存放程序的二进制指令

静态区(从低地址向高地址扩展)

特点:定义一次,多次使用,如果未赋初值,初值会自动为0,生命周期和程序运行的时长相同

bss:

存放未赋初值的全局变量

static修饰的局部变量

data:

存放已赋初值的全局变量

static修饰的局部变量

堆区(从低地址向高地址扩展)

特点:手动申请,手动释放,使用时需导入stdlib.h头文件

使用malloc、free、realloc函数进行申请、释放和重新申请

否则可能会造成内存溢出

栈区(从高地址向低地址扩展)

特点:用时申请,用完释放,如果不赋初值,初值随机

存放的是函数内定义的变量,生命周期短

JNI_day01的更多相关文章

随机推荐

  1. 反射,获取类的属性以及get方法

    vo实体类: public class Result { /*** * 返回结果code * ok:10000 * error:20000 */ private String code; /*** * ...

  2. 案例(一) 利用机器算法RFM模型做用户价值分析

      一.案例背景 在产品迭代过程中,通常需要根据用户的属性进行归类,也就是通过分析数据,对用户进行归类,以便于在推送及转化过程中获得更大的收益. 本案例是基于某互联网公司的实际用户购票数据为研究对象, ...

  3. 都0202年了,你还不知道javascript有几种继承方式?

    前言     当面试官问你:你了解js哪些继承方式?es6的class继承是如何实现的?你心中有很清晰的答案吗?如果没有的话,可以通过阅读本文,帮助你更深刻地理解js的所有继承方式.       js ...

  4. Spring + Struts + Hibernate + Bootstrap-table 实现分页和增删改查

    1.bootstrap界面效果图: 2.Teacher实体类 public class Teacher { private int id; private String name; private S ...

  5. zz MySQL redo log及recover过程浅析

    原作地址:http://www.cnblogs.com/liuhao/p/3714012.html 写在前面:作者水平有限,欢迎不吝赐教,一切以最新源码为准. InnoDB redo log 首先介绍 ...

  6. TCO14286 TriangleTriples

    题目链接:https://vjudge.net/problem/TopCoder-14286 知识点: 组合数学.容斥原理 题目大意: 给出 \(A,B,C\),问有多少个有序三元组 \((a,b,c ...

  7. 转 vue动画总结

    使用过渡类名(有进入及出去,适合显示隐藏,需要配合v-if) .v-enter,//进入前 .v-leave-to {//离开后 只需要入场动画 可以把v-leave-to删掉 opacity: 0; ...

  8. day20 函数闭包与装饰器

    装饰器:本质就是函数,功能是为其他函数添加新功能 原则: 1.不修改被装饰函数的源代码(开放封闭原则) 2.为被装饰函数添加新功能后,不修改被修饰函数的调用方式 装饰器的知识储备: 装饰器=高阶函数+ ...

  9. spark学习笔记总结

    Spark简介 spark 可以很容易和yarn结合,直接调用HDFS.Hbase上面的数据,和hadoop结合.配置很容易. spark发展迅猛,框架比hadoop更加灵活实用.减少了延时处理,提高 ...

  10. JVM调优总结(六)-新一代的垃圾回收算法

    垃圾回收的瓶颈 传统分代垃圾回收方式,已经在一定程度上把垃圾回收给应用带来的负担降到了最小,把应用的吞吐量推到了一个极限.但是他无法解决的一个问题,就是Full GC所带来的应用暂停.在一些对实时性要 ...