c89、c99、c11

C99 标准开始引入了 // 单行注释。在此之前,C语言只支持 /* ... */ 多行注释。

具体说明:

  • // 单行注释:在C99标准(ISO/IEC 9899:1999)引入之前,C语言中没有单行注释。C99标准借鉴了C++的注释风格,引入了这种单行注释。
  • /* ... */ 多行注释:自C语言的早期版本(包括C89和ANSI C)以来就已经存在。

示例:

在C99之前(例如,使用ANSI C标准的编译器):

int main() {
    /* 这是一个多行注释 */
    int a = 10;
    /* 这是
       一个多行
       注释 */
    return 0;
}

在C99及之后:

int main() {
    // 这是一个单行注释
    int a = 10;
    // 这是另一个单行注释
    return 0;
}

在现代C编译器中(C99及之后),可以混合使用这两种注释:

int main() {
    // 这是一个单行注释
    int a = 10; /* 这是一个多行注释 */
    return 0;
}

总结:

  • // 单行注释是从C99标准开始引入的。
  • /* ... */ 多行注释从C语言的早期版本(包括C89和ANSI C)就已经存在。

C89(也称为ANSI C)和C99是两个主要的C语言标准,它们之间有许多显著的区别。以下是一些关键区别及相应的示例:

1. 单行注释

  • C89:不支持 // 单行注释。
  • C99:支持 // 单行注释。

示例

// 这是一个C99支持的单行注释
int a = 10; // 这是一个单行注释

2. 变量声明

  • C89:变量必须在函数块的开头声明。
  • C99:变量可以在代码块中的任意位置声明。

示例

// C89
void example() {
    int a = 10;
    /* 必须在这里声明所有变量 */
    int b = 20;
    a = a + b;
}

// C99
void example() {
    int a = 10;
    a = a + 10;
    int b = 20; // 可以在任意位置声明变量
    a = a + b;
}

3. 复合字面量

  • C89:不支持复合字面量。
  • C99:支持复合字面量。

示例

// C99
struct Point {
    int x, y;
};
struct Point p = (struct Point){.x = 1, .y = 2}; // 复合字面量

4. 变长数组

  • C89:不支持变长数组。
  • C99:支持变长数组。

示例

// C99
void example(int n) {
    int arr[n]; // 变长数组
    for (int i = 0; i < n; i++) {
        arr[i] = i;
    }
}

5. 内联函数

  • C89:不支持 inline 关键字。
  • C99:支持 inline 关键字。

示例

// C99
inline int add(int a, int b) {
    return a + b;
}

6. 数据类型扩展

  • C89:没有 long long 数据类型。
  • C99:引入了 long long 数据类型(至少64位)。

示例

// C99
long long bigNumber = 123456789012345LL;

7. __func__ 预定义标识符

  • C89:没有 __func__ 预定义标识符。
  • C99:引入了 __func__ 预定义标识符,用于获取当前函数的名称。

示例

// C99
#include <stdio.h>

void example() {
    printf("Function name: %s\n", __func__);
}

8. 初始化增强

  • C89:初始化结构体和数组时必须按顺序进行。
  • C99:允许使用指定初始化器(designated initializers)。

示例

// C99
struct Point {
    int x, y;
};
struct Point p = {.y = 2, .x = 1}; // 指定初始化器

这些示例展示了C99对C89的多方面增强,使C语言变得更为灵活和功能强大。


C11 是 C 语言的一个标准,全称为 ISO/IEC 9899:2011,相对于 C99 进一步引入了一些新特性和改进。以下是 C11 相对于 C99 和 C89 的一些主要区别及相应的示例:

1. _Generic 选择表达式

  • C89/C99:不支持 _Generic 选择表达式。
  • C11:引入了 _Generic 选择表达式,用于泛型编程。

示例

// C11
#include <stdio.h>

#define type_of(x) _Generic((x), \
    int: "int", \
    float: "float", \
    double: "double", \
    default: "other")

int main() {
    int i = 0;
    float f = 0.0;
    printf("i is %s\n", type_of(i)); // 输出:i is int
    printf("f is %s\n", type_of(f)); // 输出:f is float
    return 0;
}

2. 匿名结构体和联合体

  • C89/C99:不支持匿名结构体和联合体。
  • C11:支持匿名结构体和联合体。

示例

// C11
struct {
    union {
        int i;
        float f;
    };
} u;

int main() {
    u.i = 10;
    printf("%d\n", u.i); // 输出:10
    u.f = 5.5;
    printf("%f\n", u.f); // 输出:5.500000
    return 0;
}

3. 静态断言

  • C89/C99:不支持静态断言。
  • C11:引入了 _Static_assert 关键字,用于在编译时进行静态断言。

示例

// C11
#include <assert.h>

_Static_assert(sizeof(int) == 4, "int size is not 4 bytes");

int main() {
    return 0;
}

4. 线程支持

  • C89/C99:不提供标准化的线程支持。
  • C11:引入了 threads.h,提供对多线程的标准支持。

示例

// C11
#include <stdio.h>
#include <threads.h>

int thread_func(void *arg) {
    printf("Hello from thread!\n");
    return 0;
}

