/*

訪问成员数组名事实上得到的是数组的相对地址。而訪问成员指针事实上是相对地址里的内容

*/

struct buf_str
{
int length;
char buf[0];
}; struct foo
{
buf_str* pbuf;
}; void test_funny()
{
foo f = {0}; printf("%x\n", f.pbuf);
printf("%x\n", &f.pbuf->length);
printf("%x\n", &f.pbuf->buf);
printf("%x\n", f.pbuf->buf); if (f.pbuf->buf) //没有申请内存,可是能够訪问相对地址,*数组名就是相对地址*
{
//printf(f.pbuf->buf); //crash,等价于printf("%s", f.pbuf->buf);指针的内容
}
} struct buf_str1
{
int length;
char *buf;
}; struct foo1
{
buf_str1* pbuf;
}; void test_funny1()
{
foo1 f = {0}; printf("%x\n", &f.pbuf->length);
printf("%x\n", &f.pbuf->buf); //指针的相对地址。 和前面的比較。也和以下的比較
printf("%x\n", f.pbuf->buf); //指针所指内容的地址,*訪问指针,就是訪问相对地址里面的内容* crash
if (f.pbuf->buf) //crash, 訪问内容
{
printf(f.pbuf->buf);
}
}

/*关于长度为0的数组,柔性数组意义*/

/*第一个意义是,方便内存释放。假设我们的代码是在一个给别人用的函数中,你在里面做了二次内存分配,

并把整个结构体返回给用户。用户调用free能够释放结构体,可是用户并不知道这个结构体内的成员

也须要free。所以你不能指望用户来发现这个事。所以,假设我们把结构体的内存以及其成员要的内存

一次性分配好了,并返回给用户一个结构体指针。用户做一次free就能够把全部的内存也给释放掉。

(读到这里,你一定会认为C++的封闭中的析构函数会让这事easy和干净非常多)





第二个原因是。这样有利于訪问速度。

连续的内存故意于提高訪问速度,也故意于降低内存碎片。

(事实上。我个人认为也没多高了,反正你跑不了要用做偏移量的加法来寻址)

*/

void test_funny2()
{
printf("buf_str size : %d\n", sizeof(buf_str));//只输出4,零长度的数组是存在于结构体内的。可是不占结构体的size int buf_len = 10;
//////////////////////////////////////////////////////////////////////////
//长度为0数组的使用方法
buf_str* pBuf = (buf_str*)malloc(sizeof(buf_str) + sizeof(char)*(buf_len+1));//连续的内存
pBuf->length = buf_len+1;
memset(pBuf->buf, 'a', sizeof(char) * buf_len);
pBuf->buf[buf_len] = '\0';
printf("%d %s\n", pBuf->length, pBuf->buf);
free(pBuf);//只释放一次内存
pBuf = NULL;
////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////
//正常的申请
buf_str1* pBuf1 = (buf_str1*)malloc(sizeof(buf_str1));
(pBuf1->buf) = (char*)malloc(sizeof(char)*(buf_len+1)); //内存可能不连续。须要两次释放
pBuf1->length = buf_len+1;
memset(pBuf1->buf, 'a', sizeof(char) * buf_len);
pBuf1->buf[buf_len] = '\0';
printf("%d %s\n", pBuf1->length, pBuf1->buf);
free(pBuf1->buf);
free(pBuf1);
pBuf = NULL;
}

原文来自于

http://coolshell.cn/articles/11377.html

仅仅只是提取了主要内容,并測验

