C语言根据协议分割获取字符串单元的实现代码
2019/7/10 22:32:21
本文主要是介绍C语言根据协议分割获取字符串单元的实现代码,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
协议做如下规定:
规定数据协议:
序列号 长度 状态字 数据长度 数据1 数据2 数据3
以空格作为数据单元。
ep:
00001 00007 1 3 34567 26358 32698 (1) (2) (3)(4) (5) (6) (7)
如ep所示:
(1)00001就是数字1,即代表序列号为1 (2)00007就是数字7,即代表长度为7 (3)1代表状态字 (4)3代表数字长度 (5)34567代表数据1 (6)26358代表数据2 (7)32698代表数据3
这样就找到规律了,假设数据都为整型或者负整型,我们就可以来实现以下代码:
#include <stdio.h> #include <stdlib.h> #include <string.h> //根据空格拆分字符串 int partition(char *src, char *par, int pos) { int i,j; i = pos; //取得一个非空字符 while(src[i] == ' ') ++i; if(src[i] != '\0') { j = 0; while((src[i] != '\0') && (src[i] != ' ')) { //判断条件是否满足 if((src[i] > '9') || (src[i] < '0') && (src[i] != '-')) return -1 ; par[j] = src[i]; ++i; ++j; } par[j]='\0'; return i; } else return -1; } int main(void) { int serial_number ; int lenght ; int status ; int data_length; int data1,data2,data3; int position = 0; int para_flag = 1 ; int parameter_item = 0; char partition_string[20] = {0}; char *data = "00001 00007 1 3 34567 26358 32698"; while(para_flag) { if(para_flag == 0) break ; if((position = partition(data,partition_string,position)) != -1) { ++parameter_item ; switch(parameter_item) { case 1: serial_number = atoi(partition_string); break ; case 2: lenght = atoi(partition_string); break ; case 3: status = atoi(partition_string); break ; case 4: data_length = atoi(partition_string); break ; case 5: data1 = atoi(partition_string); break ; case 6: data2 = atoi(partition_string); break ; case 7: data3 = atoi(partition_string); para_flag = 0 ; break ; } } } printf("序号:%d\n",serial_number); printf("长度:%d\n",lenght); printf("状态字:%d\n",status); printf("数据长度:%d\n",data_length); printf("数据1:%d\n",data1); printf("数据2:%d\n",data2); printf("数据3:%d\n",data3); return 0; }
运行结果:
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对找一找教程网的支持。如果你想了解更多相关内容请查看下面相关链接
这篇关于C语言根据协议分割获取字符串单元的实现代码的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-25Elevate Your Lead Generation Game with Maps Scraper AI
- 2024-05-15PingCAP 黄东旭参与 CCF 秀湖会议,共探开源教育未来
- 2024-05-13PingCAP 戴涛:构建面向未来的金融核心系统
- 2024-05-09flutter3.x_macos桌面os实战
- 2024-05-09Rust中的并发性:Sync 和 Send Traits
- 2024-05-08使用Ollama和OpenWebUI在CPU上玩转Meta Llama3-8B
- 2024-05-08完工标准(DoD)与验收条件(AC)究竟有什么不同?
- 2024-05-084万 star 的 NocoDB 在 sealos 上一键起,轻松把数据库编程智能表格
- 2024-05-08Mac 版Stable Diffusion WebUI的安装
- 2024-05-08解锁CodeGeeX智能问答中3项独有的隐藏技能