C语言错误的指针,c语言中关于指针的错误(内核)

1.指针的赋值

在定义一个指针的时候,一定要注意赋值的问题。在定义一个指针的时候内存只为这个 指针分配了内存空间,没有为指针指到的位置分配空间。

例如:

struct class

{

char name[2];

int age;

};

/*错误的用法

struct class *a;

a = NULL;

a->age = 3;//这里一定要注意,没有为其分配空间所以不能直接赋值,在内核中,这样会直接崩溃掉。

*/

//正确的用法

struct class *a;

a = NULL;

a = kmalloc(sizeof(struct class),GFP_KERNEL);//这里分配了空间,并返回那个空间的开头的地址。

a->age = 3;

2.指针的加减

在内核中,经常一个结构体中有另外一个结构体的指针。这里分配就会有一个技巧,为第一个指针分配空间的时候,把包含的指针的空间一起分配了。

另外,当一个指针加上一个值的时候,是在这个指针指着的地址的基础上加上这个指针指着的数据结构的大小的字节*加上的值;

例如:

struct class

{

char name[2];

int age;

};

struct school

{

char name[2];

int number;

struct class *class;

};

struct school *school;

school = NULL;

school = kmalloc( sizeof(struct school) + sizeof(struct class),GFP_KERNEL);

school->class = (void *) (school + 1);//注意这里加一,就相当于加上一个school数据结构的占用的字节。

在上述代码中,假设字节对齐了,即shool占用2+4+8(对于64位系统,指针大小8字节,32位,4字节),school的值为0x0023;则school+1 = 0x0023+0xd = 0x0031;

而我们让school->class的值为school+1,就相当与吧申请到的前面 sizeof(struct school)的字节存放shool结构体里面的值。紧接着  sizeof(struct class)字节存放结构体class里面的值并让,shcool->class指着这个这个地址的开始。

3.关于memcpy,,memset的用法。

void *memcpy(void *dest, const void *src, size_t n);函数返回指向dest的指针。

char da[6]

memcpy(da,"111111",6);

当把da的值输出来的时候是0x313131313131。这个是因为程序吧“111111”把这六个1看成字符串,而对于一个1字符,ascII对应的值是49正好是0x31。所以在这样赋值的过程是很容易错的。

void *memset(void *s, int ch,

size_t n);

解释:将s中前n个字节 (typedef unsigned int size_t )用 ch 替换并返回 s 。 所以上述代码应该用

memset(da,1,6);//没有引号

而当用

char  name[6];
memset (name, "11" ,6);//打印出来是0x959595959595
上面那个memset中传进去的是“11”这两个字符的首地址,因为是在64位中,所以这个地址8字节,而memset是取这个首地址的第一位即0x95  赋值6次。。。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值