- 1.c语言的字符串是以0结尾的字符串
- 2. C语言中没有字符串类型,字符串通过字符数组进行mon
- 3 . 字符串的分配:堆区、者栈区或全局区
int main()
{
//指定字符数组的长度---以0结尾的字符串
char buf1[64] = { 'a','b','c','d' };//4-63自动填充0
//char buf2[2] = { 'a','b','c' };//报错
//不指定字符数组的长度---字符数组(c编译器自动求出数组的长度)
char buf3[] = { '1','2','3','4','5' };
//用字符串初始化字符数
char buf4[] = "abcd";//编译器自动在末尾加''
printf("sizeof(buf4)=%d\n", sizeof(buf4));//buf4作为字符数组 大小为5字节;sizeof()求内存块的大小
printf("strlen(buf4)=%d\n", strlen(buf4));//buf4作为字符串 大小为4个字节
//指针 *** 作数组
char buf5[64] = { 'a','b','c','d' };
char* p = buf5;
printf("buf5=%s\n", p);
int i;
for (i = 0; i < 5; i++)
{
printf("%c ", *(p++));//*(p++)也可以写为:*(p+i)、*(buf5+i)不能写为*(buf5++):因为
//buf5是常量指针,指向不能被修改
return 0;
}
注:buf5 为常量指针的原因
数组开辟在栈区,当函数运行完毕时,需要释放栈区的内存若更改了buf5的指向,会导致编译器在释放内存是找不到数组的首地址。
2.数组的[]的本质和*的关系 2.1 :[]==>*的推到过程: buf5[i] = buf[0+i] = *(buf+i) 3.一级指针的内存模型
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)