技术:
指针
有关知识:
c++ 指针 多继承
java 单继承 java运行在JVM(java虚拟机)
c指针:为什么要指针
地址 内存空间
解决跨区域(不同作用域 不同代码块)之间的数据交互
野指针
“ ”
1.声明/定义变量的时候 表示一个指针变量
float b =20;
int c =10;
int *al 定义一个指针变量指向的内存空间只能存放整数
注意:定义一个指针变量的时候一定要给初值
ing *a =b;不行 指针变量只能存地址 不能存具体值
ing *a =b;不行 整型指针稚嫩存整形数据的地址
int *a =&c;正确
float *d = NULL;NULL指向内存的起始地址 0x00
2.除了定义指针碧昂量之外 都是访问某个地址的值
int *temp = =&c 定义指针变量1
*temp =21;访问tmep地址里面的数据 赋值为21
指针变量本身在内存空间内占据8个字节
3.数组和指针的关系
数组名并不是一个变量 没有分配内存空间 int a= 20
指针变量是由内存空间
定义一个数组 系统会分配内存空间 可以存值
定义一个指针变量 职位变量本身分配8个字节内存空间 无法存值 因为没有为它分配可以存值的内存空间
若想给指针指向的区域赋值
1.指针变量已经指向某块区域
int a =10;
int *pA =&a; 指向变量a的内存
*pA = 30;
2.指针指向一个数组
int num2[10]= {};
int *pNum = num2 ; 指向数组num2的内存
*(pNum+0) =20; 等价于 pNum[0] =20;
*(pNum+1) =30; 等价于 pNum[1] =30;
3.动态分配内存 malloc realloc free
上面两种指向的内存都是别人的
希望分配一个属于自己的内存空间
自己分配的内存空间必须自己释放
普通变量的内存是系统自己分配 属于系统自己负责释放
malloc 需添加 stdlib.h 头文件
malloc(10*sizeof(char)); 创建十个字节的内存
char *pName = malloc(10 * sizeof(char));
判断分配是否成功
if(pName == NULL){
//分配失败
return;
或者 exit(EXIT_FAILURE);
}
pName[0] = ‘j’;
pName[1] = ‘a’;
pName[2] = ‘c’;
printf(“%s\n”,pName);
当之前分配的内存空间不合适 需要在之前的基础上重新分配
realloc 必须是之前使用malloc分配过的
如果是系统分配的内存 是不能使用realloc的
pName = realloc(pName,4 * sizeof(char));
用完要自己释放内存
free(pName);
结构体
是一种数据类型 复合数据类型 struct
声明一种类型 struct Person
struct Person{
char name[10];
int age;
char *addr;
}
定义结构体struct Person变量
int i;
struct Person xw;
xw.name=”小王”//数组一旦定义 地址態改变
//不能直接给数组赋值
xw.name[0]= ‘x’;//系统为这个变量分配内存了
xw.name[1]=’w’;
xw.addr =’西南大学’;//敞亮字符串的地址是由系统分配的
xw.addr = malloc (1*sizeof(char));
xw.addr[0]= ‘s’ //字符指针赋值 必须要有内存
xw.age
结构体所占的字节是4的倍数 小的按顺序朝大的靠齐
定义一个学生结构体
学号 姓名 年龄 数学成绩
从终端输入学生的信息
查询
更改
删除
增加
使用文件 数据持久化
将结构体写入文件
从文件里面读取结构体
文件
打开文件
r只读 文件不存在就报错 从头开始读
w只写 文件不存在就创建 从头开始写
a只写 从末尾开始写
r+ w+ a+ 可读可写
FILE *fp=fopen(“abc.txt”,”w”);
写入数据
fpurs(“abc”,fp);
将结构体写到文件里面去
fwrite(&xw1,sizeof(struct Student),1,fp);
读取数据
fgets(temp,9,fp);
读取文件中的结构体
fread(&xw1,sizeof(struct Student),1,fp);
printf("name:%s\n",xw1.name);
printf("age:%d\n",xw1.age);
关闭文件
fclose(fp);
技术的实际使用
指针:
#include "stdafx.h"
#include "stdlib.h"
int _tmain(int argc, _TCHAR* argv[])
{
int a = 30;
int *p = &a;
char *pName =malloc(10*sizeof(char*));
if(pName == NULL){
return;
}
pName[0] = 'M';
pName[1] = 'i';
pName[2] = 'k';
pName[3] = 'e';
printf("%s\n",pName);
free(pName);
return 0;
}
结构体:
#include "stdafx.h"
#include "stdlib.h"
struct Person{
char name[10];
int age;
char *addr;
}
int _tmain(int argc, _TCHAR* argv[])
{
int i;
struct Person Mike;
Mike.name[0]='M';
Mike.name[1]='i';
Mike.name[2]='k';
Mike.name[3]='e';
Mike.age=20;
Mike.addr = malloc (1*sizeof(char));
Mike.addr[0] = 's';
return 0;
}
文件:
#include "stdafx.h"
#include "iostream"
struct Student{
char name[10];
int age;
};
int _tmain(int argc, _TCHAR* argv[])
{
char temp[20];
struct Student xw1={"xiaowang",20};
FILE *fp=fopen("C:/Users/HP/Desktop/abc.txt","a+");
/*fputs("aaaaaaaaa",fp);
fgets(temp,9,fp);
printf("%s\n",temp);*/
fwrite(&xw1,sizeof(struct Student),1,fp);
fread(&xw1,sizeof(struct Student),1,fp);
printf("name:%s\n",xw1.name);
printf("age:%d\n",xw1.age);
fclose(fp);
system("pause");
return 0;
}
随笔:
前几天的学习和之前关于c语言的学习一直给我一种感觉,其实c语言挺简单的,事实证明这个是个错觉。c语言从入门到放弃需要多久?大概是几个小时(误?),其实也不是放弃,只是更加的看清自己,知道自己有几斤几两。简单的小程序写着没问题,不代表可以写工程比较庞大的程序。努力学习 up!