• va_start、vsprintf、va_end


    va_start,

      函数名称,读取可变参数的过程其实就是在堆栈中,使用指针,遍历堆栈段中的参数列表,从低地址到高地址一个一个地把参数内容读出来的过程。

    vsprintf

      vsprintf()中的 arg 参数位于数组中。数组的元素会被插入主字符串的百分比 (%) 符号处。该函数是逐步执行的。在第一个 % 符号中,插入 arg1,在第二个 % 符号处,插入 arg2,依此类推。

      函数名: vsprintf

      返回值: 正常情况下返回生成字串的长度(除去),错误情况返回负值
      用 法: int vsprintf(char *string, char *format, va_list param);
      // 将param 按格式format写入字符串string中
      注: 该函数会出现内存溢出情况,建议使用vsnprintf

    宏va_arg()、va_start()和va_end()一起使用,便可以完成向函数传入数目可变的变元操作。取可变数目变元的典型例子是函数printf()。类型va_list是在<stdarg.h>中定义的。

    上述的宏原型如下所示:
    type va_arg(va_list argptr, type);
    void va_end(va_list argptr);
    void va_start(va_list argptr, last_parm);
    它们都包含在头文件<stdarg.h>中。
     
    创建一个能获取可变数目变元的函数的通用过程:
      在函数定义中,可变参数表之前必须有一个或多个已知参数,其中最右者为last_parm。在调用va_start()时,last_parm名被用作第二个参数。
    任何可变长度的变元被访问之前,必须先用va_start()初始化变元指针argptr。初始化argptr后,经过对va_arg()的调用,以作为下一个参数类型的
    参数类型,返回参数。最后取完所有参数并从函数返回之前。必须调用va_end()。由此确保堆栈的正确恢复。
  • 相关阅读:
    1019.安全技能树
    1020.Burp Suite扩展之Java-Deserialization-Scanner
    1018.渗透利器
    1016.XXE漏洞攻防学习
    1017.前端黑在线工具
    1015.WebGoat SQL注入之 Order by注入解题思路
    1014.WebGoat SQL盲注 解题思路
    2019春节防坑指南之抢票陷阱(文末有彩蛋)
    【年度大戏】勒索”嘿客“无间道之战
    470余万条疑似12306用户数据遭贩卖 嫌疑人被刑拘
  • 原文地址:https://www.cnblogs.com/Colored-Mr/p/5148726.html
Copyright © 2020-2023  润新知