亚洲精品中文字幕无乱码_久久亚洲精品无码AV大片_最新国产免费Av网址_国产精品3级片

C語言 百文網(wǎng)手機站

c語言中單引號和雙引號的區(qū)別

時間:2022-04-19 11:59:33 C語言 我要投稿

c語言中單引號和雙引號的區(qū)別

  單引號和雙引號都可以作為字符串的開始符和關(guān)閉符,并且只能同一種單或者雙引號來定義開始和結(jié)束。以下是小編分享給大家的c語言中單引號和雙引號的區(qū)別,歡迎閱讀!

  問題:

  從c++文件中將std:string轉(zhuǎn)換為char*后,返回包含IP地址的char*,需要將該字符串char*中的IP地址提取出來;

  解決辦法:

  1. 解決思路:

  IP地址最長為12字符+3句點=15字符,一般性表示為192.168.111.111;

  可以從第一個字符開始解析,當不是'.'時,將所有字符保存下來,然后把所有保存下來的字符轉(zhuǎn)換為16進制就可以了;

  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. 注意事項:

  原來進行字符比較的時候,用的是if (str[k] != ".")而不是if (str[k] != '.'),結(jié)果一直不對。

  后來反復(fù) 查找原因,才知道單引號''和雙引號“”的區(qū)別:

  (1)含義不同。

  單引號引起的一個字符代表一個整數(shù),整數(shù)值對應(yīng)于該字符在ASCII字符集中的序列值;

  雙引號引起的都是字符串,哪怕只有一個字符也是字符串,雙引號引起的一個字符代表一個指向無名數(shù)組起始字符的指針;

  比如:'.'代表十進制46,十六進制0x2E;

  而"."代表指向起始字符為"."的某數(shù)組的指針;

  (2)大小不同。

  單引號引起的一個字符大小就是一個字節(jié);

  雙引號引起的一個字符大小是兩個字節(jié),因為雙引號引起的字符串會在字符串的末尾添加一個0x00作為字符串的結(jié)束標識。

  拓展內(nèi)容:C語言基本算法

  1.交換(兩量交換借助第三者)

  例1、任意讀入兩個整數(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);}

  【解析】程序中加粗部分為算法的核心,如同交換兩個杯子里的飲料,必須借助第三個空杯子。

  假設(shè)輸入的值分別為3、7,則第一行輸出為3,7;第二行輸出為7,3。

  其中t為中間變量,起到“空杯子”的作用。

  注意:三句賦值語句賦值號左右的各量之間的關(guān)系!

  【應(yīng)用】

  例2、任意讀入三個整數(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í)行,從而實現(xiàn)累加功能!癆”通常是有規(guī)律變化的表達式,s在進入循環(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);}

  【解析】程序中加粗部分為累加式的典型形式,賦值號左右都出現(xiàn)的變量稱為累加器,其中“i = i + 1”為特殊的累加式,每次累加的值為1,這樣的累加器又稱為計數(shù)器。

  3.累乘

  累乘算法的要領(lǐng)是形如“s=s*A”的累乘式,此式必須出現(xiàn)在循環(huán)中才能被反復(fù)執(zhí)行,從而實現(xiàn)累乘功能!癆”通常是有規(guī)律變化的表達式,s在進入循環(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語言中單引號和雙引號的區(qū)別】相關(guān)文章:

C語言單引號和雙引號的區(qū)別03-01

C語言中static和extern的區(qū)別10-02

c語言中bit和sbit的區(qū)別哪些03-18

在C語言中函數(shù)調(diào)用方式的區(qū)別11-20

C語言中指針與數(shù)組的區(qū)別03-11

c語言單引號的用法指導(dǎo)10-06

C語言中的指針和內(nèi)存泄漏10-05

Java語言中substr和substring的區(qū)別11-13

淺談c語言和c++和VB的區(qū)別11-24

C語言中isalnum()函數(shù)和isalpha()函數(shù)的對比11-21