C语言-基本数据类型与位运算

简介: 这篇文章作为基础知识点,总结C语言的基本数据类型有哪些,浮点数的精度,整数变量的空间范围,变量定义语法,变量命名规则,浮点数打印格式,基本数据类型printf对应的打印、位运算的知识点。

一、前言

这篇文章作为基础知识点,总结C语言的基本数据类型有哪些,浮点数的精度,整数变量的空间范围,变量定义语法,变量命名规则,浮点数打印格式,基本数据类型printf对应的打印、位运算的知识点。

二、变量的定义语法与数据类型

<数据类型> <变量名称>;

例如: int a;

数据类型可以填哪些?
int、char、float、double、long、short 

每个数据类型有什么区别?
int 用来存放整型数据。比如: 123、456、-678
char 用来字符和整型数据。比如:123、2、5、'A'、'K'
float 用来浮点数类型的数据(单精度)。比如: 12.34 、12.0 、 56.789
double 用来浮点数类型的数据(双精度)。
long 用来存放整型数据。
short 用来存放整型数据。

int、char、short..都可以存放整型,具体有什么区别?
每个数据类型所占用的空间大小不一样。
int 类型 占4个字节
char类型 占1个字节
short类型占2个字节

int、char、short..都可以存放整型,具体能存放多大的数据?
因为整数的有负数的,所以程序里数据类型分为有符号和无符号。
无符号的关键字: unsigned
比如: int类型定义就有以下方式
unsigned int a; //表示不存放符号位,4个字节=32位,全部存放有效数据。 最大值: 0~4294967295
int a; //表示存放符号位,4个字节=32位,除了最高位其他位存放有效数据。 最大值: -2147483646  ~ +2147483647
unsigned char b; //存放的数据范围: 1个字节=8位    存放范围:0~255   0x00 ~ 0xFF
char b;//存放的数据范围: 1个字节=8位    存放范围: -128  -  +127  

float,double ..都可以存放浮点数,具体的区别?
float 存放单精度浮点数.  占空间4个字节。精确到小数点后6位。
double 存放双精度浮点数. 占空间8个字节。精确到小数点后10位。

unsigned 关键字可以声明哪些数据类型? 只能声明整型。 unsigned char 、 unsigned int 

<变量名称>  是如何命名的?有什么要求?
变量名的首字母必须是: 字母或者是_ (下划线)、 首字符之后可以是数字。
命名规则: 'A'到'Z' 'a' 到 'z'  '0'到'9'  '_'
后面函数名称、数组的名称、结构体......都遵循该命名规则。

变量名称有没有长度限制? 一般限定32个字符。

示例代码验证结果

#include <stdio.h>
int main(int argc,char *argv[])
{   
    unsigned char a=256;
    char b=128;
    printf("a=%d\n",a); //0
    printf("b=%d\n",b);//-128
    return 0;
}

#include <stdio.h>
int main(int argc,char *argv[])
{   
    printf("int=%d\n",sizeof(int));  //4字节
    printf("unsigned int=%d\n",sizeof(unsigned int)); //4字节
    printf("float=%d\n",sizeof(float)); //4字节
    printf("short=%d\n",sizeof(short)); //2字节
    printf("double=%d\n",sizeof(double)); //8字节
    printf("char=%d\n",sizeof(char)); //1字节
    printf("123=%d\n",sizeof(123));//4字节
    return 0;
}

三、整数、浮点数格式前缀和打印格式

#include <stdio.h>
int main(int argc,char *argv[])
{   
    int a=7;     //十进制
    int b=0x7;   //十六进制
    int c=07;   //8进制
    int d=0b0111; //二进制   gcc是支持。
    printf("%d\n",a);
    printf("%d\n",b);
    printf("%d\n",c);
    printf("%d\n",d);
    return 0;
}

#include <stdio.h>
int main(int argc,char *argv[])
{   
    unsigned int a=100;
    int b=200;
    float c=12.34;
    double d=456.789;
    long f=456;

    printf("%u\n",a);
    printf("%d\n",b);
    printf("%.2f\n",c);
    printf("%.3f\n",d);
    printf("%ld\n",f);
    return 0;
}

#include <stdio.h>
int main(int argc,char *argv[])
{   
    printf("%10d\n",123);  //左补齐空格
    printf("%-10d,%d\n",123,456);  //右边补齐空格
    return 0;
}
#include <stdio.h>
int main(int argc,char *argv[])
{   
    printf("%#x\n",255);  //16进制
    printf("%#d\n",255);  //10进制
    printf("%#o\n",255); //八进制
    return 0;
}

四、位运算知识点