int main() {
    thrd_t t;
    thrd_create(&t, thread_func, NULL);
    thrd_join(t, NULL);
    return 0;
}

5. 对齐支持

  • C89/C99:不提供对齐支持。
  • C11:引入了 _Alignof_Alignas 关键字,用于指定和查询类型对齐要求。

示例

// C11
#include <stdio.h>
#include <stdalign.h>

struct S {
    char c;
    _Alignas(16) int i;
};

int main() {
    printf("Alignment of char: %zu\n", alignof(char)); // 输出:1
    printf("Alignment of int: %zu\n", alignof(int)); // 输出:4
    printf("Alignment of struct S: %zu\n", alignof(struct S)); // 输出:16
    return 0;
}

6. 预定义宏

  • C89/C99:不支持新的预定义宏。
  • C11:引入了新的预定义宏,例如 __STDC_VERSION__

示例

// C11
#include <stdio.h>

int main() {
    #if __STDC_VERSION__ >= 201112L
        printf("C11 or later\n");
    #else
        printf("Before C11\n");
    #endif
    return 0;
}

7. 可选特性宏

  • C89/C99:不支持可选特性宏。
  • C11:引入了可选特性宏,例如 __STDC_NO_THREADS__

示例

// C11
#include <stdio.h>

int main() {
    #ifdef __STDC_NO_THREADS__
        printf("Threads are not supported\n");
    #else
        printf("Threads are supported\n");
    #endif
    return 0;
}

8. 更严格的类型检查

  • C89/C99:类型检查不如 C11 严格。
  • C11:引入了更严格的类型检查和标准库改进。

C11 标准通过引入这些新特性和改进,使得 C 语言变得更加现代化、灵活和安全,特别是在泛型编程、静态断言、多线程和内存对齐等方面提供了显著的增强。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/736823.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Redis 的安装与部署

本文为Redis的Linux版单机部署。 上传 redis-3.2.8 源码到 /opt/software/ 解压到 /opt/module/ [huweihadoop101 software]$ tar -zxvf redis-3.2.8.tar.gz -C /opt/module/安装依赖 [huweihadoop101 software]$ sudo yum -y install gcc-c tclRedis是C语言编写的 编译安装…

(南京观海微电子)——DC-DC和LDO的原理及应用区别

LDO: 低压差线性稳压器&#xff0c;故名思意为线性的稳压器&#xff0c;仅能使用在降压应用中&#xff0c;也就是输出电压必需小于输入电压。 优点&#xff1a;稳定性好&#xff0c;负载响应快&#xff0c;输出纹波小。 缺点&#xff1a; 效率低&#xff0c;输入输出的电压…

Linux使用——查看发行版本、内核、shell类型等基本命令

先做快照 虚拟机中编辑网络 关机 普通账户和管理员账户 互相对照 localhost相当于IP 参数: 短格式:以减号(-)开头&#xff0c;参数字母 长格式:以2个减号(--)后跟上完整的参数单词 当前发行版本 [rootserver ~]# cat /etc/redhat-release Red Hat Enterprise Linux release 9.…

.hmallox勒索病毒解密方法|勒索病毒解决|勒索病毒恢复|数据库修复

导言&#xff1a; 在当今数字化时代&#xff0c;勒索病毒已经成为网络安全的一大威胁&#xff0c;其中包括了最近出现的.hmallox勒索病毒。这类恶意软件不仅能够对计算机系统进行加密&#xff0c;还会要求用户支付赎金以换取解密密钥&#xff0c;给个人用户和企业带来了严重的…

Java面试题:数据库索引

数据库索引 索引:index 帮助mysql高效获取数据的数据结构,在数据之外,数据库系统还维护着满足特定查找算法的数据结构(B树),这些数据结构以某种方式引用(指向数据),这样就可以在数据结构上实现高级查找算法 将数据以树的方式进行存储,提高查找效率 索引的底层结构 使用B树 …

React AntDesign Layout组件布局刷新页面错乱闪动

大家最近在使用React AntDesign Layout组件布局后刷新页面时&#xff0c;页面布局错乱闪动 经过组件属性的研究才发现&#xff0c;设置 hasSider 为 true 就能解决上面的问题&#xff0c;耽搁了半天的时间&#xff0c;接着踩坑接着加油&#xff01;&#xff01;&#xff01; …

XTDrone-多无人机精准降落-配置教程

1 编译AprilTag_ROS AprilTag是一个视觉基准系统&#xff0c;可用于机器人&#xff0c;增强现实和相机校准等。 根据AprilTag可以可靠地计算标签相对于相机的3D位置&#xff0c;方向和ID号。这里我们使用AprilTag的ROS库来实现位姿估计与ID号计算。 编译命令如下&#xff1a; …

Linux 7种 进程间通信方式

传统进程间通信 通过文件实现进程间通信 必须人为保证先后顺序 A--->硬盘---> B&#xff08;B不知道A什么时候把内容传到硬盘中&#xff09; 1.无名管道 2.有名管道 3.信号 IPC进程间通信 4.消息队列 5.共享内存 6.信号灯集 7.socket通信 一、无名管道&a…

