我们知道在c语言中char 类型实际上整数类型,大小是1个字节(8bit,-128~127)。
我们在计算机系统上看到的所有字符都在字符集(像UTF-8,GBK等)中被编码(即用特定的数字来表示),而这些字符集一般都兼容ASCII,即0 ~ 127对应的字符和ASCII中编码是一样的。
1.零值的含义
零值 | 含义 | 说明 |
---|---|---|
0 | 整型 | 存储的时候是按照四个字节的整数0来存储的 |
‘0’ | 字符型(ASCII值为48) | 存储的时候是按照一个字节的整数48来存储的 |
‘\0’ | 转义字符型(ASCII值为0) | 非可打印字符,用于标识字符串结束标记。 存储的时候是按照一个字节的整数0来存储的 |
“0” | 字符串(字符数组) | 由’0’和 '\0’两个字符组成 |
在c中:NULL | 1. #define NULL (void*)0 没有指向任何地方的地址 0x00000000 2.整数0 | int* p = 0; int* p= (void *)0; int* p = NULL; int m = NULL; |
在c++中 :NULL | #define NULL 0 | int* p = 0; //合法 int* p = (void* )0; //不合法 因为不能隐式转换void*为另一种指针类型 |
nullptr | 关键字nullptr代表一个空指针(c++11) | 专用于指针初始化,和整数0,NULL区别开 不能将 nullptr 赋值给整型 |
2.表达式中的零值
在c/c++中,布尔类型也属于整型,因为用整数1表示true,整数0表示false,且所有的非零值都视为真。
因为字符’\0’和整数0在存储时都表示0,NULL在c/c++中都被宏定义为0,所以他们都能表示逻辑false,这样在逻辑判断时很有用。
例1:
在c语言实现去除字符串中空格中while循环的判断条件
#include<stdio.h>
#include<stdlib.h>
void CutSpace3(char* StrRes)
{
int i = 0;
char* ptr = StrRes;
//while(*ptr != 0)
//while(*ptr != NULL)
//while(*ptr != '\0')
while(*ptr)
{
if(*ptr != ' ')
StrRes[i++] = *ptr;//StrRes[i] 等价于 *(StrRes + i)
ptr++;
}
StrRes[i] = '\0';
return;
}
int main() {
char StrRes[] = " hello moto! " ;
CutSpace3(StrRes);
printf("%s\n", StrRes);
return 0;
}
例2:表达式做逻辑判断
int ret = 0;
int copy(char* from,char* to){
if(from == NULL||to == NULL)
{
ret= -1;
return ret;
}
/*写法1
while(*from != '\0')
{
*to++ = *from;
}
*to = '\0';
写法2
while((*to++ = *from++) != '\0');
*/
/*写法3
*to++ = *from++ 表达式的值是都是左值,*from将'\0'赋值给*to后
才会判断*to是否为0,所以不用写*to = '\0';*/
while(*to++ = *from++);
return ret;
}
int main(){
char* StrTmp = " hello motto! "
char Arry[64] = {};
if(copy(StrTmp,Arry))
[
printf(The function of copy is error.Check it.)
return ret;
]
printf("%s \n",Arry);
return ret;
}
参考文章:
c语言中的各种“零”
C风格字符串结束符用作逻辑判断
c语言中的0、’0’、’\0’、”0”及NULL
nullptr详解