c语言基础 printf函数和格式控制

本文介绍了C语言中ASCII与UNICODE编码的区别,包括UTF-8、UTF-16和UTF-32的字节占用,并探讨了宽字节字符与单字节字符的定义。同时,详细阐述了printf函数的各种格式化输出,如%c、%d、%s、%p等,并通过实例展示了%n的潜在安全问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ASCII:编码一个字节
UNICODE:两个或四个字节 utf-8(一个字节 变长度的 可以为1 2 4个字节 可以减少传输量,多用于web 网络) utf-16(一个字符占两个字节 Windows驱动内核的编码规则) utf-32(linux、苹果平台 一个字符占四个字节)
多字节字符串(multibyte) 例: “hello!中国”
单字节字符定义:char c //有符号或者无符号由编译器决定 vc中有符号
宽字节字符定义:wchar_t wc
’0’ 0 ‘\0’ NULL的区别
字符型(ASCII 48)
整型
字符串结尾字符就是0
指针类型word *
100I64的含义 8字节64位整数 去存储100

打印字符

%c打印字符
%wc或者%C打印宽字符
%d打印整数
%ld打印长整数
%I64d(__int64(两个下划线))打印64位整数
%Iid(long long或者__int64)8字节整数
%s打印字符串
%ws%S打印宽字节字符串
%u打印无符号整数
%x把整数以16进制的形式打印出来
%o把整数以8进制打印出来
%p打印指针
%f单精度浮点数
%Lf双精度浮点数
%g用于输出实数,根据数值大小,自动选取f格式或者e格式(输出时占宽度较小的一种,且不输出无意义的0)
%Z打印ANSI_STRING(用于驱动,不要求以0结尾,用字符串首地址给他一个指针,再确定一个长度,来规定字符串的有效数据,数据以ASCII编码类似于多字节字符串)
%wZ表示Unicode_STRING表示Unicode编码的字符串用于驱动 %n存储printf中前面的字符个数
%n就是一个非常严重的内存修改漏洞,可以修改内存,

printf没有做严格的校验(c++有做安全方面)

#include<stdio.h>
void MyPrint(char *buf)
{
    printf("%s",buf);//printf("%s\n",%s%d%x)
    printf(buf);//printf("%s%d%x\n")
}
int main()
{
    MyPrint("%s%d%x\n");
    int yes,no;
    printf("hellowordnsfsf%nffff%n",&yes,&no);
    printf("\n");
    if(1 == no)
    {
        printf("normal\n");
    }
    else if (16 == no)
    {
        printf("neicun change\n");//通过%n参数值被改变
    }
    printf("Yes-%d,No-%d\n",yes,no);
    return 0;
}

结果:

%s%d%x
Pg?4793760061e220
hellowordnsfsf
neicun change
Yes-0,No-16
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值