基于I2C协议的AHT20温湿度传感器的数据采集

一、I2C总线通信协议 软件I2C 软件I2C&#xff0c;也称为模拟I2C或bit-bang I2C&#xff0c;是一种通过微控制器的通用输入输出&#xff08;GPIO&#xff09;引脚来模拟I2C总线通信的方式。它不依赖于专门的硬件I2C接口&#xff0c;而是通过编程控制GPIO引脚的电平状态来实现I…

我在高职教STM32——LCD液晶显示(3)

大家好&#xff0c;我是老耿&#xff0c;高职青椒一枚&#xff0c;一直从事单片机、嵌入式、物联网等课程的教学。对于高职的学生层次&#xff0c;同行应该都懂的&#xff0c;老师在课堂上教学几乎是没什么成就感的。正因如此&#xff0c;才有了借助 CSDN 平台寻求认同感和成就…

前端开发流程与技术选型

目录 一、简介 二、前端职责 三、开发步骤 四、技术选型 五、页面展示 一、简介 做一个网站时&#xff0c;能看到的一切都是前端程序员的工作&#xff0c;负责网页或者app的结构、样式、用户操作网站时的事件逻辑&#xff08;比如点击一个按钮&#xff09;。 二、前端职…

一、系统学习微服务遇到的问题集合

1、启动了nacos服务&#xff0c;没有在注册列表 应该是版本问题 Alibaba-nacos版本 nacos-文档 Spring Cloud Alibaba-中文 Spring-Cloud-Alibaba-英文 Spring-Cloud-Gateway 写的很好的一篇文章 在Spring initial上面配置 start.aliyun.com 重新下载 < 2、 No Feign…

嵌入式系统中的加解密签名

笔者来了解一下嵌入式系统中的加解密 1、背景与名词解释 笔者最近在做安全升级相关的模块&#xff0c;碰到了一些相关的概念和一些应用场景&#xff0c;特来学习记录一下。 1.1 名词解释 对称加密&#xff1a;对称加密是一种加密方法&#xff0c;使用相同的密钥&#xff08;…

力扣刷题 杨辉三角(使用c++ vector解法)

杨辉三角 题目描述示例1示例2提示:代码 题目描述 给定一个非负整数 numRows&#xff0c;生成「杨辉三角」的前 numRows 行。 在「杨辉三角」中&#xff0c;每个数是它左上方和右上方的数的和。 示例1 输入: numRows 5 输出: [[1],[1,1],[1,2,1],[1,3,3,1],[1,4,6,4,1]] 示例2 …

4、SpringMVC 实战小项目【加法计算器、用户登录、留言板、图书管理系统】

SpringMVC 实战小项目 3.1 加法计算器3.1.1 准备⼯作前端 3.1.2 约定前后端交互接⼝需求分析接⼝定义请求参数:响应数据: 3.1.3 服务器代码 3.2 ⽤⼾登录3.2.1 准备⼯作3.2.2 约定前后端交互接⼝3.2.3 实现服务器端代码 3.3 留⾔板实现服务器端代码 3.4 图书管理系统准备后端 3…

【内存管理】页面分配机制

前言 Linux内核中是如何分配出页面的&#xff0c;如果我们站在CPU的角度去看这个问题&#xff0c;CPU能分配出来的页面是以物理页面为单位的。也就是我们计算机中常讲的分页机制。本文就看下Linux内核是如何管理&#xff0c;释放和分配这些物理页面的。 伙伴算法 伙伴系统的…

Visual Studio开发环境搭建

原文&#xff1a;https://blog.c12th.cn/archives/25.html Visual Studio开发环境搭建 测试&#xff1a;笔记本原装操作系统&#xff1a;Windows 10 家庭中文版 资源分享链接&#xff1a;提取码&#xff1a;qbt2 注意事项&#xff1a;注意查看本地硬盘是否够用&#xff0c;建议…

在阿里云使用Docker部署MySQL服务,并且通过IDEA进行连接

阿里云使用Docker部署MySQL服务&#xff0c;并且通过IDEA进行连接 这里演示如何使用阿里云来进行MySQL的部署&#xff0c;系统使用的是Linux系统 (Ubuntu)。 为什么使用Docker? 首先是因为它的可移植性可以在任何有Docker环境的系统上运行应用&#xff0c;避免了在不通操作系…

SpringBoot+ENC实现密钥加密及使用原理

&#x1f60a; 作者&#xff1a; 一恍过去 &#x1f496; 主页&#xff1a; https://blog.csdn.net/zhuocailing3390 &#x1f38a; 社区&#xff1a; Java技术栈交流 &#x1f389; 主题&#xff1a; SpringBootENC实现密钥加密及使用原理 ⏱️ 创作时间&#xff1a; 202…

AtCoder Beginner Contest 359 A~C(D~F更新中...)

A.Count Takahashi 题意 给出 N N N个字符串&#xff0c;每个字符串为以下两种字符串之一&#xff1a; "Takahashi" "Aoki" 请你统计"Takahashi"出现了多少次。 分析 输入并统计即可。 代码 #include <bits/stdc.h>using namespa…