C语言1 数据类型

简介: C语言1 数据类型

C语言中的数据类型可以分为以下几类:逻辑类型、整数类型、浮点类型、void类型和其他类型。每种类型有其特定的范围和用途。

1. 逻辑类型(布尔类型)


  • 只有两个值:true(非零)和 false(零)。
  • 需要包含头文件 <stdbool.h> 才能使用 bool 类型。
#include <stdio.h>
#include <stdbool.h>
 
int main() {
    bool a = true;  // 声明一个 bool 类型的变量并初始化为 true
    if (a) {
        printf("true %d\n", a); // 输出 1
    } else {
        printf("false %d\n", a);
    }
    return 0;
}


结果:

true 1


2. 整数类型

  • char:字符类型,1字节。
  • 范围:-128~127 或 0~255
  • signed char:有符号字符类型,1字节。
  • 范围:-128~127
  • unsigned char:无符号字符类型,1字节。
  • 范围:0~255
  • short(或 signed short):短整型,2字节。
  • 范围:-32768~32767
  • unsigned short:无符号短整型,2字节。
  • 范围:0~65535
  • int(或 signed int):整型,通常是4字节。
  • 范围:-2147483648~2147483647
  • unsigned int:无符号整型,通常是4字节。
  • 范围:0~4294967295
  • long(或 signed long):长整型,通常是4字节或8字节。
  • 范围:-2147483648~2147483647(4字节)或更大(8字节)
  • unsigned long:无符号长整型,通常是4字节或8字节。
  • 范围:0~4294967295(4字节)或更大(8字节)


char类型示例

#include "stdio.h"
 
int main() {
    char ch = 65;  // 初始化为字符 'A' 的 ASCII 码
    printf("ch=%d %c\n", ch, ch);  // 输出 ch=65 A
    return 0;
}


结果:

#include "stdio.h"
 
int main() {
    signed char sch = -65;
    unsigned char uch = 200;
    printf("sch=%d uch=%u\n", sch, uch);  // 输出 sch=-65 uch=200
    return 0;
}


3. 浮点类型


  • float:单精度浮点型,通常是4字节。
  • 精度大约为6-7位有效数字
  • double:双精度浮点型,通常是8字节。
  • 精度大约为15-16位有效数字
  • long double:扩展精度浮点型,通常是10字节或16字节。

浮点类型示例


#include <stdio.h>
 
int main() {
    float f = 3.14f;
    double d = 3.14;
    long double ld = 3.14L;
    
    printf("float: %f, size: %zu\n", f, sizeof(f));
    printf("double: %f, size: %zu\n", d, sizeof(d));
    printf("long double: %Lf, size: %zu\n", ld, sizeof(ld));
    
    return 0;
}


结果:

float: 3.140000, size: 4
double: 3.140000, size: 8
long double: 3.140000, size: 16


4. void类型

  • void:表示无类型,通常用于函数返回类型和指针。

void类型示例

#include <stdio.h>
 
void printMessage() {
    printf("This is a void function.\n");
}
 
int main() {
    printMessage();
    return 0;
}


结果:

This is a void function.


5. 类型大小的示例

#include <stdio.h>
#include <stdbool.h>
 
int main() {
    printf("Size of bool: %zu bytes\n", sizeof(bool));
    printf("Size of char: %zu bytes\n", sizeof(char));
    printf("Size of short: %zu bytes\n", sizeof(short));
    printf("Size of int: %zu bytes\n", sizeof(int));
    printf("Size of float: %zu bytes\n", sizeof(float));
    printf("Size of double: %zu bytes\n", sizeof(double));
    printf("Size of long double: %zu bytes\n", sizeof(long double));
    printf("Size of long: %zu bytes\n", sizeof(long));
    printf("Size of unsigned long: %zu bytes\n", sizeof(unsigned long));
    return 0;
}


结果:

Size of bool: 1 bytes
Size of char: 1 bytes
Size of short: 2 bytes
Size of int: 4 bytes
Size of float: 4 bytes
Size of double: 8 bytes
Size of long double: 16 bytes
Size of long: 8 bytes
Size of unsigned long: 8 bytes


6.命令行参数

在C语言中,argcargv 用于处理命令行参数。

  • argc:表示命令行参数的个数(包含程序名称)。
  • argv:是一个指针数组,包含命令行参数的字符串。



