首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C语言】数据类型存储、原码,反码,补码

共同学习交流 ✉️ 我们并非登上我们所选择的舞台,演出并非我们所选择的剧本 ♦  目录  类型的意义: ✨C语言类型分为 ✨构造类型  ✨指针类型类型 ✨函数的返回类型☮ ✨函数的参数☪ 整形在内存当中的存储空间...C语言类型分为 基本类型: 它们是算术类型,包括两种类型:整数类型和浮点类型。 枚举类型: 它们也是算术类型,被用来定义在程序中只能赋予其一定的离散整数值的变量。...枚举类型:enum,这个是C语言的一个关键字,到时候会拿出写一篇给大家着重讲解这个枚举类型C语言当中起到一个什么样子的作用。 联合体类型:union,这个也叫做是共用体,这个我们也现在不说。...(void) { print(); } 函数的参数☪ #include void print()//无参数的话进行传参也是可以的,但是这里没有所以我们C语言并不会进行接收 {...E) 浮点数包括: C语言中的浮点类型有float、double 和 long double 类型

55730
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    存储类型和变量的作用域(C语言

    (2)系统区:存放系统软件(操作系统、语言编译系统等) (3)程序区:存放程序的内存,程序运行时不可被覆盖 (4)数据区:存放程序数据,说明该变量的程序结束时释放 2、变量的存储类型 一个变量的完整定义应该包括数据类型存储类型...用来说明存储类型的保留字有4个:auto(自动)、register(寄存器)、static(静态)、extern(外部)。 (1)自动变量:也称局部变量。用保留字auto表示,通常省略。...存储在堆栈区,从存储位置划分,属于内存变量;从变量的生存期划分,属于动态存储变量。...void demo(){ //在demo中,可以使用全局变量 printf("%d", num1); //但是使用main中的局部变量会报错 printf("%d", num2);} (4)外部类型...存储在内存的应用区,程序运行时一直存在。

    1.1K40

    一文读懂C语言中的存储类型

    存储类型类型」 「作用域」 「生命周期」 「存储位置」 auto变量 一对{}内 当前函数 栈区 static局部变量 一对{}内 整个程序运行期 初始化在data段,未初始化在BSS段 extern...二、内存分区拓扑 内存数据存储 一、视图说明 程序在加载到内存前,代码区和全局区(data和bss)的大小就是固定的,程序运行期间不能改变。...>常量区 const int abc = 123; // 未初始化:全局变量 int a1; // 初始化:全局变量 int b1 = 10; // 未初始化:静态全局变量 static int c1...printf("未初始化全局变量:%p\n", &a1); printf("初始化全局变量:%p\n", &b1); printf("未初始化静态全局变量:%p\n", &c1...数组:008FFB1C 指针变量:008FFB1C 指针地址:008FFB10

    97110

    C语言--数据存储

    目录 1、数据类型介绍 1.1、类型的基本归类 2、整形在内存中的存储 2.1、原码、反码、补码 2.2 大小端 2.3 练习题 3....、浮点型在内存中的存储 3.1 一个例子 3.2 浮点数存储规则 ---- 1.数据类型介绍 基本的内置类型: char   字符数据类型                                                                                                                         ...表示空类型(无类型)   通常应用函数的返回类型、函数的参数、指针类型 2.整型在内存中的存储 我们都知道,创建一个变量是要在内存中开辟空间,空间的大小是根据不同的类型而决定的。...但是在C语言中除了8 bit的char之外,还有16 bit的short型,32 bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节...我们常用的 X86 结构是小端模式,而 KEIL C51 则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。 2.3 练习题 3.

    1.7K20

    C51 存储类型存储模式

    ---- 在C51中对变量进行定义的格式如下: 【存储种类】数据类型存储类型】 变量名列表;  其中存储种类和存储类型是可选项,当变量名列表中的变量不止一个时,用逗号隔开。...通常C51编译器会自动识别程序中使用频率最高的变量,并自动将其作为寄存器变量,程序员无需专门声明。 变量的存储种类和存储类型是不一样的。存储类型指明该变量所处的内存空间。...使用不同的存储类型,程序会有不同的执行效率,在编写C51程序时,推荐指定变量的存储类型,这样有利于提高程序的执行效率。...#define 定义:    例: #define #define PORTA XBYTE[0x8003] /*将PORTA定义为外部I/O口,其地址为0x8003*/,长度为一个字节...3、指针的存储类型   C51编译器支持两种不同类型的指针:存储器指针和通用指针 (1)通用指针     通用或未定型的指针的声明和标准C语言中一样。

    1.7K20

    C语言——枚举类型

    一,什么是枚举类型 简单来说,枚举类型就是可以让我们给整数值分配有意义的名字,从而使得代码更易读、易维护 二,枚举类型的定义和变量的声明 1,如何定义和声明 枚举类型的定义和变量的声明方式也与结构体和联合体相似...如果我们在创建枚举变量时,为未给成员进行初始化赋值,则C语言会自动赋值 遵循:默认从0开始,依次增1 如果只有前几个值,那么后面未被赋值的成员也会被自动赋值,遵循依次增1 例子一(不赋值)...存在同名的枚举成员 enum color1 { red, yellow, blue }; enum color2 { red, black, white }; 三,对变量进行赋值 1,使用成员赋值 ⭐C语言中的枚举变量通常只能被赋值为枚举类型中定义的成员...blue = 3 }; int main() { enum color a, b, c; a = red; b = yellow; c = blue; return 0; } 2,强制类型转化...blue = 3 }; int main() { enum color c; c = (enum color)10; //强制类型转换 printf("%d\n", c); return 0

    55411

    C语言(枚举类型

    C语言中的枚举类型常年跑龙套当配角,不受待见,这当然是有其个人原因的。今天来个小知识,看看枚举为什么那么衰,也顺便看看怎么用。 我们先来回忆一下为什么需要枚举,枚举究竟是个什么东东?...这么看来,枚举是一种挺好玩也挺有用的东西,但是在C语言中怎么就不受待见了呢?...原因是C语言只提供了一种阉割版的枚举,以上两大目的在C中实质上都是没有实现的,也就是说,在C语言中,实际情况是这样的: color = blue; // 正确,此时color就是5 color = 5;...此时color就是blue color = 8; // 正确,8是整型,跟枚举完全没有任何区别 color = red + orange; // 正确,完全等价于 color = 1+2 你看明白了吧,C语言中的所谓枚举其实就是个坑爹货...枚举的真正实现,在C++中才有实现。

    1.8K30

    C语言 | 求字符串的长度

    “要成为绝世高手,并非一朝一夕,除非是天生武学奇才,但是这种人…万中无一” ——包租婆 这道理放在C语言学习上也一并受用。...在编程方面有着天赋异禀的人毕竟是少数,我们大多数人想要从C语言小白进阶到高手,需要经历的是日积月累的学习。 那么如何学习呢?当然是每天都练习一道C语言题目!! ? 作者 闫小林 白天搬砖,晚上做梦。...例78:C语言写一个函数,求一个字符串的长度,在main函数中输入字符串,并输出其长度,要求用指针。...解题思路:求字符串的长度,还要求用指针,读者首先应该想一下不用指针是否可以,求字符串的长度需要判断字符串的结束标志。...C语言源代码演示: #include//头文件 int main()//主函数 { int sum_Length(char *point);//函数声明 int len;

    2.9K42

    C语言条件运算符_c语言数组长度可变吗

    如果希望获得两个数中最大的一个,可以使用 if 语句,例如: if(a>b){ max = a; }else{ max = b; } 不过,C语言提供了一种更加简单的方法...表达式2 : 表达式3 条件运算符是C语言中唯一的一个三目运算符,其求值规则为:如果表达式1的值为真,则以表达式2 的值作为整个条件表达式的值,否则以表达式3的值作为整个条件表达式的值。...a : c>d ? c : d; 应理解为: a>b ? a : ( c>d ? c : d ); 这也就是条件表达式嵌套的情形,即其中的表达式又是一个条件表达式。...本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

    1.2K20

    C语言 | 求字符串的长度

    例78:C语言写一个函数,求一个字符串的长度,在main函数中输入字符串,并输出其长度,要求用指针。...解题思路:求字符串的长度,还要求用指针,读者首先应该想一下不用指针是否可以,求字符串的长度需要判断字符串的结束标志。...C语言源代码演示: #include//头文件  int main()//主函数  {   int sum_Length(char *point);//函数声明    int len;...//定义整型变量    char str[20];//定义字符数组    printf("请输入要求长度的字符串:");//提示语句    scanf("%s",str);//因为str是数组,不用加取地址符...以上,如果你看了觉得对你有所帮助,就给小林点个赞,分享给身边的人叭,这样小林也有更新下去的动力,跪谢各位父老乡亲啦~ C语言学习路线     C语言开发工具 跟多案例可以go公众号:C语言入门到精通

    3.3K32

    C语言如何计算数组的长度

    main() { // 定义一个整型数组, 并进行初始化赋值9个数据 : int arr[] = {1,2,3,4,5,6,7,8,9}; int length = 0; // 计算数组中数据长度...: // 所有数据的字节数除以一个数据的字节数即为数据的个数 : length = sizeof(arr) / sizeof(int); printf(“数组的长度为: %d\n”,length...); return 0; } 执行结果 : (2)上面的方法会出现一个误区 那就是当数组作为实参传递到另一个函数时, 而这个函数执行了上面同样的方法, 结果出来的不会正确的数组的长度 : 测试代码...: // 所有数据的字节数除以一个数据的字节数即为数据的个数 : length = sizeof(arr) / sizeof(int); printf(“main_数组的长度为: %d\n”...(这样是得不到准确的数组的长度的, 建议的操作是在定义数组的函数中计算数组的长度, 在以实参的形式传递出去, 这样其他的函数变可以获得数组的长度) 发布者:全栈程序员栈长,转载请注明出处:https:

    2.7K30

    初识C语言·数据存储

    3 整数存储练习题 代码1: int main() { char a = -1; signed char b = -1; unsigned char c = -1; printf("a=%d,b...=%d,c=%d", a, b, c); return 0; } 问:代码的运行结果是什么?...在vs里面char ,signed  char类型是一样的所以两个的结果是一样的,因为-1的补码是32个1,截断8个bit位之后,就是11111111,进行整型提升,对符号位进行提升,最后也是32个1,...所以a b的结果都是-1,那么,unsigned char类型的没有符号位,全是数值位,截断之后是11111111,提升之后是32个1,32个1也就是2^8 -  1,所以c是255。...数值的读入可以认为是一个循环,char类型的循环可以认为是-1 ……-128 127 126 ……0,可以认为是这样的一个循环,所以char a[1000]里面的数值也是这样的,那么从-1 到 0 一共有

    7010

    C语言之数据存储

    C语言中数据在内存中的存储 文章目录 C语言中数据在内存中的存储 1.数据类型的介绍 2.整形在内存中的存储 2.1原码,反码,补码 2.2大小端字节序 2.3试题练习 3.浮点数在内存中的存储...3.1.浮点数在计算机内部的表示方法 3.2.浮点数的存储规则 3.3.一个练习题 写在最后 1.数据类型的介绍 C语言中具体由哪些数据结构: ps: 1.这里需要提醒大家的就是其实char也是整形家族的...但是在C语言中除了8 bit的char之外,还有16 bit的short型,32 bit的long型(要看具体的编译器)。...C语言标准规定: 1.当一个数超过该类型数据所能存储的最大值就发生截断。如八个比特位的char存储32个比特位的int时只存储最后面的八个比特位。...因此,即使是两个char类型的相加,在CPU执行时实际上也要先转换位CPU内整形操作数的标准长度

    1.5K00

    C语言——数据的存储

    目录 数据类型介绍 整型家族 浮点数家族:  构造类型:  指针类型类型 原码 反码 补码 大小端介绍 大端小端 数据类型介绍 相信大家应该已经了解了基本的数据类型吧 整型家族 char 为什么归根到...因为:char虽然是字符类型,但是字符类型储存的时候,存储的字符的ascii码值 ascii值是整数。...有正负的数据可以存放在有符号的变量中 只有正数的数据可以存放在无符号的变量中 浮点数家族:  构造类型:  指针类型类型 原码 反码 补码 计算机中的整数有三种表示方法,即原码、反码和补码...反码:将原码的的符号位不变,其他位依次取反就可以得到了 补码:反码加一就是补码 对于整数来说,数据存放内存中其实存放的是补码 大小端介绍 大端小端 大端(存储)模式,是指数据的低位保存在内存的高地址中...,而数据的高位,保存在内存的低地址 中; 小端(存储)模式,是指数据的低位保存在内存的低地址中,而数据的高位,,保存在内存的高地 址中

    1.4K10

    C语言】数据的存储

    一、整形在内存中的存储 1....大小端的存储模式 大端(存储)模式:是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中; eg:0x11223344 小端(存储)模式:是指数据的低位保存在内存的低地址中,而数据的高位...8个比特位,所以会截断前面的24位,截断后是:11111111,现在a,b,c中放的都是11111111,然后根据需要打印的类型进行整型提升,例如a,是要按照%d的形式打印,而且它不是unsigned类型...类型,如果是,就忽略符号位,直接补0,例如 unsigned char c=-1中,截断后发生整型提升后是:00000000000000000000000011111111(补码),由于unsigned...是无符号数,原反补码相同,直接计算得出结果为c = 255;若不是unsigned类型,需要补回原来的符号位,然后转成反码,再转成原码得出结果,a = b = -1. (2)计算结果 int main

    13810

    C语言详解(数据存储

    1、大小端字节序和字节序判断 在 C语言(操作符)1 中,我们介绍了整数在内存中的存储,但是我们只介绍了整数的存储形式,并没有介绍整数是如何存储的,那本节我们就来探讨一下整数在内存中究竟是怎么存储的...(其实我们在C语言(操作符)2中的表达式求值部分已经学习过)我们来分析一下: 我们想将整数-1存入一个字符型变量a中,整型和字符型不兼容,通过C语言(操作符)2的学习我们知道要发生截断,...char类型占一个字节也就是8个比特位,最高位当做符号位来看待,就剩下了7位存0、1值。 在C语言(操作符)2中,我们还画了这样一个图,并做了相应解释。...,然后strlen求字符数组a的长度。...\0,所以求的是-1~0的长度,是255。

    8110
    领券