C语言中的结构体,结构体中数组初始化与赋值

C语言中的结构体,结构体中数组初始化与赋值原作地址:https://www.cnblogs.com/zhangfeionline/p/5913905.html最近写c语言中的结构体遇到了些问题,从网上找了些资料如下:结构体是连续存储的,但由于结构体中成员类型各异,所以会存在内存对齐问题,也就是内存里面会有空档,具体的对齐方式这里暂不讨论;1.结构体的定义和赋值结构体是可以直接初始化的,在定义的时候,就可

大家好,又见面了,我是你们的朋友全栈君。

最近写c语言中的结构体遇到了些问题,从网上找了些资料如下:

结构体是连续存储的,但由于结构体中成员类型各异,所以会存在内存对齐问题,也就是内存里面会有空档,具体的对齐方式这里 暂不讨论;

 

1.结构体的定义和赋值 

结构体是可以直接初始化的,在定义的时候,就可以初始化,而且如果你的结构体中恰好有字符数组的话,这个时候初始化是不错的选择,原因很简单,字符数组只能定义的时候直接初始化

后来就不可以了,后来你就只能用strcpy函数来拷贝初始化了。

struct 结构体名
{
    数据类型   成员名1;
    数据类型   成员名2;
    :
    数据类型   成员名n;
};

 2.定义结构体变量的3种方法:

第1种:

struct 结构体名
{
成员列表;
}变量名1;

第2种:

struct 结构体名
{
成员列表;
};
struct 结构体名 变量名2;

第3种:

typedef struct 结构体名
{
    成员列表;
}结构体别名;

结构体别名 变量名3;

 

访问结构体成员的2种方式:
1、直接访问:结构体变量名.成员名

2、指针访问:结构体变量指针->成员名

3.结构体初始化操作

1. struct 结构体名 变量名 = {0,0,0,...};

2. struct 结构体名 变量名 = 
{
    .成员1 = 0,
    .成员2 = 0,
    .成员3 = 0,
    ...
};

3. struct 结构体名 变量名 = 
{
    成员1: 0,
    成员2: 0,
    成员3: 0
};

第2、3种方式成员顺序可以打乱,甚至可以只初始化其中某几个成员。3种初始化的方式在linux下使用GCC编译均可通过。

 

4.结构体定义时的嵌套

1、内部的结构体名称定义齐全

struct student
{
    int a;
    int b;
    struct other
    {
        int c;
        int d;
    }name;
};

引用c成员的方式: 变量.name.c
 
 
2、 内部的结构体通常定义为无名结构体

 

 

struct student
{
    int a;
    int b;
    struct
    {
        int c;
        int d;
    };
};

引用c成员的方式:变量.C

 

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/161042.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Designer VS Coder, who is the winner?

    Designer VS Coder, who is the winner?

    2021年7月26日
    53
  • Java实现完美洗牌算法

    1问题描述有一个长度为2n的数组{a1,a2,a3,…,an,b1,b2,b3,…,bn},希望排序后变成{a1,b1,a2,b2,a3,b3,…,an,bn},请考虑有没有时间复杂度为O(n)而空间复杂度为O(1)的解法。2解决方案2.1位置置换算法下面算法的时间复杂度为O(n),空间复杂度为O(n)。packagecom.liuzhen.practice;publiccl…

    2022年4月7日
    57
  • 深究递归和迭代的区别、联系、优缺点及实例对比「建议收藏」

    深究递归和迭代的区别、联系、优缺点及实例对比「建议收藏」深究递归和迭代的区别、联系、优缺点及实例对比1.概念区分递归的基本概念:程序调用自身的编程技巧称为递归,是函数自己调用自己.一个函数在其定义中直接或间接调用自身的一种方法,它通常把一个大型的复杂的问题转化为一个与原问题相似的规模较小的问题来解决,可以极大的减少代码量.递归的能力在于用有限的语句来定义对象的无限集合.使用递归要注意的有两点:1)递归就是在过程或函数里面调用自身;

    2022年6月5日
    41
  • Laravel 之搜索引擎elasticsearch扩展Scout

    Laravel 之搜索引擎elasticsearch扩展Scout

    2021年10月24日
    65
  • MC蒙特卡洛_我的世界mcc是什么

    MC蒙特卡洛_我的世界mcc是什么MCMC(一)蒙特卡罗方法MCMC(二)马尔科夫链MCMC(三)MCMC采样和M-H采样MCMC(四)Gibbs采样作为一种随机采样方法,马尔科夫链蒙特卡罗(MarkovChainMont

    2022年8月1日
    25
  • 有序的hashmap_在待排序的元素基本有序的前提下

    有序的hashmap_在待排序的元素基本有序的前提下如何给HashMap中的值排序?这个问题很多人都遇到过,很常见的一个方案是使用LinkedHashMap,因为LinkedHashMap可以记住元素放入的顺序,可以认为是真正的“有序”(想让HashMap有序是不可能的),我比较喜欢。然而问题是往往数据已经封装在了HashMap中,我们必须手动的排序后再放入LinkedHashMap,这当然也就成了思路,代码实现起来也很简单,写出来看起来还挺舒服的…

    2022年10月24日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号