- 相關(guān)推薦
c語(yǔ)言中單引號(hào)和雙引號(hào)的區(qū)別
單引號(hào)和雙引號(hào)都可以作為字符串的開(kāi)始符和關(guān)閉符,并且只能同一種單或者雙引號(hào)來(lái)定義開(kāi)始和結(jié)束。以下是小編分享給大家的c語(yǔ)言中單引號(hào)和雙引號(hào)的區(qū)別,歡迎閱讀!
問(wèn)題:
從c++文件中將std:string轉(zhuǎn)換為char*后,返回包含IP地址的char*,需要將該字符串char*中的IP地址提取出來(lái);
解決辦法:
1. 解決思路:
IP地址最長(zhǎng)為12字符+3句點(diǎn)=15字符,一般性表示為192.168.111.111;
可以從第一個(gè)字符開(kāi)始解析,當(dāng)不是'.'時(shí),將所有字符保存下來(lái),然后把所有保存下來(lái)的字符轉(zhuǎn)換為16進(jìn)制就可以了;
2. 程序如下:
復(fù)制代碼 代碼如下:
typedef struct {
char addr_ipv4[4];
} IPADDR_IPV4;
#include
// Function: To extract HEX value of IP address from string expression.
IPADDR_IPV4 parse_IPString(const char *str, u8 strlen) {
IPADDR_IPV4 ipv4;
char tmpBuf[4] = {0};
u8 k;
u8 inx = 0;
u8 j = 0;
// Dprintf("The ch_ip is:%sn", ch_ip);
for (k=0; k
if (str[k] != '.') {
// Dprintf("k-inx: %dn", k-inx);
memcpy(&tmpBuf[k-inx], &str[k], 1);
}
else {
inx = k + 1;
// Dprintf("inx: %d, tmpBuf: %sn", inx, tmpBuf);
ipv4.addr_ipv4[j++] = strtol(tmpBuf, NULL, 10);
memset(tmpBuf, 0, sizeof(tmpBuf));
continue;
}
// Dprintf("tmpBuf: %sn", tmpBuf);
ipv4.addr_ipv4[j] = strtol(tmpBuf, NULL, 10);
}
// Dprintf("ipv4 is: ");
// for (k=0; k
// Dprintf("%d", ipv4.addr_ipv4[k]);
// }
// Dprintf("n");
return ipv4;
}
應(yīng)用如下:
復(fù)制代碼 代碼如下:
char* ch_ip = NULL;
IPADDR_IPV4 ipv4Addr;
ch_ip = (char*)malloc(16);
memset(ch_ip, 0, 16);
// parse IP address
ch_ip = getIPAddr();
// convert IP address from string to HEX expression
ipv4Addr = parse_IPString(ch_ip, strlen(ch_ip));
3. 注意事項(xiàng):
原來(lái)進(jìn)行字符比較的時(shí)候,用的是if (str[k] != ".")而不是if (str[k] != '.'),結(jié)果一直不對(duì)。
后來(lái)反復(fù) 查找原因,才知道單引號(hào)''和雙引號(hào)“”的區(qū)別:
(1)含義不同。
單引號(hào)引起的一個(gè)字符代表一個(gè)整數(shù),整數(shù)值對(duì)應(yīng)于該字符在ASCII字符集中的序列值;
雙引號(hào)引起的都是字符串,哪怕只有一個(gè)字符也是字符串,雙引號(hào)引起的一個(gè)字符代表一個(gè)指向無(wú)名數(shù)組起始字符的指針;
比如:'.'代表十進(jìn)制46,十六進(jìn)制0x2E;
而"."代表指向起始字符為"."的某數(shù)組的指針;
(2)大小不同。
單引號(hào)引起的一個(gè)字符大小就是一個(gè)字節(jié);
雙引號(hào)引起的一個(gè)字符大小是兩個(gè)字節(jié),因?yàn)殡p引號(hào)引起的字符串會(huì)在字符串的末尾添加一個(gè)0x00作為字符串的結(jié)束標(biāo)識(shí)。
拓展內(nèi)容:C語(yǔ)言基本算法
1.交換(兩量交換借助第三者)
例1、任意讀入兩個(gè)整數(shù),將二者的值交換后輸出。
main()
{int a,b,t;
scanf("%d%d",&a,&b);
printf("%d,%d ",a,b);
t=a; a=b; b=t;
printf("%d,%d ",a,b);}
【解析】程序中加粗部分為算法的核心,如同交換兩個(gè)杯子里的飲料,必須借助第三個(gè)空杯子。
假設(shè)輸入的值分別為3、7,則第一行輸出為3,7;第二行輸出為7,3。
其中t為中間變量,起到“空杯子”的作用。
注意:三句賦值語(yǔ)句賦值號(hào)左右的各量之間的關(guān)系!
【應(yīng)用】
例2、任意讀入三個(gè)整數(shù),然后按從小到大的順序輸出。
main()
{int a,b,c,t;
scanf("%d%d%d",&a,&b,&c);
if(a>b){ t=a; a=b; b=t; }
if(a>c){ t=a; a=c; c=t; }
if(b>c) { t=b; b=c; c=t; }
printf("%d,%d,%d ",a,b,c);}
2.累加
累加算法的要領(lǐng)是形如“s=s+A”的累加式,此式必須出現(xiàn)在循環(huán)中才能被反復(fù)執(zhí)行,從而實(shí)現(xiàn)累加功能!癆”通常是有規(guī)律變化的表達(dá)式,s在進(jìn)入循環(huán)前必須獲得合適的初值,通常為0。
例1、求1+2+3+……+100的和。
main()
{int i,s;
s=0; i=1;
while(i<=100)
{s=s+i;
i=i+1;
}
printf("1+2+3+...+100=%d ",s);}
【解析】程序中加粗部分為累加式的典型形式,賦值號(hào)左右都出現(xiàn)的變量稱(chēng)為累加器,其中“i = i + 1”為特殊的累加式,每次累加的值為1,這樣的累加器又稱(chēng)為計(jì)數(shù)器。
3.累乘
累乘算法的要領(lǐng)是形如“s=s*A”的累乘式,此式必須出現(xiàn)在循環(huán)中才能被反復(fù)執(zhí)行,從而實(shí)現(xiàn)累乘功能。“A”通常是有規(guī)律變化的表達(dá)式,s在進(jìn)入循環(huán)前必須獲得合適的初值,通常為1。
例1、求10!
[分析]10!=1×2×3×……×10
main()
{int i; long c;
c=1; i=1;
while(i<=10)
{c=c*i;
i=i+1;
}
printf("1*2*3*...*10=%ld ",c);}
【c語(yǔ)言中單引號(hào)和雙引號(hào)的區(qū)別】相關(guān)文章:
C語(yǔ)言單引號(hào)和雙引號(hào)的區(qū)別05-04
PHP中單引號(hào)與雙引號(hào)的區(qū)別02-10
C語(yǔ)言中static和extern的區(qū)別02-27
C語(yǔ)言中char*和char[]用法區(qū)別03-17
c語(yǔ)言中bit和sbit的區(qū)別哪些04-21
C語(yǔ)言中Sizeof與Strlen的區(qū)別與聯(lián)系04-07