示例程序

#include <stdio.h>
 
int main(int argc, char *argv[]) {
    printf("Number of arguments: %d\n", argc);
    for (int i = 0; i < argc; i++) {
        printf("Argument %d: %s\n", i, argv[i]);
    }
    return 0;
}


编译并运行:

gcc -o cmdargs cmdargs.c
./cmdargs arg1 arg2


结果:

Number of arguments: 3
Argument 0: ./cmdargs
Argument 1: arg1
Argument 2: arg2


目录
相关文章
|
3月前
|
存储 安全 C语言
C语言中的数据类型
C语言中的数据类型
|
3月前
|
存储 C语言
C语言数据类型、变量和运算符以及printf相关问题
C语言数据类型、变量和运算符以及printf相关问题
|
27天前
|
存储 C语言
【c语言】数据类型和变量
本文介绍了C语言中的数据类型和变量。数据类型分为内置类型和自定义类型,内置类型包括字符型、整型、浮点型等,每种类型有不同的内存大小和取值范围。变量分为全局变量和局部变量,它们在内存中的存储位置也有所不同,分别位于静态区和栈区。通过示例代码和图解,详细阐述了这些概念及其应用。
36 1
|
1月前
|
C语言
3.4 C语言基本数据类型2
在C语言中,声明一个整型(int)变量时,需先写入&#39;int&#39;关键字,后跟变量名并以分号结尾。若同时声明多个变量,可在&#39;int&#39;后用逗号分隔列出所有变量名。例如,`int erns;` 或 `int hogs, cows, goats;` 都是合法声明。变量声明后需通过赋值语句如 `cows = 112;` 或使用函数如 `scanf()` 来初始化其值。
44 10
|
1月前
|
存储 程序员 C语言
3.1 C语言基本数据类型
在C语言中,整数类型如`int`类型是很有用的,它属于有符号整型,意味着该类型的值必须是整数,并且可以是正整数、负整数或者零。`int`类型的数值范围依据计算机系统有所不同,通常取决于系统的位宽。例如,在早期16位的IBM PC兼容机上,`int`类型使用16位存储,取值范围为-32768至32767;而在当前32位系统中,使用32位存储,拥有更宽泛的取值范围。随着64位处理器的普及,`int`类型能够存储的整数范围将进一步扩大。根据ISO C标准,`int`类型的最小取值范围被规定为-32768到32767。系统通常会利用一个特殊的位来表示整数的正负。
34 10
|
1月前
|
C语言
3.1C语言基本数据类型
在C语言中,初始化变量是指为变量设定初始值,通常在声明时直接完成,例如 `int cows=32;`。应注意避免在同一语句中混合初始化与未初始化的变量,如 `int dogs, cats=94;` 这样的写法容易引起误解。此外,整型常量如21、32等在C语言中被视为int类型,但非常大的整数则不然,且带有小数点或指数的数值不属于整型常量。
27 9
|
1月前
|
存储 C语言
初识C语言:常量与变量中寻找数据类型
初识C语言:常量与变量中寻找数据类型
|
2月前
|
存储 C语言 索引
C 语言数据类型详解
C语言中的数据类型主要包括基本数据类型、构造数据类型和用户定义数据类型。基本类型如整型(`int`)、字符型(`char`)、浮点型(`float`)、双精度浮点型(`double`)和无符号整型(`unsigned int`)。构造类型包括数组(`Array`)、结构体(`Struct`)、共用体(`Union`)和枚举(`Enum`)。用户定义类型则通过`typedef`为已有类型定义新名称,并可通过结构体和共用体自定义复合数据结构。此外,还有指针类型用于存储变量地址,以及`signed`、`unsigned`、`short`、`long`等类型修饰符。
81 11
|
2月前
|
存储 C语言
【C语言基础考研向】02 数据类型-常量-变量
本文介绍了编程中的基本概念,包括数据类型分类、常量与变量的定义及使用。首先概述了四大类数据类型:基本类型(整型、浮点、字符型)、构造类型(数组、结构体)、指针类型和空类型。接着阐述了常量与变量的区别及命名规则,并详细说明了整型、浮点型和字符型数据的特点与应用。最后总结了常见的易错点,如字符串与字符常量的区别及浮点数的默认输出格式。
|
1月前
|
存储 编译器 程序员
C语言数据类型详解
C语言数据类型详解