C語言中0、‘\0‘、‘0‘、NULL以及類型轉(zhuǎn)化
0 ‘\0' ‘0' NULL
0 '\0' NULL都是三種0值,它們在數(shù)字上是完全一樣的,而且在內(nèi)存中存的都是二進制0。

所以,它們的值是一樣的,只不過表現(xiàn)的形式不一樣,也就是它們的類型是不同的:
0在整形中表示數(shù)字0,在字符中'0'表示一個字符它的ASCII碼值為48,
'\0'是一個字符,表示字符串結(jié)束,在ASCII中的值為0
NULL 即空指針,它表示一個指針指向地址為0的空間,可以看到這里的0被強制轉(zhuǎn)化為void*指針,這也就意味著而NULL可以賦值給任何類型的指針:

對于不同的類型,如果使用運算符(比如±=等運算符)運算的話,會進行隱式類型轉(zhuǎn)化,對于一些類型檢查嚴格的編譯器可能會報錯:
#include<stdio.h>
int main()
{
int a = '\0';//將'\0'的ASCII碼值賦值給a
char b = 0;//將0的二進制賦值給b
int c = '0';//將字符'0'的ASCII碼值賦值給c
int d = a + b + c;//在相加時,由于b是char型,所以會整形提升為int型
printf("%d\n", d);//以%d形式打印d內(nèi)存空間的內(nèi)容
printf("%c\n", '0');//打印字符'0'
printf("%d\n", '0');//打印字符'0'的ASCII碼值
printf("%c\n", 0); //空(即NULL)
printf("%d\n", 0);//數(shù)字0
printf("%c\n", 0 + '\0');//空(NULL) '\0'先轉(zhuǎn)換成int,然后ASCII編碼相加為0,
//%c輸出,轉(zhuǎn)換成char,所以輸出NULL
printf("%d\n", 0 + '\0');//先轉(zhuǎn)換成int,然后ASCII編碼相加為0,%d輸出,不用轉(zhuǎn)換,輸出數(shù)字0
printf("%c\n", 0 + '0');//'0'先轉(zhuǎn)換成int,然后ASCII編碼相加為0,
//%c輸出,ASCII轉(zhuǎn)換成char,所以輸出字符'0'
printf("%d\n", 0 + '0');//輸出字符'0'的ASCII碼值
}

真實的類型轉(zhuǎn)化和不改變內(nèi)存的類型轉(zhuǎn)化
真實的類型轉(zhuǎn)化:改變內(nèi)存中的數(shù)據(jù)
不改變內(nèi)存的類型轉(zhuǎn)化:不改變內(nèi)存中的數(shù)據(jù),只改變對應(yīng)的類型
舉個例子:比如把字符串"12345"轉(zhuǎn)化成整形數(shù)字12345,它們的內(nèi)存大小和內(nèi)容都發(fā)生了改變,字符串"12345"的內(nèi)存大小為6字節(jié),每個字節(jié)存儲的是單個字符的ASCII碼值,而整形數(shù)字12345則為4字節(jié),內(nèi)存中存儲的是數(shù)字12345的二進制補碼。
如果要實現(xiàn)這種轉(zhuǎn)化,則要使用對于的函數(shù),在這里可以自己實現(xiàn)一個:
#include<stdio.h>
int my_atoi(char* str)
{
int i = 0;
int flag = 1;//默認字符串為正
int value = 0;
if ('-' == str[0])
{
flag = -1;//字符串第一個字符為‘-',則將flag置為-1
i++;
}
else if ('+' == str[0])//字符串第一個字符為'+',則不改變flag
{
i++;
}
else//字符串不加符號,默認為正
{
;
}
while (str[i] >= '0' && str[i] <= '9')
{
value = value * 10 + str[i] - '0';
i++;
}
return flag * value;
}
int main(void)
{
char str1[] = "+12345";
char str2[] = "-12345";
char str3[] = "12345";
int a = my_atoi(str1);
int b = my_atoi(str2);
int c = my_atoi(str3);
printf("%d\n", a);
printf("%d\n", b);
printf("%d\n", c);
return 0;
}

而對于不改變內(nèi)存的類型轉(zhuǎn)化,則不會改變其內(nèi)存空間中存儲的值,只是改變數(shù)據(jù)類型:

對于C語言強制類型轉(zhuǎn)換時,會有兩種方式:
- 保持內(nèi)存中的內(nèi)容不變,僅修改對這段內(nèi)存的解釋方式, 如int和char的互轉(zhuǎn)
- 保持值不變(近似),但修改內(nèi)存中的內(nèi)容,如int和double的互轉(zhuǎn)
附:c語言中不同數(shù)據(jù)類型之間的相互轉(zhuǎn)化
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <iostream>
void split(char* str, double* position)
{
char* words[3];
char* temp;
temp = strtok(str, " ");
int i = 0;
while(temp!=NULL)
{
words[i] = temp;
temp = strtok(NULL, " ");
position[i] = atof(words[i]);
i++;
}
}
int main()
{
char lineBuf[] = "11.12 11.13 11.14";
std::cout << "1" << std::endl;
double position[3];
split(lineBuf, position);
std::cout << "1" << std::endl;
for(int i=0; i<3; i++)
{
// std::cout << words[i] << std::endl;
// position[i] = atof(words[i]);
std::cout << position[i] << std::endl;
}
return 0;
}
總結(jié)
到此這篇關(guān)于C語言中0、‘\0‘、‘0‘、NULL以及類型轉(zhuǎn)化的文章就介紹到這了,更多相關(guān)C語言0、\0、0、NULL及類型轉(zhuǎn)化內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++ LeetCode1780判斷數(shù)字是否可以表示成三的冪的和
這篇文章主要為大家介紹了C++ LeetCode1780判斷數(shù)字是否可以表示成三的冪的和題解示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-12-12

