C语言笔记(26)位段、枚举、联合等知识

位段的声明和结构是类似的,有两个不同:

1.位段的成员必须是int, unsigned int或signed int

2.位段的成员后边有一个冒号和1个数字

如:struct A

        {

           int - a : 2;//意思是只需要2个比特位

            int - b : 5;

         }

3.只能在结构体中使用

内存分配(位段)

1.位段空间上是按照需要以4个字节(int)或1个字节(char)的方式来开辟的。

2.位段涉及很多不确定因素,位段是不跨平台的,注重可移植的程序应该避免使用位段。

如:

#include <stdio.h>
struct A
{
	//4byte - 32bit
	int  a : 2;
	int  b : 5;
	int  c : 10;
	//15
	//4byte - 32bit

};
int main()
{
	printf("%d\n", sizeof(struct A));
	return 0;
}

位段跨平台问题:

1.int位段被当成有符号数还是无符号数是不确定的。

2.位段中最大位的数目是不能确定。(16位机器最大16,32位机器最大32,写成27会在16位机器中出问题)

3.位段中的成员在内存中从左向右分配,还是从右向左分配标准尚未定义。

4.当一个结构包含两个位段,第二个位段成员比较大,无法容纳第一个位段剩余的位时,是舍弃剩余的位还是利用,这是不确定的。

总结:跟结构相比,位段可以达到同样的效果,但可以很好节省空间,但有跨平台问题存在。

枚举的优点

为什么使用枚举?

我们可以使用#define定义常量,为什么非要用枚举?

枚举的优点:

1.增加代码的可读性和可维护性。

3.和#define定义的标识符比较枚举有类型检查,更加严谨。

3.防止命名污染。

4.便于调试。

5。使用方便,一次可以定义多个变量。

联合:联合也是一种特殊的自定义类型,这种类型定义的变量也包含一系列的成员,特征是这些成员公用同一块空间,所以联合体也叫共用体。

举例:


union un
{
	int a;
	char c;
};
int main()
{
	union un;
	printf("%p\n", &(u.a));
}

判断当前计算机的大小端存储:

#include <stdio.h>
int check_sys()
{
	int a = 1;
	return *(char*)&a;
}
int main()
{
	//int a = 1;
	//低到高
	//01000000..小端
	//00000001....大端
	int ret = check_sys();
	if (ret == 1)
	{
		printf("小端\n");
	}
	else
		printf("大端\n");
	return 0;
}

原理:

union un

{

char arr[5];

int i;

}

指针,结构体,动态内存开辟学号此三类知识时用c/c++写好数据结构的基础

  • 8
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: memset 函数可以用来将一块内存空间的值设置为指定的值,它常用于对数组、结构体等数据结构进行初始化操作。不过需要注意的是,对于结构体内部的指针变量,使用 memset 并不能直接将其初始化为 NULL,因为在内存中 NULL 的值并不是 0。 一个比较好的做法是,在结构体定义的时候将指针变量初始化为 NULL,例如: ``` struct Node { int data; struct Node *next; }; struct Node node = {0, NULL}; ``` 这样就可以确保在使用 memset 进行清零操作时,结构体内部的指针变量也被正确地初始化为 NULL。 如果要使用 memset 对结构体进行清零操作,可以使用以下代码: ``` struct Node node; memset(&node, 0, sizeof(struct Node)); ``` 这里我们使用 & 符号获取结构体变量的地址,然后将其作为 memset 函数的第一个参数传入。第二个参数是要设置的值,这里我们设置为 0 表示清零。第三个参数则是结构体的大小,可以使用 sizeof 运算符来获取。 需要注意的是,使用 memset 函数进行清零操作时,要确保结构体中的所有成员变量都可以被正确地清零,否则可能会导致程序出现未知的错误。另外,在使用 memset 函数时,也需要注意不要越界访问内存空间。 ### 回答2: memset函数是C语言中用于对指定的内存块进行初始化的函数,常见的使用方式是对数组和字符串进行初始化。然而,对于结构体内部包含指针的情况,memset函数并不能直接用于初始化指针所指向的内存空间。 原因在于,memset函数是以字节为单位进行操作的,而指针的大小往往是4个字节或8个字节,因此无法准确地将指针的值初始化为NULL或其他指定的值。 对于结构体内部的指针,我们可以通过手动逐个成员初始化的方式,来达到初始化的目的。例如,可以先将结构体的指针成员赋值为NULL,然后再逐个成员进行初始化。示例如下: ```c #include <stdio.h> #include <stdlib.h> typedef struct { int *ptr; int num; } MyStruct; void initializeStruct(MyStruct *s) { s->ptr = NULL; s->num = 0; } int main() { MyStruct s; initializeStruct(&s); printf("ptr = %p\n", s.ptr); printf("num = %d\n", s.num); return 0; } ``` 在上述代码中,通过initializeStruct函数对结构体s进行初始化,将s.ptr赋值为NULL,将s.num赋值为0。这样就可以实现对结构体内部指针的初始化。 需要注意的是,对于结构体内部嵌套的其他结构体或者动态分配的内存空间,我们同样需要手动进行逐个成员初始化,以确保结构体内部的所有指针都被正确初始化,并且不产生内存泄漏的问题。 ### 回答3: memset是C语言中的一个函数,用于对一段内存空间进行初始化操作。它可以将指定内存区域的每个字节都设置为特定的值。 在C语言中,结构体是一种用户定义的数据类型,它可以包含多个不同类型的变量。结构体可以被看作是一种形式上的数据集合,可以统一管理一组相关的变量。 结构体内可以包含指针变量,这些指针变量可以指向堆内存中的某个地址。然而,当我们使用memset来初始化结构体内的指针时,需要注意指针变量指向的内存空间是否已经被分配。 由于memset函数只能设置内存空间的值,并不能为指针变量分配内存,因此在使用memset初始化结构体内指针之前,需要先为指针变量分配足够的内存空间。否则,如果指针未指向有效的内存地址,当我们尝试访问这个指针时,可能会导致程序崩溃或者产生未知的结果。 所以在使用memset来初始化结构体内指针时,我们需要先为这些指针变量分配内存,并在memset函数调用之后再对这些指针进行进一步的操作,以确保指针变量的正确性和有效性。 在使用结构体时,我们也可以将多个结构体通过指针链接成链表结构,形成一种更加复杂的数据结构。链表可以通过指针将各个结构体连接起来,方便进行数据的插入、删除和查找等操作。 此外,C语言还提供了枚举类型,它可以定义一些常量集合,方便程序员使用和维护。枚举类型可以用于表示一组相关的取值,通过定义的枚举常量,我们可以直观地理解程序中的某些状态或者选项。 总之,结构体、链表和枚举C语言中重要的概念和特性,它们能够帮助我们更好地组织和管理程序中的数据,提高代码的可读性和可维护性。在使用这些特性时,我们需要注意指针的正确使用和内存的分配释放,以避免出现错误和内存泄漏等问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

千度vea

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值