你记住格式就行
FIEL *fp
fp = fopen("","")
if (fp == NULL)
{}
...
fclose(fp)
FILE *p1,*p2,*p3刚声明了文件指针,文件指针是空的
马上执行:
p2=p1
语法是允许的,但 p1 还没有初始化呢。
就如:int a,b
马上执行磨衡:b=a a 还没有初始化呢。
文件指针 指向拆举的对象,通常是从成功地 fopen 打开文件获得。获得后,与一般指针一样,运算规旅游碧则相同。
一.在定义指针的时候注意连续声明多个指针时容易犯的错误,例如int * a,b这种声明是声明了一个指向int类型变量的指针a和一个int型的变量b,这时候要清醒地记着,而不要混淆成是声明了两个int型指针。二.要避免使用未初始化的指针。很多运行时错误都是由未初始化的指针导致的,而且这种错误又不能被编译器检查所以很难被发现。这时的解决办法就是尽量在使用指针的时候定义它,如果早定义的化一定要记得初始化,当然初始化时可以直接使用cstdlib中定义的NULL也可以直接赋值为0,这是很好的编程习惯。
三.指针赋值时一定要保证类型匹配,由于指针类型确定指针所指向对象的类型,因此初始化或赋值时必须保证类型匹配,这样才能在指针上执行相应的 *** 作。
四.void * 类型的指针,其实这种形式只是记录了一个地址罢了,如上所说,由于不知道所指向的数据类返滑型是什么所以不能进行相应的 *** 作。其实void * 指针仅仅支持几种有限的 *** 作:1.与另外的指针进行比较,因为void *类型里面就是存的一个地址,所以这点很好理解;2.向函数传递void *指针或从函数返回void *指针,举个例子吧,我们平时常用的库函数qsort中的比较函数cmp(个人习惯于用这个名字)中传递的两个参数就是const void *类型的,用过的应该很熟了;3.给另一个void * 类型的指针赋值。还是强调一下不能使用void * 指针 *** 纵它所指向的对象。
五.不要将两个指针变量指向同一块动态内存。这个容易引起很严重的问题。如果将两个指针变量指向同一块动态内存,而其中一个生命期结束释放了该动态内存,这个时候就会出现问题,另一个指针所指向的地址虽然被释放了但该指针并不等于NULL,这就是所谓的悬垂指针错误,这种错误很难被察历慧觉,而且非常严重,因为这时该指针的值是随机的,可能指向一个系统内存而导致程序崩溃。但也就是因为值是随机的,所以运行程序时有时正常有时崩溃,这一点要特别注意。
六.在动态delete释放一个指针所指向的内存后注意将该指针置空。
七.在为一个指针再次分配内存之前一定要保证它原先没有指向其他内存,防止出现内存泄漏。解决的办法是我们必须判断该指针是否为空,这时候就显示出第六条的优势,因为如果释放某内漏烂腊存后相应指针不置空的话就不能为其分配新内存了。所以第六条很有必要。
八.虽然程序在退出main函数时会释放所有内存空间,但对于大型程序最好还是某块内存不用了立刻释放,而不要指望系统最后的回收,因为内存泄漏会慢慢消耗系统资源直到内存不足而程序死掉。
九.在用new动态分配完内存之后一定要判断是否分配成功,分配成功后才能使用。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)