位运算: ~ 按位取反、| 按位或  & 按位与  >>按位右移  <<按位左移   ^异或运算
逻辑运算符: || 逻辑或  && 逻辑与   !逻辑非  (逻辑只有真假 0和1  非0即为真)

~ 按位取反的规则:  0为1、1为0
例如:  
unsigned char a=0x38;
00111000
11000111
~a等于11000111

| 按位或的规则:  有1为1,全0为0
& 按位与的规则:  有0为0,全1为1
>>按位右移的规则: 低位溢出、高位补0
<<按位左移的规则: 高位溢出,低位补0
^异或运算的规则: 相同为0 不同为1
目录
相关文章
|
1月前
|
存储 安全 C语言
C语言中的数据类型
C语言中的数据类型
|
1月前
|
存储 C语言
C语言数据类型、变量和运算符以及printf相关问题
C语言数据类型、变量和运算符以及printf相关问题
|
9天前
|
存储 C语言 索引
C 语言数据类型详解
C语言中的数据类型主要包括基本数据类型、构造数据类型和用户定义数据类型。基本类型如整型(`int`)、字符型(`char`)、浮点型(`float`)、双精度浮点型(`double`)和无符号整型(`unsigned int`)。构造类型包括数组(`Array`)、结构体(`Struct`)、共用体(`Union`)和枚举(`Enum`)。用户定义类型则通过`typedef`为已有类型定义新名称,并可通过结构体和共用体自定义复合数据结构。此外,还有指针类型用于存储变量地址,以及`signed`、`unsigned`、`short`、`long`等类型修饰符。
43 11
|
8天前
|
存储 C语言
【C语言基础考研向】02 数据类型-常量-变量
本文介绍了编程中的基本概念,包括数据类型分类、常量与变量的定义及使用。首先概述了四大类数据类型:基本类型(整型、浮点、字符型)、构造类型(数组、结构体)、指针类型和空类型。接着阐述了常量与变量的区别及命名规则,并详细说明了整型、浮点型和字符型数据的特点与应用。最后总结了常见的易错点,如字符串与字符常量的区别及浮点数的默认输出格式。
|
11天前
|
存储 C语言
C语言程序设计核心详解 第十章:位运算和c语言文件操作详解_文件操作函数
本文详细介绍了C语言中的位运算和文件操作。位运算包括按位与、或、异或、取反、左移和右移等六种运算符及其复合赋值运算符,每种运算符的功能和应用场景都有具体说明。文件操作部分则涵盖了文件的概念、分类、文件类型指针、文件的打开与关闭、读写操作及当前读写位置的调整等内容,提供了丰富的示例帮助理解。通过对本文的学习,读者可以全面掌握C语言中的位运算和文件处理技术。
|
11天前
|
存储 编译器 程序员
c语言基本数据类型详解
在 C 语言中,基本数据类型用于存储不同类型的数据,并在内存中分配不同大小的空间,如 `char`(1 字节)、`int`(4 字节)、`short`(2 字节)、`long`(4 或 8 字节)、`float`(4 字节)和 `double`(8 字节)。此外,还有 `void` 和用 `int` 类型替代的 `bool` 类型。这些数据类型的存储空间大小可能因编译器和平台的不同而有所变化,但通常遵循上述规则。选择合适的数据类型可以充分利用内存空间并确保数据准确性。C 语言还支持用户自定义数据类型,如结构体和枚举类型,用于描述复杂的数据结构。
|
12天前
|
C语言
C语言程序设计核心详解 第二章:数据与数据类型 4种常量详解 常见表达式详解
本文详细介绍了C语言中的数据与数据类型,包括常量、变量、表达式和函数等内容。常量分为整型、实型、字符型和字符串常量,其中整型常量有十进制、八进制和十六进制三种形式;实型常量包括小数和指数形式;字符型常量涵盖常规字符、转义字符及八进制、十六进制形式;字符串常量由双引号括起。变量遵循先定义后使用的规则,并需遵守命名规范。函数分为标准函数和自定义函数,如`sqrt()`和`abs()`。表达式涉及算术、赋值、自增自减和逗号运算符等,需注意运算符的优先级和结合性。文章还介绍了强制类型转换及隐式转换的概念。
|
1月前
|
C语言
C语言------数据类型与输入输出
这篇文章是C语言的数据类型与输入输出实训教程,通过示例代码演示了整型、实型、字符型数据的定义、使用和输出,以及如何使用printf()和scanf()函数进行格式化输出和输入。
C语言------数据类型与输入输出
|
1月前
|
存储 编译器 C语言
【C语言篇】C语言数据类型和变量
我们使⽤强制类型转换都是万不得已的时候使用,如果不需要强制类型转化就能实现代码,这样⾃然更好的.
|
1月前
|
C语言
C语言数据类型和变量
C语言数据类型和变量
32 5