ASCII:编码一个字节
UNICODE:两个或四个字节 utf-8(一个字节 变长度的 可以为1 2 4个字节 可以减少传输量,多用于web 网络) utf-16(一个字符占两个字节 Windows驱动内核的编码规则) utf-32(linux、苹果平台 一个字符占四个字节)
多字节字符串(multibyte) 例: “hello!中国”
单字节字符定义:char c //有符号或者无符号由编译器决定 vc中有符号
宽字节字符定义:wchar_t wc
’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++有做安全方面)
#includevoid MyPrint(char *buf) { printf("%s",buf);//printf("%sn",%s%d%x) printf(buf);//printf("%s%d%xn") } int main() { MyPrint("%s%d%xn"); int yes,no; printf("hellowordnsfsf%nffff%n",&yes,&no); printf("n"); if(1 == no) { printf("normaln"); } else if (16 == no) { printf("neicun changen");//通过%n参数值被改变 } printf("Yes-%d,No-%dn",yes,no); return 0; }
结果:
%s%d%x Pg?4793760061e220 hellowordnsfsf neicun change Yes-0,No-16



