c語(yǔ)言中單引號(hào)和雙引號(hào)的區(qū)別(順利解決從字符串中提取IP地址的困惑)
問(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. 程序如下:
typedef struct {
char addr_ipv4[4];
} IPADDR_IPV4;
#include <stdlib.h>
// 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:%s\n", ch_ip);
for (k=0; k<strlen; k++) {
if (str[k] != '.') {
// Dprintf("k-inx: %d\n", k-inx);
memcpy(&tmpBuf[k-inx], &str[k], 1);
}
else {
inx = k + 1;
// Dprintf("inx: %d, tmpBuf: %s\n", inx, tmpBuf);
ipv4.addr_ipv4[j++] = strtol(tmpBuf, NULL, 10);
memset(tmpBuf, 0, sizeof(tmpBuf));
continue;
}
// Dprintf("tmpBuf: %s\n", tmpBuf);
ipv4.addr_ipv4[j] = strtol(tmpBuf, NULL, 10);
}
// Dprintf("ipv4 is: ");
// for (k=0; k<sizeof(ipv4.addr_ipv4); k++) {
// Dprintf("%d", ipv4.addr_ipv4[k]);
// }
// Dprintf("\n");
return ipv4;
}
應(yīng)用如下:
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í)。
在本人的程序中正確取到了IP地址。
問(wèn)題解決。
相關(guān)文章
C語(yǔ)言中數(shù)據(jù)如何存儲(chǔ)進(jìn)內(nèi)存揭秘
使用編程語(yǔ)言進(jìn)行編程時(shí),需要用到各種變量來(lái)存儲(chǔ)各種信息。變量保留的是它所存儲(chǔ)的值的內(nèi)存位置。這意味著,當(dāng)您創(chuàng)建一個(gè)變量時(shí),就會(huì)在內(nèi)存中保留一些空間。您可能需要存儲(chǔ)各種數(shù)據(jù)類(lèi)型的信息,操作系統(tǒng)會(huì)根據(jù)變量的數(shù)據(jù)類(lèi)型,來(lái)分配內(nèi)存和決定在保留內(nèi)存中存儲(chǔ)什么2022-08-08C語(yǔ)言動(dòng)態(tài)內(nèi)存管理malloc柔性數(shù)組示例詳解
這篇文章主要為大家介紹了C語(yǔ)言動(dòng)態(tài)內(nèi)存管理malloc柔性數(shù)組示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10C++程序的五大內(nèi)存分區(qū)實(shí)例詳解
C++內(nèi)存區(qū)域,一般可分為棧內(nèi)存區(qū)、堆內(nèi)存區(qū)、全局/靜態(tài)內(nèi)存區(qū)、文字常量?jī)?nèi)存區(qū)及程序代碼區(qū)5大分區(qū),本文就帶大家深刻的理解這5大內(nèi)存分區(qū),感興趣的可以了解一下2021-10-10字符串中找出連續(xù)最長(zhǎng)的數(shù)字字符串的實(shí)例代碼
這篇文章介紹了字符串中找出連續(xù)最長(zhǎng)的數(shù)字字符串的實(shí)例代碼,有需要的朋友可以參考一下2013-09-09C++中的vector使用詳解及重要部分底層實(shí)現(xiàn)
本篇文章會(huì)對(duì)vector的語(yǔ)法使用進(jìn)行詳解,同時(shí),還會(huì)對(duì)重要難點(diǎn)部分的底層實(shí)現(xiàn)進(jìn)行講解,其中有vector的迭代器失效和深拷貝問(wèn)題,希望本篇文章的內(nèi)容會(huì)對(duì)你有所幫助2023-07-07