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