首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

一个printf(结构体指针)引发的血案

不过大部分人都是使用 Windows 系统下的 VS 集成开发环境,或者 Linux 下的 gcc 命令行窗口来测试。...警告信息说:printf 语句需要 int 型数据,但是传递了一个 Student 结构体类型,我们先不用理会这个警告,因为我们就是想通过指针来访问这个地址里的数据。...s 与 指针变量 p 的值是否正确?...从现象上看,似乎是 printf 语句在执行过程中打印第一个数字之后,影响到了指针 p 的值,但是具体是怎么影响的说不清楚,而且它是系统里的库函数,肯定不能改变 p 的值。...这就说明 printf 语句在执行时没有改变指针变量的指向地址。 3.2 打印一个结构体变量 既然在字符串上测试没有问题,那么问题就出在结构体类型上了。

82620
您找到你想要的搜索结果了吗?
是的
没有找到

一个printf(结构体指针)引发的血案

不过大部分人都是使用 Windows 系统下的 VS 集成开发环境,或者 Linux 下的 gcc 命令行窗口来测试。...警告信息说:printf 语句需要 int 型数据,但是传递了一个 Student 结构体类型,我们先不用理会这个警告,因为我们就是想通过指针来访问这个地址里的数据。...s 与 指针变量 p 的值是否正确?...从现象上看,似乎是 printf 语句在执行过程中打印第一个数字之后,影响到了指针 p 的值,但是具体是怎么影响的说不清楚,而且它是系统里的库函数,肯定不能改变 p 的值。...这就说明 printf 语句在执行时没有改变指针变量的指向地址。 3.2 打印一个结构体变量 既然在字符串上测试没有问题,那么问题就出在结构体类型上了。

64920

再议printf函数

System.out.printf()是在JDK1.5版开始引入的方法,即在JDK1.5以后的版本才可以使用此函数,printf 方法有 printf(Stringformat, Object ......args) 和 printf(Locale l, String format, Object... args) 两种重载方式。...目前printf支持以下格式:           %c        单个字符           %d        十进制整数           %f        十进制浮点数           ...比如: main(){ inta = -1; printf("%d, %o",a,a); } 运行结果: -1, 177777 3.x格式:以无符号十六进制形式输出整数。...%s:例如:printf("%s","CHINA")输出"CHINA"字符串; 6.2.%ms:输出的字符串占m列,如字符串本身长度大于m,则突破m的限制,将字符串全部输出。

67440

Linux编程--指针的++操作

elf_phdr; phdr_start_addr < phdr_end_addr; phdr_start_addr++) { // 开始遍历程序头 // 在C中,数组指针的...typedef __u64 Elf64_Addr; typedef __u32 Elf32_Addr; 而elf_file->elf_phdr则是(Elf64_Phdr *),也就是指针类型,而对于指针来说...,+1或者-1都是对于整个结构体而言,所以对于指针的操作,每次加1或者-1都会偏移sizeof(struct)的大小。...,因为在运行的时候会有很多字节对齐的操作,如果没有指定类型的话,无法知道对应的结构体的大小,所以禁止(void *)指针的计算。...结论 对于地址的加减来说,可以正常按数加减,而且加减完后可以赋值给结构体指针。 而对于指针的加减来说,是对于指针对应的结构体大小而言的,每次加减都是计算的N个结构体大小的偏移。

81330

printf漏洞介绍

printf(format,) 1、概念 printf接受变长的参数,其中第一个参数为格式化字符串,后面的参数在实际运行时将与格式化字符串中特定的子字符串进行对应,将格式化字符串中的特定字串...2、漏洞成因 printf函数在执行时,首先进行格式化字符串的解析–从栈(或者寄存器)获取参数并与符号说明进行匹配,然后将匹配的结果输出到屏幕上,那么 ,如果格式化字符串中的符号声明与栈上参数不能正确匹配...而本书,printf也就是一个有力的攻击武器,我们可以通过控制字符串的值来实现更多的泄露或者完成个高级的利用。...3、实例代码 gcc编译之后用gdb打开 我们可以看到红框内edx是“My name is %s”,这个时候注意我们的代码,printf后面是没有跟参的,在本该压参的位置没有参数,导致了压入的是“...我们看到红框呢内,程序开始调用printf函数了,我们的格式是给了,但是var这个参数是什么我们没有给,所以他就会到esp,高4位的地方去取值 所以说这个是残缺的程序,那我们来帮助他完成。

9910

printf格式控制符

(1)输出格式控制综述:     printf的格式控制的完整格式:%  -  0  m.n  l或h     ①%:格式说明的起始符号,不可缺少。     ...有几中用法 %s:例如:printf("%s", "CHINA")输出"CHINA"字符串(不包括双引号)。...(3)三类特殊情况 ①如果想输出字符"%",则应该在“格式控制”字符串中用连续两个%表示,如: printf("%f%%", 1.0/3); 输出0.333333%。...对于双精度数,使用%lf格式符输出时,前16位是有效数字,小数6位. ②对于m.n的格式还可以用如下方法表示 char ch[20]; printf("%*....③输出格式 %n 可以将所输出字符串的长度值赋绐一个变量, 见下例: int slen; printf("hello world%n", &slen); 执行后变量slen被赋值为11。

1.6K20

Go 学习笔记:Println 与 Printf 的区别,以及 Printf 的详细用法「建议收藏」

Println :可以打印出字符串,和变量 Printf : 只可以打印出格式化的字符串,可以输出字符串类型的变量,不可以输出整形变量和整形 也就是说,当需要格式化输出信息时一般选择 Printf,...  //right fmt.Printf(a)  //error Printf 详细用法 Printf 在使用时需要给它指定一个格式化规则,即第一个参数,那么一共有多少种格式呢,用的时候需要怎么写呢?...fmt.Printf("%b\n", 14) //这个输出给定整数的对应字符。 fmt.Printf("%c\n", 33) //%x 提供十六进制编码。...fmt.Printf("%e\n", 123400000.0) fmt.Printf("%E\n", 123400000.0) //使用 %s 进行基本的字符串输出。...fmt.Printf("%x\n", "hex this") //要输出一个指针的值,使用 %p。

59130
领券