C语言在线运行

版本:

所属目录
点击了解高性能代码运行API
运行结果
教程手册
代码仓库
极速运行
终端运行
图形+终端

                        
以下是用户最新保存的代码
数组队列二叉按层遍历求深度 发布于:2025-04-15 09:04 这是我的代码 发布于:2025-04-12 08:29 这是我的代码 发布于:2025-04-12 08:09 俄罗斯方块 发布于:2025-04-12 20:27 随机数冒泡排序 发布于:2025-04-11 15:05 100—500随机数 发布于:2025-04-11 14:01 90365sent得crc 发布于:2025-04-11 10:53 Md5 计算MQTT 发布于:2025-04-14 15:50 struct示例 发布于:2025-04-10 12:06 人生模拟器(文字版) 发布于:2025-04-11 20:07 活动结束兰蔻 发布于:2025-04-06 15:50 俺妈世界第一漂亮!!! 发布于:2025-04-16 22:57 斐波那契数列 发布于:2025-04-06 10:25 整型与变量 发布于:2025-04-06 09:53 我爱编程,编程使我快乐! 发布于:2025-04-06 07:52 成都成就梦想! 发布于:2025-04-06 07:44 第五章第二个lab 发布于:2025-04-03 21:08 第五章第一个lab 发布于:2025-04-03 21:07 helloworld第一个文件 发布于:2025-04-03 21:05 mt6511sent输出 发布于:2025-04-03 13:18 uint32转uint8数组 发布于:2025-04-03 10:50 C,AES128 ECB 发布于:2025-04-03 10:46 设计一算法,逆置带头结点的动态单链表 发布于:2025-04-15 08:40 切割指定字符的字符串 发布于:2025-03-31 16:02 从键盘输入1~7的数字,分别提示: Monday、Tuesday、Wednesday、Thursday、friday、saturday、sunday, 输入其它,提示出错, 使用:switch case break 实现 发布于:2025-03-31 11:07 从屏幕上输入一个学生的成绩(0-100), 对学生成绩进行评定: <=60为"E", 60~69为"D, 70~79为"C", 80~89为"B", 90以上为"A", <0或>100提示成绩输入出错, 使用:if else if等实现 发布于:2025-03-31 11:04 成绩查询系统 发布于:2025-03-30 16:19 m的次方等于m个连续奇数相乘 发布于:2025-03-30 15:14 三角形的确定 发布于:2025-03-30 11:24 计算中英混合字符长度且不算无效字符 发布于:2025-03-26 15:42 我也不知道我为什么要这样 发布于:2025-03-26 00:25 算法3.5(第80页)带头结点的头插法建立单链表 发布于:2025-03-25 14:48 将两个顺序表合并为一个顺序表 发布于:2025-03-25 14:41 例3.1(第70页)线性表按奇偶拆分 - 将线性表A按元素值奇偶拆分成两个表,A表存放奇数,B表存放偶数。 发布于:2025-03-25 14:39 线性顺序表 发布于:2025-03-24 23:38 这是最大值的程序 发布于:2025-03-23 13:57 台湾球员管理 发布于:2025-03-23 11:03 B树代码构成 发布于:2025-03-21 21:44 完全二叉树判断 发布于:2025-03-21 21:39 循环链表构造 发布于:2025-03-21 21:04 链表转队列 发布于:2025-03-21 20:51 单链表构造 发布于:2025-03-22 10:31 队列的表示方法 发布于:2025-03-21 17:56 栈的构造代码 发布于:2025-03-21 17:07 分块查找算法 发布于:2025-03-21 14:14 二分查找算法 发布于:2025-03-21 13:43 顺序查找算法 发布于:2025-03-21 13:28 树的存储结构以及先中后层序遍历 发布于:2025-03-21 13:22 字符串输入输出以及排序 发布于:2025-03-21 12:15 链式存储队列功能实现 发布于:2025-03-21 11:40 [更多]
显示目录

位域



学习嵌入式的绝佳套件,esp8266开源小电视成品,比自己去买开发板+屏幕还要便宜,省去了焊接不当搞坏的风险。 蜂鸣版+触控升级仅36元,更强的硬件、价格全网最低。

点击购买 固件广场

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操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。
yout