1.在函数参数的声明中, 数组名被编译器当做指向数组第一个元素的指针, 因此不能够通过在函数中使用sizeof(array_name) / sizeof(type)求数组的大小, 而是应该通过参数将数组的大小传递给调用函数.
2.当字符串常量出现在表达式中时, 它的值是指针常量。编译器把该字符串的一份拷贝存储在内存中的某个位置, 并存储一个指向第一个字符的指针, 我们可以对字符串常量进行下标引用, 间接访问以及指针运算。
如:
#include <iostream>
using namespace std;
int main(int argc, char *argv[])
{
freopen("output.txt", "wt", stdout);
cout << "xyz" + 1 << endl;
cout << *"xyz" << endl;
cout << "xyz"[1] << endl;
return EXIT_SUCCESS;
}
输出:
yz
x
y
3.int maxtrix[10][10], 则maxtrix + 1指向了矩阵第二行的元素…
4.int array[10], 则array是指向数组中第一个元素的指针, 而&array是指向整个数组的指针…
5.strlen(), sizeof()的返回值均是size_t类型, 这个类型在头文件stddef.h中定义, 是一个无符号的整形类型, 所以诸如一下的判断都是无意义的:
假设char *str1 = “sssss”, *str2 = “sss”;
If(strlen(str2) – strlen(str1) >= 0)
……
If(strlen(str1) – 10000 >= 0)
……
If(sizeof(str1) – 10000 >= 0)
……
这些if判断都是恒成立的, 因为无符号整数都是>=0的, 如果想消除这个问题, 可以进行强制类型转换, 如if((int)strlen(str1) – 18 >= 0)…..
或是int a = strlen(str1); if(a – 18 >= 0)….
6.char a[] = “12345”, 那么strlen(a) = 5, sizeof(a) = 6(包含最后的’/0’)
7.NULL和NUL的区别:
NULL是在<stddef.h>中专门为空指针定义的一个宏, NUL是ASCII字符集中第一个字符的名称, 它对应一个0值, NULL可以被定义为(void*)0, 而NUL可以被定义为’/0’, 所以通常, NULL定义为指针类型, 而NUL定义为字符类型.