取Byte数组里的值怎么这么难呢!

tulipcaicai 2011-08-23 04:48:11
哪题,请看下面代码

Byte* Send_CODE::Send_0000H()
{
short int XOR_L, XOR_H;
Byte sendArry[28];

sendArry[0] = 0xeb;
sendArry[1] = 0x90;
sendArry[2] = 0xeb;
sendArry[3] = 0x90;

for (int i = 4; i < 20; ++i)
{
sendArry[i] = 0xff;
}

sendArry[20] = 0x00;
sendArry[21] = 0x00;

sendArry[22] = 0x00;
sendArry[23] = 0x00;

XOR_L = MainForm->IntXOR16(sendArry,24, 4, 23) >> 16;
XOR_H = MainForm->IntXOR16(sendArry,24, 4, 23) >> 8;

sendArry[24] = XOR_L;
sendArry[25] = XOR_H;

sendArry[26] = 0x03;
sendArry[27] = 0x03;

return sendArry;
}


现在想实现把sendArry里面的串用UDP发送出去,即IdUDPClient->Send(Send_0000H(), TEncoding::Unicode),但是提示各种无符号char to UnicodeString 错误。要怎么转化Byte和UnicodeString啊!
...全文
242 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
BORLANDSUN 2011-08-24
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 zhouzhangkui 的回复:]

发Byte 的数组,何须转成UnicodeString那么麻烦
直接发送TBytes 类型即可
C/C++ code

void __fastcall TForm1::FormShow(TObject *Sender)
{
IdUDPServer1->DefaultPort = 10006;
IdUDPServer1->Active = true ;
}
void __fastca……
[/Quote]
正解。
ccrun.com 2011-08-24
  • 打赏
  • 举报
回复
IntXOR16函数改成这样:
int  IntXOR16(TBytes pCRCBuffer, int nlen,
int BeginOffsetOfCRCBuffer , int EndOffsetOfCRCBuffer)
{
int XOR;
Byte XOR_L, XOR_H;

Byte Buffer[1024];

XOR_L = 0x00;
XOR_H = 0x00;

if (BeginOffsetOfCRCBuffer< 0 || EndOffsetOfCRCBuffer < BeginOffsetOfCRCBuffer)
{
return -1;
}

int i = 0;
for (i = 0; i < nlen; i++)
{
Buffer[i] = pCRCBuffer[i++];
}

for (i = BeginOffsetOfCRCBuffer; i < EndOffsetOfCRCBuffer; i = i + 2)
{
XOR_L = XOR_L ^ Buffer[i];
}

for (i = BeginOffsetOfCRCBuffer + 1; i < EndOffsetOfCRCBuffer; i = i + 2)
{
XOR_H = XOR_H ^ Buffer[i];
}

XOR = XOR_L | XOR_H << 8;

return XOR;
}


公用的纯算法函数,没必要放到Form类中。
tulipcaicai 2011-08-24
  • 打赏
  • 举报
回复
仔细的看了一下大家提供的东东,现在贴一下我的XOR部分和UDP代码,大家多提宝贵意见啊。

int  TMainForm::IntXOR16(Byte* pCRCBuffer, int nlen,
int BeginOffsetOfCRCBuffer , int EndOffsetOfCRCBuffer)
{
Byte* ptr = pCRCBuffer;

int XOR;
Byte XOR_L, XOR_H;

Byte Buffer[1024];

XOR_L = 0x00;
XOR_H = 0x00;

if (BeginOffsetOfCRCBuffer< 0 || EndOffsetOfCRCBuffer < BeginOffsetOfCRCBuffer)
{
return -1;
}

int i = 0;
for (i = 0; i < nlen; i++)
{
Buffer[i] = *ptr++;
}

for (i = BeginOffsetOfCRCBuffer; i < EndOffsetOfCRCBuffer; i = i + 2)
{
XOR_L = XOR_L ^ Buffer[i];
}

for (i = BeginOffsetOfCRCBuffer + 1; i < EndOffsetOfCRCBuffer; i = i + 2)
{
XOR_H = XOR_H ^ Buffer[i];
}

XOR = XOR_L | XOR_H << 8;
return XOR;
}


调用 XOR 代码

void Send_CODE::Send_0000H(Byte sendArry[])
{
short int XOR_L, XOR_H;

sendArry[0] = 0xeb;
sendArry[1] = 0x90;
sendArry[2] = 0xeb;
sendArry[3] = 0x90;

for (int i = 4; i < 20; ++i)
{
sendArry[i] = 0xff;
}

sendArry[20] = 0x00;
sendArry[21] = 0x00;

sendArry[22] = 0x00;
sendArry[23] = 0x00;

XOR_L = MainForm->IntXOR16(sendArry,24, 4, 23) >> 16;
XOR_H = MainForm->IntXOR16(sendArry,24, 4, 23) >> 8;

sendArry[24] = XOR_L;
sendArry[25] = XOR_H;

sendArry[26] = 0x03;
sendArry[27] = 0x03;

}


