zoukankan      html  css  js  c++  java
  • 字符串与数字之间的转换

    转载:

    1、字符串数字之间的转换

    (1)string --> char *
       string str("OK");
       char * p = str.c_str();

    (2)char * -->string
       char *p = "OK";
       string str(p);

    (3)char * -->CString 
       char *p ="OK";
       CString m_Str(p);
       //或者
       CString m_Str;
       m_Str.Format("%s",p);

    (4)CString --> char *
       CString str("OK");
       char * p = str.GetBuffer(0);
       ...
       str.ReleaseBuffer();

    (5)string --> CString  
       CString.Format("%s", string.c_str());  

    (6)CString --> string
       string s(CString.GetBuffer(0));  
       GetBuffer()后一定要ReleaseBuffer(),否则就没有释放缓冲区所占的空间,CString对象不能动态增长了。

    (7)double/float->CString
       double data;
       CString.Format("%.2f",data); //保留2位小数

    (8)CString->double
       CString s="123.12";
       double   d=atof(s);   
     
    (9)string->double
      double d=atof(s.c_str());

    2、数字转字符串:使用sprintf()函数

    char str[10];
    int a=1234321;
    sprintf(str,"%d",a);
    --------------------
    char str[10];
    double a=123.321;
    sprintf(str,"%.3lf",a);
    --------------------
    char str[10];
    int a=175;
    sprintf(str,"%x",a);//10进制转换成16进制,如果输出大写的字母是sprintf(str,"%X",a)
    --------------------
    char *itoa(int value, char* string, int radix); 
    同样也可以将数字转字符串,不过itoa()这个函数是平台相关的(不是标准里的),故在这里不推荐使用这个函数。

    3、字符串转数字:使用sscanf()函数

    char str[]="1234321";
    int a;
    sscanf(str,"%d",&a);
    .............
    char str[]="123.321";
    double a;
    sscanf(str,"%lf",&a);
    .............
    char str[]="AF";
    int a;
    sscanf(str,"%x",&a); //16进制转换成10进制

    另外也可以使用atoi(),atol(),atof().

    4、使用stringstream类

    用ostringstream对象写一个字符串,类似于sprintf() 
      ostringstream s1;
      int i = 22;
      s1 << "Hello " << i << endl;
      string s2 = s1.str();
      cout << s2;

    用istringstream对象读一个字符串,类似于sscanf() 
      istringstream stream1;
      string string1 = "25";
      stream1.str(string1);
      int i;
      stream1 >> i;
      cout << i << endl;  // displays 25

     
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
  • 相关阅读:
    Luogu-P2295 MICE
    Luogu-P2627 修剪草坪
    Loj-10176-最大连续和
    Luogu-P1886 滑动窗口
    Luogu-P3807 【模板】卢卡斯定理
    Luogu-P1879 [USACO06NOV]玉米田Corn Fields
    Luogu-P1896 [SCOI2005]互不侵犯
    Loj-SGU 223-国王
    Luogu-P2657 [SCOI2009]windy数
    素数
  • 原文地址:https://www.cnblogs.com/lyf-sunicey/p/8489899.html
Copyright © 2011-2022 走看看