C语言 百文网手机站

c语言中单引号和双引号的区别

时间:2022-04-19 11:59:33 C语言 我要投稿

c语言中单引号和双引号的区别

  单引号和双引号都可以作为字符串的开始符和关闭符,并且只能同一种单或者双引号来定义开始和结束。以下是小编分享给大家的c语言中单引号和双引号的区别,欢迎阅读!

  问题:

  从c++文件中将std:string转换为char*后,返回包含IP地址的char*,需要将该字符串char*中的IP地址提取出来;

  解决办法:

  1. 解决思路:

  IP地址最长为12字符+3句点=15字符,一般性表示为192.168.111.111;

  可以从第一个字符开始解析,当不是'.'时,将所有字符保存下来,然后把所有保存下来的字符转换为16进制就可以了;

  2. 程序如下:

  复制代码 代码如下:

  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;

  }

  应用如下:

  复制代码 代码如下:

  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] != '.'),结果一直不对。

  后来反复 查找原因,才知道单引号''和双引号“”的区别:

  (1)含义不同。

  单引号引起的一个字符代表一个整数,整数值对应于该字符在ASCII字符集中的序列值;

  双引号引起的都是字符串,哪怕只有一个字符也是字符串,双引号引起的一个字符代表一个指向无名数组起始字符的指针;

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

  而"."代表指向起始字符为"."的某数组的指针;

  (2)大小不同。

  单引号引起的一个字符大小就是一个字节;

  双引号引起的一个字符大小是两个字节,因为双引号引起的字符串会在字符串的末尾添加一个0x00作为字符串的结束标识。

  拓展内容:C语言基本算法

  1.交换(两量交换借助第三者)

  例1、任意读入两个整数,将二者的'值交换后输出。

  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);}

  【解析】程序中加粗部分为算法的核心,如同交换两个杯子里的饮料,必须借助第三个空杯子。

  假设输入的值分别为3、7,则第一行输出为3,7;第二行输出为7,3。

  其中t为中间变量,起到“空杯子”的作用。

  注意:三句赋值语句赋值号左右的各量之间的关系!

  【应用】

  例2、任意读入三个整数,然后按从小到大的顺序输出。

  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.累加

  累加算法的要领是形如“s=s+A”的累加式,此式必须出现在循环中才能被反复执行,从而实现累加功能。“A”通常是有规律变化的表达式,s在进入循环前必须获得合适的初值,通常为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);}

  【解析】程序中加粗部分为累加式的典型形式,赋值号左右都出现的变量称为累加器,其中“i = i + 1”为特殊的累加式,每次累加的值为1,这样的累加器又称为计数器。

  3.累乘

  累乘算法的要领是形如“s=s*A”的累乘式,此式必须出现在循环中才能被反复执行,从而实现累乘功能。“A”通常是有规律变化的表达式,s在进入循环前必须获得合适的初值,通常为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语言中单引号和双引号的区别】相关文章:

C语言单引号和双引号的区别03-01

C语言中static和extern的区别10-02

c语言中bit和sbit的区别哪些03-18

在C语言中函数调用方式的区别11-20

C语言中指针与数组的区别03-11

c语言单引号的用法指导10-06

C语言中的指针和内存泄漏10-05

Java语言中substr和substring的区别11-13

浅谈c语言和c++和VB的区别11-24

C语言中isalnum()函数和isalpha()函数的对比11-21