linux C++ 数字和字符的转换

1、数字===》string

USING_STD(string);
USING_STD(vector);
USING_STD(istringstream);
USING_STD(ostringstream);
USING_STD(ends);
USING_STD(setbase);
USING_STD(pair);
USING_STD(numeric_limits);

 

/**
 * 将指定数据转化为字符串
 * @param t 待转为字符串的数据
 * @return 字符串
 */
template<class T> string str(T t) {
    ostringstream os;
    os.precision(numeric_limits<T>::digits10);
    os << t;
    return os.str();
}

 

 

/**
 * 将数值转化为字符串
 * @param t 待转为字符串的数据
 * @param radix 数值进制
 * @return 字符串
 */
template<class T> string str(T t, int radix) {
    ostringstream os;
    os.precision(numeric_limits<T>::digits10);
    os << setbase(radix)<< t;
    return os.str();
}

 

 

2、string ===》 其他类型数字

 

 

/**
     * 将字符串转为 long,int,bool,short
     */
    template<class ValueType> static ValueType& fromString(const string& s,
            ValueType& value, int radix = 10) {
        istringstream is(s);
        is >> setbase(radix)>> value;
        if (is.fail()) {
            value = ValueType();
        }
        return value;
    }

 

 

 

 

3、to  double

 

returnstrtod(s.c_str(), 0);

 

 

4、to float

 

returnstatic_cast<float>(strtod(s.c_str(), 0));

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux C中将整数转换成二进制字符串是一项非常基本的操作。可以使用以下步骤来完成这个过程: 1. 定义一个字符数组来存储二进制字符串,数组长度要足够长以存储整数的所有二进制位。 2. 定义一个变量来存储整数。 3. 使用位运算符将整数的每个二进制位与1进行“与运算”,可以确定每个二进制位是否为1。将结果存储在字符数组的对应位置。 4. 将整数右移一位,并重复第3步。这个过程需要循环,直到整数为0。 5. 字符数组中存储的二进制字符串是从右到左存储的,需要将其反以获得正确的二进制字符串。 下面是一个简单的示例代码: ``` #include <stdio.h> #include <string.h> #define MAX_LEN 32 void intToBin(int num, char* binStr) { int i = 0; while(num > 0) { binStr[i++] = (num % 2 == 1) ? '1' : '0'; num >>= 1; } binStr[i] = '\0'; strrev(binStr); } int main() { int num = 10; char binStr[MAX_LEN]; intToBin(num, binStr); printf("%d in binary is %s\n", num, binStr); return 0; } ``` 在这个例子中,函数`intToBin`将`num`转换为二进制字符串,并将结果存储在`binStr`中。函数`strrev`用于反字符串。在`main`函数中,我们将整数10转换为二进制字符串并打印出来。输出结果为`10 in binary is 1010`。 在实际应用中,还需要进行一些特殊处理来处理整数为负数的情况以及处理二进制字符串的前导0。但是,以上的方法已经可以用来实现一个基本的整数二进制字符串的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值