Jump to content
  • Hello visitors, welcome to the Hacker World Forum!

    Red Team 1949  (formerly CHT Attack and Defense Team) In this rapidly changing Internet era, we maintain our original intention and create the best community to jointly exchange network technologies. You can obtain hacker attack and defense skills and knowledge in the forum, or you can join our Telegram communication group to discuss and communicate in real time. All kinds of advertisements are prohibited in the forum. Please register as a registered user to check our usage and privacy policy. Thank you for your cooperation.

    TheHackerWorld Official

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

 Share


NedK7

Recommended Posts

 

一、前言

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

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

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

例如: int a;

数据类型可以填哪些?
intcharfloatdoublelongshort 

每个数据类型有什么区别?
int 用来存放整型数据。比如: 123456、-678
char 用来字符和整型数据。比如:12325'A''K'
float 用来浮点数类型的数据(单精度)。比如: 12.34 12.0  56.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 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;
}

四、位运算知识点

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

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

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

 Share

discussion group

discussion group

    You don't have permission to chat.
    • Recently Browsing   0 members

      • No registered users viewing this page.
    ×
    ×
    • Create New...