UDP代码:

void __fastcall TMainForm::Button4Click(TObject *Sender)
{
String strfilePath;
char recvBuffer[66];
strfilePath = "c:\\uptime.dat";
ifstream infile(strfilePath.c_str(), ios::binary);
if (!infile)
{

}
else
{
infile.read(recvBuffer, 66);
}

// String str = "我是一个小菜菜";
// this->IdUDPClient->Send(str, TEncoding::Unicode);
TBytes arr;
arr.set_length(28);

Send_CODE *psend_code = new Send_CODE();

Byte sendArry[28];

psend_code->Send_0000H(sendArry);

memcpy(&arr[0], sendArry, 28);

this->IdUDPClient->SendBuffer("192.168.2.255", 12345, arr);

delete psend_code;
}
ccrun.com 2011-08-24
  • 打赏
  • 举报
回复
你原先是如何是XOR运算的?
tulipcaicai 2011-08-24
  • 打赏
  • 举报
回复
一楼和四楼的方法都好用,谢谢。
我现在的问题是要进行XOR运算,之前用的是Byte数组,现在用TBytes时,TByteDynArray 是不支持 XOR的,请问我要怎么转换呢?

tulipcaicai 2011-08-24
  • 打赏
  • 举报
回复
谢谢大家,结贴
ccrun.com 2011-08-23
  • 打赏
  • 举报
回复
楼主的代码有几个问题:

1. 正如2楼平平所说,Send_0000H函数中,将函数内的byte数组作为返回对象,这是很危险的,你得到的很可能不是预期的值。改成以参数的方式代入Bytes数组地址为佳。

2. IdUDPClient和IdUDPServer之间如果要传输String字符串,只需注意Bytes和String的转换:
#include <idglobal.hpp>
// 发送方:将String转成TBytes
void __fastcall TForm1::Button1Click(TObject *Sender)
{
String str = "我了个艹的abc";
IdUDPClient1->Send(str, TEncoding::Unicode);
}
// 接收方:将TBytes转成String
void __fastcall TForm1::IdUDPServer1UDPRead(TIdUDPListenerThread *AThread,
TBytes AData, TIdSocketHandle *ABinding)
{
String str = BytesToString(AData, TEncoding::Unicode);
ShowMessage(str);
}


3. 就楼主的代码来说,Bytes数组中存在0x00的成员,还是建议直接以TBytes的方式发送,以保证数据的完整性。IdUDPClient组件重载了SendBuf函数,其中一个重载方式,接收TByteDynArray类型的参数,这个TByteDynArray就是Byte类型的动态数组。楼主的代码我略修改一下:
__fastcall TForm1::TForm1(TComponent* Owner)
: TForm(Owner)
{
IdUDPServer1->DefaultPort = 10000;
IdUDPServer1->Active = true;

IdUDPClient1->Host = "127.0.0.1";
IdUDPClient1->Port = 10000;
}
//---------------------------------------------------------------------------
void Send_0000H(Byte sendArry[])
{
short int XOR_L, XOR_H;

sendArry[0] = 0xeb;
sendArry[1] = 0x90;
sendArry[2] = 0xeb;
sendArry[3] = 0x90;

for (int i = 4; i < 20; ++i)
{
sendArry[i] = 0xff;
}

sendArry[20] = 0x00;
sendArry[21] = 0x00;

sendArry[22] = 0x00;
sendArry[23] = 0x00;

// XOR_L = MainForm->IntXOR16(sendArry,24, 4, 23) >> 16;
// XOR_H = MainForm->IntXOR16(sendArry,24, 4, 23) >> 8;
//
// sendArry[24] = XOR_L;
// sendArry[25] = XOR_H;

sendArry[26] = 0x03;
sendArry[27] = 0x03;
}

void __fastcall TForm1::Button1Click(TObject *Sender)
{
Byte sendArry[28];
Send_0000H(sendArry);

TByteDynArray bda;
bda.set_length(28);

memcpy(&bda[0], sendArry, 28);

IdUDPClient1->SendBuffer(bda);
}
//---------------------------------------------------------------------------
void __fastcall TForm1::IdUDPServer1UDPRead(TIdUDPListenerThread *AThread, TBytes AData, TIdSocketHandle *ABinding)
{
ShowMessage(AData.Length);
}
zzbinfo 2011-08-23
  • 打赏
  • 举报
