C语言在线运行

版本:
运行结果
教程手册
代码仓库
极速运行
交互输入
极速运行模式,更高效的运行,点击编辑器上方的运行按钮即刻体验吧。
以下是用户最新保存的代码
阶乘的运算 发布于:2022-10-04 18:27 问题求解模型(初始) 发布于:2022-10-04 16:43 选择排序代码 发布于:2022-10-04 00:20 插入排序代码 发布于:2022-10-04 00:42 打印1~n整数中能被3整除的数 发布于:2022-10-03 21:45 冒泡排序法 发布于:2022-10-03 21:41 冒泡排序法 发布于:2022-10-03 21:40 归并排序代码 发布于:2022-10-03 19:19 花里胡哨的的 发布于:2022-10-03 18:04 找到一位三位数。 发布于:2022-10-03 17:11 百鸡百钱问题 发布于:2022-10-02 22:46 选择排序和堆排序代码 发布于:2022-10-02 22:28 快速排序代码 发布于:2022-10-02 21:52 九九乘法表 发布于:2022-10-02 21:03 函数的调用---1*...*n 发布于:2022-10-02 20:37 链表的使用 发布于:2022-10-01 16:10 不知道哪里还有问题,运行不了 发布于:2022-09-30 22:04 数数的位数的代码 发布于:2022-09-30 21:43 9.30顺序查找的实现 发布于:2022-09-30 18:21 9.30 打印三位数,这三位数要满足个位比百位大,百位比十位大,三个位数之和和三个位数之积相等的代码 发布于:2022-09-30 18:19 9.30被3整除的代码 发布于:2022-09-30 18:15 求三个整数中最小数 发布于:2022-09-30 18:15 找零的c代码 发布于:2022-09-30 11:28 计算代码运行时间 发布于:2022-09-30 11:22 比较运算符 发布于:2022-09-30 09:41 求两个数的平均值 发布于:2022-09-30 09:33 冒泡排序和选择排序 发布于:2022-09-30 00:49 冒泡排序、 发布于:2022-09-29 23:02 插入排序算法 发布于:2022-09-29 22:53 冒泡的实现 发布于:2022-09-29 19:29 顺序查找法 发布于:2022-09-29 19:17 冒泡排序法 发布于:2022-09-29 18:37 1~n整数中能被3整除的数 发布于:2022-09-29 18:22 顺序查找的实现 发布于:2022-09-29 18:18 顺序查找的实现 发布于:2022-09-29 18:17 1~n整数中能被3整除的数 发布于:2022-09-29 18:27 打印三位数,这三位数要满足个位比百位大,百位比十位大,三个位数之和和三个位数之积相等 发布于:2022-09-29 18:13 打印1~n整数中能被3整除的数 发布于:2022-09-29 18:10 判断是否为闰年 发布于:2022-09-29 16:21 找三位数水仙花数 发布于:2022-09-29 15:54 判断是否水仙花数 发布于:2022-09-29 15:54 求是否是闰年 发布于:2022-09-29 15:18 for循环水仙花 发布于:2022-09-29 16:09 几英尺几英寸换算成米 发布于:2022-09-29 15:38 找零程序学习 发布于:2022-09-29 12:37 顺序查找的实现 发布于:2022-09-29 17:56 求一个三位数 发布于:2022-09-29 10:57 1~n中能被3整除的数 发布于:2022-09-29 09:09 广东发货太尴尬 发布于:2022-09-29 09:01 [更多]
显示目录

位域



C 位域

位域是操控位的一种方法

有些数据在存储时只占用一个或几个二进制位,并不需要占用一个完整的字节。基于这种考虑,C语言又提供了一种数据结构,叫做“位域”或“位段”。

位域通过一个结构声明来建立:该结构声明为每个字段提供标签,并确定该字段的宽度。例如,下面的声明建立了个4个1位的字段:

struct 
{
   unsigned int autfd:1;
   unsigned int bldfc:1;
   unsigned int undin:1;
   unsigned int itals:1;
}prnt;

根据该声明, prnt包含4个1位的字段。现在,可以通过普通的结构成员运算符(.)单独给这些字段赋值:

prnt.itals = 0:
prnt.undin = 1;

由于每个字段恰好为1位,所以只能为其赋值1或0。变量prnt被储存在int大小的内存单元中 :后面的数字用来限定成员变量占用的位数。位域的宽度不能超过它所依附的数据类型的长度。通俗地讲,成员变量都是有类型的,这个类型限制了成员变量的最大长度,:后面的数字不能超过这个长度。

如上述结构中autfd、bldfc、undin、itals后面的数字不能超过unsigned int的位数,即在32bit环境中就是不能超过32。

位域的取值范围非常有限,数据稍微大些就会发生溢出,请看下面的例子:

#include <stdio.h>

struct pack
{
 unsigned a:2;  // 取值范围为:0~3
 unsigned b:4;   // 取值范围为:0~15
 unsigned c:6;   // 取值范围为:0~63
};

int main(void)
{
 struct pack pk1;
 struct pack pk2;

 // 给pk1各成员赋值并打印输出
 pk1.a = 1;
 pk1.b = 10;
 pk1.c = 50;
 printf("%d, %d, %d\n", pk1.a, pk1.b, pk1.c);

 // 给pk2各成员赋值并打印输出
 pk2.a = 5;
 pk2.b = 20;
 pk2.c = 66;
 printf("%d, %d, %d\n", pk2.a, pk2.b, pk2.c);

 return 0;
}

程序输出结果为:

pk1.a = 1, pk1.a = 10, pk1.c = 5
pk2.a = 1, pk2.b = 4, pk2.c = 2

位域声明

在结构内声明位域的形式如下:

struct
{
  type [member_name] : width ;
};

下面是有关位域中变量元素的描述:

元素 描述
type 整数类型,决定了如何解释位域的值。类型可以是整型、有符号整型、无符号整型。
member_name 位域名
width 位域中位的数量。宽度必须小于或等于指定类型的位宽度。

带有预定义宽度的变量被称为位域。位域可以存储多于 1 位的数,例如,需要一个变量来存储从 0 到 7 的值,您可以定义一个宽度为 3 位的位域,如下:

struct
{
  unsigned int age : 3;
} Age;

上面的结构定义指示 C 编译器,age 变量将只使用 3 位来存储这个值,如果您试图使用超过 3 位,则无法完成。让我们来看下面的实例:

#include <stdio.h>
#include <string.h>

struct
{
  unsigned int age : 3;
} Age;

int main( ) {
   Age.age = 4;
   printf( "Sizeof( Age ) : %d\n", sizeof(Age) );
   printf( "Age.age : %d\n", Age.age );

   Age.age = 7;
   printf( "Age.age : %d\n", Age.age );

   Age.age = 8;
   printf( "Age.age : %d\n", Age.age );

   return 0;
}

尝试一下

当上面的代码被编译时,它会带有警告,当上面的代码被执行时,它会产生下列结果:

Sizeof( Age ) : 4
Age.age : 4
Age.age : 7
Age.age : 0
由JSRUN为你提供的C语言在线运行、在线编译工具
        JSRUN提供的C语言在线运行,C语言 在线运行工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。

title

使用此草稿 删除草稿

  • 00:23
注册登录后可减少验证码的弹出,点击前往 注册 | 登录

皮肤:

运行模式:

嵌入代码 iframe嵌入:


服务器已安装大部分常用的第依赖库,但仍可能存在一些未被安装的库, 可以通过本窗口立即安装所需依赖库。


请输入依赖库的名称:

请选择语言: