Explain how whitespace characters are handled in the string input operator and in the
getline
function.
The getline
function takes an input stream and a string.
This function reads the given stream up to and including
the first newline and stores what it read—not including
the newline—in its string argument.
After getline
sees a newline, even if it is the first character in the input,
it stops reading and returns.
If the first character in the input is a newline,
then the resulting string is the empty string.
getline
function whitespace handling,
do not ignore the beginning of the line blank characters read characters
until it encounters a line break,
read to termination and discard newline
(line breaks removed from the input stream
but is not stored in the string object).
What would happen if you define the loop control variable in the previous exercise as type char? Predict the results and then change your program to use a char to see if you were right.
No different.
auto& c : str
We use auto
to let the compiler determine the type of c
.
which in this case will be char&
.
What does the following program do? Is it valid? If not, why not?
string s;
cout << s[0] << endl;
Try to get the first element of the string
. It is invalid, cause this is undefined behavior.
Is the following range for legal? If so, what is the type of c?
const string s = "Keep out!";
for (auto &c : s){/*... */}
When you don't change c
's value, it's legal, else it's illegal.
For example:
cout << c; // legal.
c = 'X'; // illegal.
The type of c
is const char&
. read-only variable is not assignable.
Which, if any, of the following vector definitions are in error? For those that are legal, explain what the definition does. For those that are not legal, explain why they are illegal.
vector<vector<int>> ivec; // legal(c++11), vectors.
vector<string> svec = ivec; // illegal, different type.
vector<string> svec(10, "null"); // legal, vector have 10 strings: "null".
How many elements are there in each of the following vectors? What are the values of the elements?
vector<int> v1; // size:0, no values.
vector<int> v2(10); // size:10, value:0
vector<int> v3(10, 42); // size:10, value:42
vector<int> v4{10}; // size:1, value:10
vector<int> v5{10, 42}; // size:2, value:10, 42
vector<string> v6{10}; // size:10, value:""
vector<string> v7{10, "hi"}; // size:10, value:"hi"
In the binary search program on page 112, why did we write
mid=beg+(end-beg)/2;
instead ofmid=(beg+end) /2;
?
Because the iterator of vector don't define the +
operator between the two iterators.
beg + end
is illegal.
We can only use the subtraction between the two iterators.
Assuming txt_size is a function that takes no arguments and returns an int value, which of the following definitions are illegal? Explain why.
unsigned buf_size = 1024;
int ia[buf_size]; // illegal, The dimension value must be a constant expression.
int ia[4 * 7 - 14]; // legal
int ia[txt_size()]; // illegal, The dimension value must be a constant expression.
char st[11] = "fundamental"; // illegal, the string's size is 12.
What are the values in the following arrays?
string sa[10];
int ia[10];
int main() {
string sa2[10];
int ia2[10];
}
please see 2.2.1. Variable Definitions -> Default Initialization.
std::string
isn't a build-in type. The initializer will set it empty.
ia
and ia2
are build-type. But ia
isn't in the function body, so it
will be initialized to zero. ia2
is in the function body. so it's
value is undefined.
You can also use gdb to debug the value when the code is running.
List some of the drawbacks of using an array instead of a vector.
- can't add elements to an array.
- vector is better supported bt std.
Identify the indexing errors in the following code:
constexpr size_t array_size = 10;
int ia[array_size];
for (size_t ix = 1; ix <= array_size; ++ix)
ia[ix] = ix;
The size of ia is 10, so the index of value should less than 10. ix cannot equal the array_size.
What would happen if we did not initialize the scores array in the program on page 116?
If we did not initialize the scores array. the array is undefined. the value will be Unknown.
Given that p1 and p2 point to elements in the same array, what does the following code do? Are there values of p1 or p2 that make this code illegal?
p1 += p2 - p1;
p1 += p2 - p1;
same as p1 = p2;
. If p2 and p1 are legal, this code always legal.
What does the following program do?
const char ca[] = {'h', 'e', 'l', 'l', 'o'};
const char *cp = ca;
while (*cp) {
cout << *cp << endl;
++cp;
}
Print all the elements of the array.
WARNING!!!!
When we use a string, the compiler put it in the section .rodata
, the code uses C-style character string without adding a '\0' in the end of ca
.
So, when we code like this:
const char ca[] = {'h', 'e', 'l', 'l', 'o'};
const char s[] = "world";
const char *cp = ca;
while (*cp) {
cout << *cp;
++cp;
}
The code will print "helloworld" when you run it.
because the character list in the .rodata
like this:
h e l l o w o r l d \0
While(*cp)
judge weather *cp is 0 or not. when *cp is not 0, it will print the character until 0.
When you change the code like this:
const char ca[] = {'h', 'e', 'l', 'l', 'o', '\0'};
the character list in the .rodata
:
h e l l o \0 w o r l d \0
The program will run correctly. So when using C-style character string, be careful!!
see .rodata
, you can use this command:
hexdump -C a.out
In this section, we noted that it was not only illegal but meaningless to try to add two pointers. Why would adding two pointers be meaningless?
Because Subtracting two points gives a logically explainable result - the offset in memory between two points. Similarly, you can subtract or add an integral number to/from a pointer, which means "move the pointer up or down". Adding a pointer to a pointer is something which is hard to explain. The result is meaningless.
References: