字符串转换为正整数

这是一个STM32官方例程中的Str2Int()函数,能将带有k或M后缀的十进制字符串转换为整数。函数检查输入字符串是否以0x开头来判断是否为16进制,并处理k(*1024)和M(*1024*1024)的情况。

看了ST官方例程的一个 Str2Int() 函数,添加了几行中文注释。特色之处是将十进制可能带k、M的地方作了处理。

/**
  * @brief  Convert a string to an integer
  * @param  inputstr: The string to be converted
  * @param  intnum: The intger value
  * @retval 1: Correct
  *         0: Error
  */
uint32_t Str2Int(uint8_t *inputstr, int32_t *intnum)
{
  uint32_t i = 0, res = 0;
  uint32_t val = 0;

  if (inputstr[0] == '0' && (inputstr[1] == 'x' || inputstr[1] == 'X'))
  {    // 16进制的字符处理
    if (inputstr[2] == '\0')
    {    // 字符串="0x"或"0X",Error
      return 0;
    }
        // 16进制字符串最多有10个字符外加1个结束符
            // 假设:inputstr[] ="0x12345678"
                // 则 inputstr[0] = '0', inputstr[1] = 'x'
                // 则 inputstr[2] = '1', inputstr[3] = '2'
                // 则 inputstr[4] = '3', inputstr[5] = '4'
                // 则 inputstr[6] = '5', inputstr[7] = '6'
                // 则 inputstr[8] = '7', inputstr[9] = '8'
                // 则 inputstr[10] = '\0'
    for (i = 2; i < 11; i++)
    {
      if (inputstr[i] == '\0')
      {    // 字符串结尾(这里已经排除了"0x"、"0X"串的可能)
        *intnum = val;
        /* return 1; */
        res = 1;
        break;    // 退出for循环
      }
            // 未到字符串结尾
      if (ISVALIDHEX(inputstr[i]))
      {    // 是16进制字符
        val = (val << 4) + CONVERTHEX(inputstr[i]);
                // 假设:inputstr[] ="0x12345678"
                    // 当i=2时, val=0x00000001
                    // 当i=3时, val=0x00000012
                    // 当i=4时, val=0x00000123
                    // 当i=5时, val=0x00001234
                    // ...
                    // 当i=9时, val=0x12345678
      }
      else
      {    // 不是16进制字符
        /* return 0, Invalid input */
        res = 0;
        break;
      }
    }    // for循环 结束
    /* over 8 digit hex --invalid */
    if (i >= 11)
    {
      res = 0;
    }
  }    // 16进制的字符处理 结束
  else /* max 10-digit decimal input */
  {    // 10进制字符处理
    for (i = 0;i < 11;i++)
    {
      if (inputstr[i] == '\0')
      {    // 字符串结尾(空字符串做为数值0)
        *intnum = val;
        /* return 1 */
        res = 1;
        break;
      }
      else if ((inputstr[i] == 'k' || inputstr[i] == 'K') && (i > 0))
      {    // k, 表示前面的数值*1024
        val = val << 10;    // 左移10次, 等于乘以2的10次方
        *intnum = val;
        res = 1;
        break;
      }
      else if ((inputstr[i] == 'm' || inputstr[i] == 'M') && (i > 0))
      {    // M, 表示前面的数值*1024*1024
        val = val << 20;
        *intnum = val;
        res = 1;
        break;
      }
      else if (ISVALIDDEC(inputstr[i]))
      {
        val = val * 10 + CONVERTDEC(inputstr[i]);
      }
      else
      {
        /* return 0, Invalid input */
        res = 0;
        break;
      }
    }
    /* Over 10 digit decimal --invalid */
    if (i >= 11)
    {
      res = 0;
    }
  }

  return res;
}
 

### 判断字符串是否为正整数的 C++ 实现 在 C++ 中,可以通过遍历字符串中的字符来检查其是否全部由数字组成。以下是具体实现方式: #### 方法一:逐字符检查法 通过 `std::isdigit` 函数逐一验证字符串中的每个字符是否为数字。 ```cpp #include <iostream> #include <cctype> // isdigit() using namespace std; bool isPositiveInteger(const string& s) { if (s.empty()) return false; // 空字符串不是正整数 for(char c : s){ if (!isdigit(c)) return false; } return true; } int main(){ string input; cout << "请输入一个字符串:" << endl; cin >> input; if(isPositiveInteger(input)){ cout << "\"" << input << "\" 是正整数。" << endl; }else{ cout << "\"" << input << "\" 不是正整数。" << endl; } return 0; } ``` 此方法简单高效,适用于大多数情况[^1]。 --- #### 方法二:使用标准库函数 `std::stoi` 另一种方法是尝试将字符串转换为整数,并捕获可能发生的异常。如果成功,则说明该字符串是一个有效的正整数;否则则不是。 ```cpp #include <iostream> #include <string> using namespace std; bool isPositiveInteger(const string& s) { try { size_t pos; int value = stoi(s, &pos); if(pos != s.size() || value <= 0) return false; // 防止前导零或其他非法字符 return true; } catch (...) { return false; } } int main(){ string input; cout << "请输入一个字符串:" << endl; cin >> input; if(isPositiveInteger(input)){ cout << "\"" << input << "\" 是正整数。" << endl; }else{ cout << "\"" << input << "\" 不是正整数。" << endl; } return 0; } ``` 这种方法依赖于标准库的功能,能够处理一些边界条件,例如带有前导零的情况。 --- ### 总结 上述两种方法都可以有效判断给定字符串是否为正整数。第一种方法更直观且易于理解,而第二种方法则更加健壮,因为它能自动检测某些特殊情形下的错误输入。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值