链表:元素插入有序数列

项目场景:

提示:这里简述项目相关背景:
例如:项目场景:示例:通过蓝牙芯片(HC-05)与手机 APP 通信,每隔 5s 传输一批传感器数据(不是很大)


问题描述:

提示:这里描述项目中遇到的问题:
例如:数据传输过程中数据不时出现丢失的情况,偶尔会丢失一部分数据
APP 中接收数据代码:

#include<stdio.h>
//malloc:
#include<stdlib.h>
//strcpy、strcmp:
#include<string.h>
//构建链表
typedef struct world{
	char data;
	struct world *next;
}LNode,*LinkList;
LinkList create();

void sort(LinkList L,LNode temp);

int main(){
	LinkList L;
	LNode *p,temp;
	char n;
	puts("************");
	temp.data=getchar();
	//scanf("%c",&n);
	while((getchar())!='\n');
	puts("************");
	L=create();
	puts("************");
sort(L,temp);
	p=L->next;
	while(p){
		printf("%c\n",p->data);
		p=p->next;
	}
	return 0;
}

LinkList create(){
	LinkList head;
	LNode *p,*q;
	char a;
	head=(LinkList)malloc(sizeof(LNode));
	head->next=NULL;
	while((a=getchar())!='\n'){
		p=(LNode *)malloc(sizeof(LNode));
		p->data=a;
		if(head->next==NULL)
			head->next=p;
		else
			q->next=p;
		q=p;
	}
	q->next=NULL;
	return head;
}
void sort(LinkList L,LNode temp){
	LNode *p,*q,*t;
	t=(LNode *)malloc(sizeof(LNode));
	t->data=temp.data;
	p=L;q=L->next;
	while(q){
		if(t->data<q->data){
			
			p->next=t;
			t->next=q;
			break;
		}
		p=p->next;q=q->next;

	}
}

原因分析:

提示:这里填写问题的分析:
例如:Handler 发送消息有两种方式,分别是 Handler.obtainMessage()和 Handler.sendMessage(),其中 obtainMessage 方式当数据量过大时,由于 MessageQuene 大小也有限,所以当 message 处理不及时时,会造成先传的数据被覆盖,进而导致数据丢失。


解决方案:

提示:这里填写该问题的具体解决方案:
例如:新建一个 Message 对象,并将读取到的数据存入 Message,然后 mHandler.obtainMessage(READ_DATA, bytes, -1, buffer).sendToTarget();换成 mHandler.sendMessage()。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值