c结构体里的数组与指针的更多相关文章

  1. 【VS开发】【编程开发】【C/C++开发】结构体中的数组与指针的内存分配情况说明

    [VS开发][编程开发][C/C++开发]结构体中的数组与指针的内存分配情况说明 标签:[VS开发] [编程开发] 主要是疑惑在结构体定义的数组的内存空间与指针动态分配的内存空间,在地址上连续性.以及 ...

  2. 读陈浩的《C语言结构体里的成员数组和指针》总结,零长度数组

    原文链接:C语言结构体里的成员数组和指针 复制例如以下: 单看这文章的标题,你可能会认为好像没什么意思.你先别下这个结论,相信这篇文章会对你理解C语言有帮助.这篇文章产生的背景是在微博上,看到@Lar ...

  3. c#中关于结构体和字节数组转化

    最近在使用结构体与字节数组转化来实现socket间数据传输.现在开始整理一下.对于Marshal可以查阅msdn,关于字节数组与结构体转代码如下: using System; using System ...

  4. C#结构体和字节数组的转换函数

    在通信过程中,一般我们都会操作到字节数组.特别是希望在不同语言编程进行操作的时候. 虽然C#提供了序列化的支持,不用字节数组也行.但操作字节数组肯定会碰到.   一般都会采用结构来表示字节数组.但结构 ...

  5. c# 调用c++sdk时结构体与byte数组互转

    /// <summary> /// 由结构体转换为byte数组 /// </summary> public static byte[] StructureToByte<T ...

  6. 深入理解指针—>结构体里的成员数组和指针

    单看这文章的标题,你可能会觉得好像没什么意思.你先别下这个结论,相信这篇文章会对你理解C语言有帮助.这篇文章产生的背景是在微博上,看到@Laruence同学出了一个关于C语言的题,微博链接.微博截图如 ...

  7. C语言结构体里的成员数组和指针

    struct test{ int i; char *p; }; struct test *str; ; char *b = "ioiodddddddddddd"; str = (s ...

  8. C# Struct结构体里数组长度的指定

    typedef struct Point{ unsigned short x; unsigned short y; }mPoint;//点坐标 typedef struct Line{ mPoint ...

  9. c++与C# winform的消息通讯--(结构体与byte数组的使用)

    近期正在做一个蓝牙驱动的使用程序,其中有一块从c++发送数据到C#的部分,网上查了很多资料,大多都是介绍如何通过调用函数获取用户数据.并且在消息发送中,很少介绍如何发送一个结构体,并且结构体里面有 b ...

随机推荐

  1. 算法复习——1D/1Ddp优化

    搬讲义~~~~ 题目1:玩具装箱(bzoj1010) Description P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一 ...

  2. Activation(hdu 4089)

    题目:仙5的激活序列.有以下4种情况: 1.注册失败,但是不影响队列顺序 ,概率为p1 2.连接失败,队首的人排到队尾,概率为p2 3.注册成功,队首离开队列,概率为p3 4.服务器崩溃,激活停止,概 ...

  3. 【BZOJ3529】【SDOI2014】数表 (莫比乌斯反演+树状数组)

    传送门 Description 有一张$n\times m$的数表,其第$i$行第$j$列 $(1≤i≤n,1≤j≤m)$ 的数值为能同时整除$i$和$j$的所有自然数之和.现在给定$a$,计算数表中 ...

  4. 理解 Glance

    OpenStack 由 Glance 提供 Image 服务. 理解 Image 要理解 Image Service 先得搞清楚什么是 Image 以及为什么要用 Image? 在传统 IT 环境下, ...

  5. Pόlya定理-学习笔记

    gi为一个为一个置换 c(g),为c(g)的轮换的数量 (循环的数量) 太监了

  6. elementary os 0.4.1下编译GCC-7.1源码并安装成功

    参考文章:http://www.2cto.com/os/201402/281131.html 前几天为了图个新鲜,安装了elementary os 0.4.1,的确是一股清流,可惜的是gcc版本觉得有 ...

  7. 微信公众号手机端PC端多客服系统

    最近很多客户反应没有专门的客服坐在电脑面前,接收回复客户的问题:不能及时回复客户 咨询的问题,现在我们已经为此帮您解决烦恼!! 支持PC与手机端接收微信客户咨询与回复客户,让您随时随地及时回复客户咨询 ...

  8. Codeforces 889C Maximum Element(DP + 计数)

    题目链接  Maximum Element 题意  现在有这一段求序列中最大值的程度片段: (假定序列是一个1-n的排列) int fast_max(int n, int a[]) { int ans ...

  9. 初学ElasticSeacher

    这周,刚接手了同事那边的工作,项目里需要用到ElasticSeacher.但是,之前从未接触过,因此,看了ES的文档,开始慢慢的知道了一些ES的知识. 一.ES简介: Elasticsearch是一个 ...

  10. 获取path的几种方式:NSFileManager NSHomeDirectory NSBundle

    //---------------------------------------------------------------------------------NSFileManager *fi ...