博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
根据结构体里面元素的某个地址计算机构体地址
阅读量:6147 次
发布时间:2019-06-21

本文共 618 字,大约阅读时间需要 2 分钟。

#include <stdio.h>

#include <stdlib.h>

#define CONTAINER_OF(ptr, type, member)((type *)((char *)ptr - (char *)&((type*)0)->member))

#define ARRAY_SIZE(a)(sizeof(a) / sizeof((a)[0]))

struct user_data

{
     char a;
     char b;
     int c;
};

int main(int argc, char *argv[])

{
      struct user_data *tmp;
      char *h;
      struct user_data = (struct user_data *)malloc (sizeof(struct user_data));
if(p_data ==NULL)
{
      printf("no memory!\n");
      return -1;
}

     h = &p_data->b;

     printf("p_data's address is 0x%p\n", p_data);

     printf("h's           address is 0x%p\n", h);

     tmp = CONTAINER_OF(h, struct user_data, b);

     printf("tmp's address is 0x%p\n", tmp);

     return 0;
}

转载地址:http://uimya.baihongyu.com/

你可能感兴趣的文章
每天进步一点----- MediaPlayer
查看>>
PowerDesigner中CDM和PDM如何定义外键关系
查看>>
跨域-学习笔记
查看>>
the assignment of reading paper
查看>>
android apk 逆向中常用工具一览
查看>>
MyEclipse 报错 Errors running builder 'JavaScript Validator' on project......
查看>>
Skip List——跳表,一个高效的索引技术
查看>>
Yii2单元测试初探
查看>>
五、字典
查看>>
前端js之JavaScript
查看>>
Log4J日志配置详解
查看>>
实验7 BindService模拟通信
查看>>
scanf
查看>>
Socket编程注意接收缓冲区大小
查看>>
SpringMVC初写(五)拦截器
查看>>
检测oracle数据库坏块的方法
查看>>
SQL server 安装教程
查看>>
Linux下ftp和ssh详解
查看>>
跨站脚本功攻击,xss,一个简单的例子让你知道什么是xss攻击
查看>>
js时间和时间戳之间如何转换(汇总)
查看>>