vsprintf缓冲区溢出问题

2023-10-10 08:08

本文主要是介绍vsprintf缓冲区溢出问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目标:为string对象提供一个printf形式的格式化函数
方法:vsprintf先输出到一个char[],再拷贝到string变量中
问题:vsprintf输出的char[]缓冲区该开多大?
开小了可能不够,开大了浪费空间,多大是够大?
有没有函数能预先计算出目标串的长度?
有没有其他思路解决这个问题?

char fmt_buf[4096];
int stringprintf( string& str, char* fmt, ... )
{
va_list args;
va_start(args, fmt);
if ( vsnprintf ( fmt_buf, sizeof(fmt_buf)-1, fmt, args ) < 0 ) return -1;
str = fmt_buf;
va_end(args);
return ( str.size() );
}


想到个复杂的办法

虽然不能预先知道多大,但缓冲区不够大时是可以发现的,发现不够大时malloc扩大一倍缓冲区,一直到够大为止

len=1024;     //初始缓冲区1024
buf=malloc(len);
while ( vnsprintf(buf,...) == -1 && len <1M ) {   // 缓冲区不够大
  len *= 2;    // 缓冲区扩大一倍
  buf=realloc(len);
}

好象有点疯狂


代码说话,这是从我工程里摘取的:
C/C++ code ?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
shared_ptr<string> format( const  char * fmt, ...)
{
     va_list  ap;
     va_start (ap, fmt);
     vector< char > buf(1024);
     int  ret;
     while  ((ret = vsnprintf_s(&buf[0], buf.size(), buf.size(), fmt, ap)) == -1)
     {
         buf.resize(buf.size() * 2);
     }
     va_end (ap);
     // 结尾不是NULL,则截断
     if  (ret ==  static_cast < int >(buf.size()))
     {
         buf[buf.size() - 1] =  '\0' ;
     }
     return  shared_ptr<string>( new  string(&buf[0]));
}
对我有用[0]  丢个板砖[0]  引用 |  举报 |  管理 |  TOP
C/C++ code ?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
int  stringprintf( string& str, int  num, int  max, char * fmt, ... ) ;
int  main( int  argc, char  *argv[]) 
{
  int  n;
  string str;
  n=stringprintf(str,2,20, "%d %s" , 123,  "abcde" );
  cout<<str<<endl;
  return  0;
}
int  stringprintf( string& str, int  num, int  max, char * fmt, ... ) 
     va_list  args; 
     va_start (args, fmt); 
     char  *fmt_buf= new  char [num*max];
     if  ( _vsnprintf ( fmt_buf, num*50, fmt, args ) < 0 )  return  -1; 
     str = fmt_buf; 
     delete  []fmt_buf;
     va_end (args); 
     return  ( str.size() ); 


只能这样了。
对我有用[0]  丢个板砖[0]  引用 |  举报 |  管理 |  TOP
13楼的老兄:还真有人这么干啊,看来不是我一个人在钻牛角尖
声明一下,我12楼的内容不是抄你的哦,纯属巧合,看看发表时间和楼层号就知道,呵呵

这篇关于vsprintf缓冲区溢出问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/179154

相关文章

如何解决idea的Module:‘:app‘platform‘android-32‘not found.问题

《如何解决idea的Module:‘:app‘platform‘android-32‘notfound.问题》:本文主要介绍如何解决idea的Module:‘:app‘platform‘andr... 目录idea的Module:‘:app‘pwww.chinasem.cnlatform‘android-32

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

Pyserial设置缓冲区大小失败的问题解决

《Pyserial设置缓冲区大小失败的问题解决》本文主要介绍了Pyserial设置缓冲区大小失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录问题描述原因分析解决方案问题描述使用set_buffer_size()设置缓冲区大小后,buf

resultMap如何处理复杂映射问题

《resultMap如何处理复杂映射问题》:本文主要介绍resultMap如何处理复杂映射问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录resultMap复杂映射问题Ⅰ 多对一查询:学生——老师Ⅱ 一对多查询:老师——学生总结resultMap复杂映射问题

java实现延迟/超时/定时问题

《java实现延迟/超时/定时问题》:本文主要介绍java实现延迟/超时/定时问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java实现延迟/超时/定时java 每间隔5秒执行一次,一共执行5次然后结束scheduleAtFixedRate 和 schedu

如何解决mmcv无法安装或安装之后报错问题

《如何解决mmcv无法安装或安装之后报错问题》:本文主要介绍如何解决mmcv无法安装或安装之后报错问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mmcv无法安装或安装之后报错问题1.当我们运行YOwww.chinasem.cnLO时遇到2.找到下图所示这里3.

浅谈配置MMCV环境,解决报错,版本不匹配问题

《浅谈配置MMCV环境,解决报错,版本不匹配问题》:本文主要介绍浅谈配置MMCV环境,解决报错,版本不匹配问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录配置MMCV环境,解决报错,版本不匹配错误示例正确示例总结配置MMCV环境,解决报错,版本不匹配在col

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo