探讨数组与字符串输入的问题(C++版)

对于字符串问题,原来理解的不够深刻,现在讨论一些关于字符串输入的问题

1.strlen() 返回的是数组中的字符串的长度,而不是数组本身的长度。
   2.strlen()只计算可见的字符,而不把空字符计算在内。

那么更有意思的在后面:

char name[16] = "abcdefg";
//输出结果是多少?
cout << name << endl;
name[3] = '\0';
//输出结果又是多少?
cout << name << endl;

大家猜猜 ?

# include <iostream>
# include <cstring>
# define SIZE 15
using namespace std;
int main(void)
{
  char name_cin[SIZE];
  char name[SIZE] = "C++owboy"; //initialized array
  cout << "Hello I'm " << name;
  cout << "! What is your name ? ";
  cin >> name_cin;
  cout << "Well " << name_cin << ", your name has ";
  cout << strlen(name_cin) << " letters and is stored " << endl;
  cout << "in an array of " << sizeof(name_cin) << "bytes." << endl;
  cout << "your initial is " << name_cin[0] << "." << endl;
  name[3] = '\0';
  cout << "Here are the first 3 characters of my name : ";
  cout << name << endl;
  return 0;
}

大家猜猜结果呢?

name字符串被截断了...

释义: 
   数组可以用索引来访问数组的各个字符,例如name[0]找到数组的第一个字符,name[3] = '\0';  设置为空字符,使得这个字符串在第三个字符后面即结束,即使数组中还有其他字符。

不过cin有个缺陷,就是以空白符为结束标志,如果遇到空格和回车就把这个字符串输入完了,这样就需要用能输入一行字符串的方法来解决,但是先看看这个问题:

# include <iostream>
using namespace std;
int main(void)
{
 const int ArSize = 20;
 char name[ArSize];
 char dessert[ArSize];
 cout << "Enter your name : " << endl;
 cin >> name; //输入名字
 cout << "Enter your favorite dessert: " << endl;
 cin >> dessert; //输入甜点的名字
 cout << "I have some delicious " << dessert;
 cout << " for you, " << name << "." << endl;
 return 0;
}

释义:

cin使用空白(空格、制表符、换行符)来定字符串的边界,cin在获取字符数组输入时只读取第一个单词,读取单词后,cin将该字符串放到数组中,并自动在结尾添加空字符'\0'
cin把Meng作为第一个字符串,并放到数组中,把Liang放到输入队列中第二次输入时,发现输入队列Liang,因为cin读取Liang,并将它放到dessert数组中

这时如果能输入一行数据,这个问题不就解决了吗?
getline()、get()可以实现...

 # include <iostream>
using namespace std;
int main(void)
{
  const int ArSize = 20;
  char name[ArSize];
  char dessert[ArSize];
  cout << "Enter you name : " << endl;
  cin.getline(name,ArSize);
  cout << "Enter you favorite dessert : " << endl;
  cin.getline(dessert,ArSize);
  cout << "I have some delicious " << dessert;
  cout << " for you," << name << endl;
  return 0;
}

释义:

cin是将一个单词作为输入,而有些时候我们需要将一行作为输入,如 I love C++
   iostream中类提供了一些面向行的类成员函数,如getline()和get(),这两个都是读取一行的输入,直到换行符结束,区别是getline()将丢弃换行符
   get()将换行符保留在输入序列中
   面向行的输入:getline(char* cha,int num)
   getline()读取整行,通过换行符来确定结尾,调用可以使用 cin.getline(char* cha,int num),成员函数的方式使用,第一个参数是用来存储输入行的数组的名称,第二个参数是要读取的字符数,如果这个字符数的参数为30,则最多读入29个字符,余下的用于存储自动在结尾处添加的空字符。
   get()存储字符串的时候,用空字符结尾。

如果遇到这种情况咋办?

# include <iostream>
using namespace std;
int main(void)
{
 cout << "What year was your house built? " << endl;
 int year;
 cin >> year;
 //char ch;
 //cin.get(ch); 接收换行符 (cin >> year).get();
 cout << "What is its street address ? " << endl;
 char address[80];
 cin.getline(address, 80);
 cout << "Year built : " << year << endl;
 cout << "Address : " << address << endl;
 cout << "Done ! " << endl;
 return 0;
}

地址还没有输入,就结束了...
去掉上面的注意,加一个字符,接收换行符就可以了...
注:C++程序常使用指针而不是数组来处理字符串

以上就是本文的全部内容,希望对大家的学习有所帮助。

(0)

