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

Posted DS小龙哥

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言-基本数据类型与位运算相关的知识,希望对你有一定的参考价值。

一、前言

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

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

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

例如: int a;

数据类型可以填哪些?
intcharfloatdoublelongshort 

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

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

intcharshort..都可以存放整型,具体能存放多大的数据?
因为整数的有负数的,所以程序里数据类型分为有符号和无符号。
无符号的关键字: 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 charunsigned 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;

四、位运算知识点

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

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

| 按位或的规则:11,全00
& 按位与的规则:00,全11
>>按位右移的规则: 低位溢出、高位补0
<<按位左移的规则: 高位溢出,低位补0
^异或运算的规则: 相同为0 不同为1

以上是关于C语言-基本数据类型与位运算的主要内容,如果未能解决你的问题,请参考以下文章

Java基础Java基本数据类型与位运算

C语言原码反码补码与位运算.

C语言实验7_宏与位运算

C语言-结构体与位域

第一章 数据储存 1.1 位与位存储

位域与位运算