回复
+1
IdUDPClient1->SendBuffer
pp616 2011-08-23
  • 打赏
  • 举报
回复
Byte* Send_CODE::Send_0000H()
{
...
Byte sendArry[28];
...
}
sendArry是声明在函数栈里的, 当函数返回时sendArry就释放掉了,或者说不在你程序的控制范围了。你返回它的指针已经没有意义了。别的程序随时可能重写那个内存块的。
周药师 2011-08-23
  • 打赏
  • 举报
回复
发Byte 的数组,何须转成UnicodeString那么麻烦
直接发送TBytes 类型即可

void __fastcall TForm1::FormShow(TObject *Sender)
{
IdUDPServer1->DefaultPort = 10006;
IdUDPServer1->Active = true ;
}
void __fastcall TForm1::IdUDPServer1UDPRead(TIdUDPListenerThread *AThread, TBytes AData,
TIdSocketHandle *ABinding)
{
//TBytes为字节数组类型...
AnsiString ls_str="" ;
int li_len = AData.Length ;
for(int i =0 ;i<li_len ;i++)
ls_str = ls_str + (char)AData[i] ;
Memo1->Lines->Add(ls_str);
}
void __fastcall TForm1::Button3Click(TObject *Sender)
{
TBytes bt;
bt.set_length(2);//设定数组长度
bt[0]='A';
bt[1]='B';
IdUDPClient1->SendBuffer("127.0.0.1",10006,bt);
}

 学习对象对java感兴趣,但没有任何软件编程基础,想先从零基础入手的软件开发爱好者;希望从另外一些简单的其他语言转型从事java开发的求职人员。适合大学生学习计算机入门,通过java语言计算机二级。想从事编程开发的人员、具有计算机基础、面试不过关的待业者、出校门的大学生、以及编程能力提升的从业者、以及世界500强的java工程师。 课程目标:你将对java内容有个全面的掌握,助编程能力的提升,让你理解500强企业要求的度,通过计算机二级java语言考试 学习计划如果是待业者,明天用8个小时,会在两个月内完成。如果是上班族,每周至少用12-20小时,4-6个月内完成。课后有附加资料和练习来巩固知识并加强编程能力。此课程注重500强企业的编程能力实战要求。Java是一门面向对象编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++以理解的多继承、指针等概念,因此Java语言具有功能强大和简单易用两个特征。Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程 。Java具有简单性、面向对象、分布式、健壮性、安全性、平台独立与可移植性、多线程、动态性等特点  。Java可以编写桌面应用程序、Web应用程序、分布式系统和嵌入式系统应用程序等。Java 具备下列特性。1.简单性Java看起来设计得很像C++,但是为了使语言小和容易熟悉,设计者们把C++语言中许多可用的特征去掉了,这些特征是一般程序员很少使用的。例如,Java不支持go to语句,代之以提供break和continue语句以及异常处理。Java还剔除了C++的操作符过载(overload)和多继承特征,并且不使用主文件,免去了预处理程序。因为Java没有结构,数组和串都是对象,所以不需要指针。Java能够自动处理对象的引用和间接引用,实现自动的无用单元收集,使用户不必为存储管理问题烦恼,能更多的时间和精力花在研发上。2.面向对象Java是一个面向对象的语言。对程序员来说,这意味着要注意应中的数据和操纵数据的方法(method),而不是严格地用过程来思考。在一个面向对象的系统中,类(class)是数据和操作数据的方法的集合。数据和方法一起描述对象(object)的状态和行为。每一对象是其状态和行为的封装。类是按一定体系和层次安排的,使得子类可以从超类继承行为。在这个类层次体系中有一个根类,它是具有一般行为的类。Java程序是用类来组织的。Java还包括一个类的扩展集合,分别组成各种程序包(Package),用户可以在自己的程序中使用。例如,Java提供产生图形用户接口部件的类(java.awt包),这awt是抽象窗口工具集(abstract windowing toolkit)的缩写,处理输入输出的类(java.io包)和支持网络功能的类(java.net包)。3.分布性Java设计成支持在网络上应用,它是分布式语言。Java既支持各种层次的网络连接,又以Socket类支持可靠的流(stream)网络连接,所以用户可以产生分布式的客户机和服务器。网络变成软件应用的分布运载工具。Java程序只要编写一次,就可到处运行。4.编译和解释性Java编译程序生成字节码(byte-code),而不是通常的机器码。Java字节码提供对体系结构中性的目标文件格式,代码设计成可有效地传送程序到多个平台。Java程序可以在任何实现了Java解释程序和运行系统(run-time system)的系统上运行。在一个解释性的环境中,程序开发的标准“链接”阶段大大消失了。如果说Java还有一个链接阶段,它只是把新类装进环境的过程,它是增量式的、轻量级的过程。因此,Java支持快速原型和容易试验,它将导致快速程序开发。这是一个与传统的、耗时的“编译、链接和测试”形成鲜明对比的精巧的开发过程。5.稳健性Java原来是用作编写消费类家用电子产品软件的语言,所以它是被设计成写高可靠和稳健软件的。Java消除了某些编程错误,使得用它写可靠软件相当容易。Java是一个强类型语言,它允许扩展编译时检查潜在类型不匹配问题的功能。Java要求显式的方法声明,它不支持C风格的隐式声明。这些严格的要求保证编译程序能捕捉调用错误,这就导致更可靠的程序。可靠性方面最重要的增强之一是Java的存储模型。Java不支持指针,它消除重写存储和讹误数据的可能性。类似地,Java自动的“无用单元收集”预防存储漏泄和其它有关动态存储分配和解除分配的有害错误。Java解释程序也执行许多运行时的检查,诸如验证所有数组和串访问是否在界限之内。异常处理是Java中使得程序更稳健的另一个特征。异常是某种类似于错误的异常条件出现的信号。使用try/catch/finally语句,程序员可以找到出错的处理代码,这就简化了出错处理和恢复的任务。6.安全性Java的存储分配模型是它防御恶意代码的主要方法之一。Java没有指针,所以程序员不能得到隐蔽起来的内幕和伪造指针去指向存储器。更重要的是,Java编译程序不处理存储安排决策,所以程序员不能通过查看声明去猜测类的实际存储安排。编译的Java代码中的存储引用在运行时由Java解释程序决定实际存储地址。Java运行系统使用字节码验证过程来保证装载到网络上的代码不违背任何Java语言限制。这个安全机制部分包括类如何从网上装载。例如,装载的类是放在分开的名字空间而不是局部类,预防恶意的小应用程序用它自己的版本来代替标准Java类。7.可移植性Java使得语言声明不依赖于实现的方面。例如,Java显式说明每个基本数据类型的大小和它的运算行为(这些数据类型由Java语法描述)。Java环境本身对新的硬件平台和操作系统是可移植的。Java编译程序也用Java编写,而Java运行系统用ANSIC语言编写。8.高性能Java是一种先编译后解释的语言,所以它不如全编译性语言快。但是有些情况下性能是很要紧的,为了支持这些情况,Java设计者制作了“及时”编译程序,它能在运行时把Java字节码翻译成特定CPU(中央处理器)的机器代码,也就是实现全编译了。Java字节码格式设计时考虑到这些“及时”编译程序的需要,所以生成机器代码的过程相当简单,它能产生相当好的代码。9.多线程性Java是多线程语言,它提供支持多线程的执行(也称为轻便过程),能处理不同任务,使具有线索的程序设计很容易。Java的lang包提供一个Thread类,它支持开始线索、运行线索、停止线索和检查线索状态的方法。Java的线索支持也包括一组同步原语。这些原语是基于监督程序和条件变量风范,由C.A.R.Haore开发的广泛使用的同步化方案。用关键词synchronized,程序员可以说明某些方法在一个类中不能并发地运行。这些方法在监督程序控制之下,确保变量维持在一个一致的状态。10.动态性Java语言设计成适应于变化的环境,它是一个动态的语言。例如,Java中的类是根据需要载入的,甚至有些是通过网络获的。 尹成老师带你步入Java语言基础的殿堂,讲课生动风趣、深入浅出,全套视频内容充实,整个教程以Java语言为核心,完整精彩的演练了Java语言操作流程以及各种精彩的小项目等,提高竞赛能力,非常适合同学们学习!课程特色特色一:通俗易懂本视频语言简洁,通俗易懂,将以理解的编程问题用简单清晰的语言描述,让你更容易理解。特色三:内容丰富本视频讲解的java语言知识更加丰富翔实,较之其他视频,本视频讲解的java语言知识更多更深入。特色三:配图详尽本视频在讲解知识点时都配图了表格或图示,在讲解案例时,都配备了流程图或分析图示,让你对所学知识点或案例理解更清晰。特色四:实战性强本视频讲解的每个知识都配备了一个小案例,这样既增加了学生动手能力,又巩固了学生所学知识。特色五:加入尹成老师微信群本视频尹成老师亲自答疑

13,825

社区成员

发帖
与我相关
我的任务
社区描述
C++ Builder相关内容讨论区
社区管理员
  • 基础类社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