相关推荐

  • C++指针数组、数组指针、数组名及二维数组技巧汇总

    本文较为详细的分析了关于理解C++指针数组,数组指针,数组名,二维数组的一些技巧.是比较重要的概念,相信对于大家的C++程序设计有一定的帮助作用. 一.关于数组名 假设有数组: int a[3] = {1, 2, 3} 1.数组名代表数组第一个元素的地址,注意,不是数组地址(虽然值相等),是数组第一个元素地址,a 等同于 &a[0]; a+1是第二个元素的地址.比第一个元素地址a(或者&a[0])超出了一个整型指针的大小,在这里是4个字节(byte) cout << a <

  • 详解C++中的一维数组和二维数组

    C++一维数组 定义一维数组 定义一维数组的一般格式为:     类型标识符  数组名[常量表达式]; 例如: int a[10]; 它表示数组名为a,此数组为整型,有10个元素. 关于一维数组的几点说明: 1) 数组名定名规则和变量名相同,遵循标识符定名规则. 2) 用方括号括起来的常量表达式表示下标值,如下面的写法是合法的: int a[10]; int a[2*5]; int a[n*2]; //假设前面已定义了n为常变量 3) 常量表达式的值表示元素的个数,即数组长度.例如,在"int

  • C++中关于[]静态数组和new分配的动态数组的区别分析

    本文以实例分析了C++语言中关于[]静态数组和new分配的动态数组的区别,可以帮助大家加深对C++语言数组的理解.具体区别如下: 一.对静态数组名进行sizeof运算时,结果是整个数组占用空间的大小: 因此可以用sizeof(数组名)/sizeof(*数组名)来获取数组的长度. int a[5]; 则sizeof(a)=20,sizeof(*a)=4.因为整个数组共占20字节,首个元素(int型)占4字节. int *a=new int[4];则sizeof(a)=sizeof(*a)=4,因为

  • C++二分法在数组中查找关键字的方法

    本文实例讲述了C++二分法在数组中查找关键字的方法.分享给大家供大家参考.具体如下: /* 此程序演示了二分法查找算法(针对按从小到大排列的数组)的实现. */ #include <iostream> using namespace std; /* 功能: 实现数组的二分法查找(只算法只适合按从小到大排列的数组) 返回值:关键字在数组中的下标, 返回-1表示未找到 a[]: 要搜索的数组 len: 数组元素个数 key: 要查找的关键字 */ int binSearch(int a[], in

  • C++语言实现线性表之数组实例

    本文实例讲述了C++语言实现线性表之数组.分享给大家供大家参考.具体分析如下: 感觉用C++中的构造函数.析构函数等类的特点来描述一些数据结构更加易读,更加合理,便捷.但有一个问题,编译器不支持模板的分离编译,很不舒服 #include <iostream> using namespace std; template<class T> class CArray { public: CArray(const int &iMax); CArray(); ~CArray(); v

  • 详解C++中的指针、数组指针与函数指针

    C++中一个重要的特性就是指针,指针不仅具有获得地址的能力,还具有操作地址的能力.指针可以用于数组.或作为函数的参数,用来访问内存和对内存的操作,指针的使用使得C++很高效,但是指针也非常危险,使用不当会带来比较严重的问题. 1.指针 程序中所有的变量和常量都存在一个内存地址中,当然,函数也有对应的内存地址,内存地址的不同会导致程序执行时有所不同. 指针就是用来控制和存储内存地址的变量,它指向单个对象的地址,除了void之外,指针的数据类型与所指向地址的变量数据类型保持一致. 2.如何定义指针.

  • C++通过自定义函数找出一个整数数组中第二大数的方法

    本文实例讲述了C++通过自定义函数找出一个整数数组中第二大数的方法.分享给大家供大家参考.具体实现方法如下: const int MINNUMBER = -32767 ; //2字节的Int 0x8000-1, //4字节的Int 0x80000000-1 -2147483647 int find_sec_max( int data[] , int count) { int maxnumber = data[0] ; int sec_max = MINNUMBER ; for ( int i =

  • Lua教程(五):C/C++操作Lua数组和字符串示例

    本文将介绍如何在C/C++里面操作Lua的数组和字符串类型,同时还会介绍如何在C/C++函数里面存储Lua状态(registry和upvalue),而registry在使用C/C++自定义类型时非常有用,可以方便地为userdata指定metatable. C/C++操作Lua数组 Lua数组Overview 在Lua里面,数组只不过是key为整数的table而已.比如一个table为array = {12,"Hello", "World"},它是一个数组,可以用下

  • 详解C++编程中数组的基本用法

    可以使用数组下标操作符 ([ ]) 访问数组的各个元素. 如果在无下标表达式中使用一维数组,组名计算为指向该数组中的第一个元素的指针. // using_arrays.cpp int main() { char chArray[10]; char *pch = chArray; // Evaluates to a pointer to the first element. char ch = chArray[0]; // Evaluates to the value of the first e

  • 详解C++中的对象指针与对象数组

    C++对象指针 指向对象的指针 在建立对象时,编译系统会为每一个对象分配一定的存储空间,以存放其成员.对象空间的起始地址就是对象的指针.可以定义一个指针变量,用来存放对象的指针. 如果有一个类: class Time { public : int hour; int minute; int sec; void get_time( ); }; void Time::get_time( ) { cout<<hour<<":"<<minute<<

  • 详解C++编程中用数组名作函数参数的方法

    C++数组的概念 概括地说:数组是有序数据的集合.要寻找一个数组中的某一个元素必须给出两个要素,即数组名和下标.数组名和下标惟一地标识一个数组中的一个元素. 数组是有类型属性的.同一数组中的每一个元素都必须属于同一数据类型.一个数组在内存中占一片连续的存储单元.如果有一个整型数组a,假设数组的起始地址为2000,则该数组在内存中的存储情况如图所示. 引入数组就不需要在程序中定义大量的变量,大大减少程序中变量的数量,使程序精炼,而且数组含义清楚,使用方便,明确地反映了数据间的联系.许多好的算法都与

随机推荐