Home > 零敲碎打 > [C语言教程]指针转换方式实现C语言的指针操作安全代码

[C语言教程]指针转换方式实现C语言的指针操作安全代码

今天讲点比较枯燥的理论知识,关于C语言的安全指针,如果你习惯于用C语言,那么会知道C语言的指针操作是很不安全的,但是这反而是C语言的特色之一,同时增强了C语言的灵活性和高效性,我本人也是比较偏爱于C语言的,并不是C++或者其他语言在算法方面不行,而是C语言的算法表述更加易于理解和运行更加高效,往往专家编程或者高效编程会采用C或者它的发展C++,但是对于初学者来说,要正确运用好C尤其是它的指针确实比较困难,所以我在此讲解几种C安全指针的处理方法。但是在此说明,请保持良好的编程习惯和正确的C指针处理方法,本文只提供一些


首先讲点基础的,什么叫指针(pointer),简单点指针也是一种特殊的数据结构,特殊在它的内容只是表示一个地址,而且它的操作是面向这个地址中的数据的,请注意不是地址,地址是操作系统进行内存分配的单位,并且已经确定的,为什么指针操作不安全?大部分原因在于C在面向地址单元的操作不采取任何保护性措施,而对于操作系统而言,部分内存地址,比如重要的系统数据,往往需要进行保护,那么结果会很郁闷了,如果我用C编程修改这些数据,(当然操作系统会有保护措施),会让系统出现问题,甚至宕机,因此说C的指针不安全并不是指针的数据结构不安全,而在于指针的操作会产生不可预料的结果,对于你的系统和程序而言是很危险的。

那如何是指针安全呢?目前主要有两个方法:指针转换,堆栈保护,指针转换主要是使指针转换为一种安全的数据结构,增加效验数据的过程,另外堆栈保护主要是使用了类似C++类的私有保护的方式,将指针放置在一个限制访问范围的区域内,而区域则限制该指针的使用,从而实现指针安全,但是实现比较复杂,

下面我主要讲点使用指针转换实现指针安全的方法,看下面的代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
typedef int type_int;/*定义保护的指针类型这里用int*/
 
typedef struct {
 type_int value;/*指针指向的数据的值*/
 type_int * pointer;/*指向指针*/
}Ptype_int;/*指针类型*/
 
int init(Ptype_int p){/*初始化,可用于释放指针*/
 p.value=0;
 p.pointer=&p.value;/*取地址,这里使用了引用方式,便于理解*/
 return 1;
}
 
int check(Ptype_int p){/*数据检查*/
 if(p.value==*(p.pointer))
  return 1;
 else
  return 0;
}
 
int assignValue(Ptype_int p , type_int v){/*直接赋值操作*/
 if(check(p)){
  p.value=v;
  *(p.pointer)=v;
  return 1;
 }
 else
  return 0;
)
 
int assignPointer(Ptype_int p , type_int *v){/*指针赋值操作*/
 if(check(p)){
  p.pointer=v;
  p.value=*v;
  return 1;
 }
 else
  return 0;
)
/*以上定义了基本的复制操作,比较,复制等操作基本相同,可根据需要定义*/
 
int main(){
 type_int i = 0;
 type_int *pi=i;
 Ptype_int p;
 init(p);/*初始化*/
 assignValue(p , i);/*直接赋值*/
 assignPointer(p , pi);/*指针赋值*/
}

相信原理很简单吧,就是把指针的操作转换为面向结构体的操作。但是结构体的定义使得其拥有自我效验机制,因为本程序中的所有赋值操作并没有设计指针操作,全部转换成函数调用,也就不存在指针安全问题了

本程序的原理:因为指针在物理层面上只是一个保存内存地址的内存单元,但是在我们在使用上主要用到的是其指向的地址单元内容,从而产生了安全问题,因此定义一个包含数据和指针的结构体,其中的type_int可以是其中type_int*指向的内容,用与效验,同时在初始化阶type_int*又是直接指向type_int的,所以type_int*可以很安全的使用,同时加上type_int和type_int*的比较效验,又增加了安全性

Categories: 零敲碎打 Tags:
  1. December 28th, 2008 at 13:48 | #1

    N年前学习C的时候,哪个卖力啊,现在基本上都还给老师了,改天回学校要学费去!

  2. December 28th, 2008 at 15:35 | #2

    这个可不是一个好习惯,有时间回归这些经典的东西,往往会获得意外的收获

  1. No trackbacks yet.