C++判断string是不是数字|C++获取数组长度
用了C++才发现难,啥都得找本质。
C++并没有把这些初级的方法封装起来,比如成一个数组类。
或者封装一个Int.TryParse ();可能有他的道理吧。
或者就是让你自己封装的。
#include <sstream>
using namespace std;
// 判断字符串是不是数字
bool isNum(string str)
{
stringstream sin(str);
double d;
char c;
if(!(sin >> d))
return false;
if (sin >> c)
return false;
return true;
}
// 得到数组长度
template <class T>
int getArrayLen(T &array)
{
return (sizeof(array) / sizeof(array[0]));
}
void main()
{
// 判断数字
string str = "123.456";
bool b = isNum(str);
str = "abc";
b = isNum(str);
b = isNum("123abc");
// 数组长度
string arrStr[] = {"abc","efg","hij"};
int n = getArrayLen(arrStr);
string arrStr2[10][5];
int i = getArrayLen(arrStr2); // 一维长度
int j = getArrayLen(arrStr2[0]);// 二维长度
}
参考:
C、C++中没有提供 直接获取数组长度的函数,对于存放字符串的字符数组提供了一个strlen函数获取长度,那么对于其他类型的数组如何获取他们的长度呢?其中一种方法是使 用sizeof(array) / sizeof(array[0]), 在C语言中习惯上在 使用时都把它定义成一个宏,
比如#define GET_ARRAY_LEN(array,len) {len = (sizeof(array) / sizeof(array[0]));} 。
而在C++中则可以使用模板 技术定义一个函数,比如:
template <class T>
int getArrayLen(T& array)
{
return (sizeof(array) / sizeof(array[0]));
}
这样对于不同类型的数 组都可以使用这个宏或者这个函数来获取数组的长度了。以下是两个Demo程序,一个C语言的,一个C++的:
P.S:若数组为存储 字符串的字符数组,则所求得的长度还需要减一,即对于宏定义: #define GET_ARRAY_LEN(array,len) {len = (sizeof(array) / sizeof(array[0]) - 1 );} ,对于函数定义:
template <class T>
int getArrayLen(T& array)
{
return (sizeof(array) / sizeof(array[0]) - 1);
}
原因为存储字符串的字 符数组末尾有一个'\0'字符,需要去掉它。
【C语言】
#include <stdio.h>
#include <stdlib.h>
#define GET_ARRAY_LEN(array,len){len = (sizeof(array) / sizeof(array[0]));}
//定义一个带参数的 宏,将数组长度存储在变量len中
int main()
{
char a[] = {'1','2','3','4'};
int len;
GET_ARRAY_LEN(a,len)
//调用预定义的宏,取得数组a的长度,并将其存储在变量len中
printf("%d\n",len);
system("pause");
return 0;
}
【C++】
#include <iostream>
using namespace std;
template <class T>
int getArrayLen(T& array)
{//使用模板定义一 个函数getArrayLen,该函数将返回数组array的长度
return (sizeof(array) / sizeof(array[0]));
}
int main()
{
char a[] = {'1','2','3'};
cout << getArrayLen(a) << endl;
return 0;
}
另: 在c++的函数里面,如果把一个数组作为参数传进去,那么这个数组就会退化为一个指针,因而就不知道这个数组的长度(这里的数组指的是静态的而不是new出来的).
我这个博客废弃不用了,今天想寻找外链的时候,突然想到这个博客权重很高。
有需要免费外链的,留言即可,我准备把这个博客变成免费的友情链接站点。