打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
java与c/c 进行socket通信的一些问题(1)

近几天看到csdn上问c/c++和java通信的问题比较多,特别是c特有的数据结构(如struct)。

特地根据网友的一个问题举个例子,希望对初学者有所帮助。

原问题见:http://community.csdn.net/Expert/topic/3886/3886989.xml?temp=.3527033

这类问题通常是为了利用原有Server或者Server不能做修改(通常是c/c++)造成。

比如Server端只接收一个结构Employee,定义如下:

struct UserInfo {
  char UserName[20];
  int UserId;
};
struct Employee {
  UserInfo user;
  float salary;
};
当然也可以定义为

struct Employee {
  char name[20];
  int    id;
  float salary;
};

java client 测试源码(为说明问题,假设struct字节对齐,sizeof(Employee)=28)

import java.net.*;

/**
 * 与C语言通信(java做Client,c/c++做Server,传送一个结构)
 * @author kingfish
 * @version 1.0
 */
class Employee {
  private byte[] buf = new byte[28];  //为说明问题,定死大小,事件中可以灵活处理

  /**
   * 将int转为低字节在前,高字节在后的byte数组
   */
  private static byte[] toLH(int n) {
    byte[] b = new byte[4];
    b[0] = (byte) (n & 0xff);
    b[1] = (byte) (n >> 8 & 0xff);
    b[2] = (byte) (n >> 16 & 0xff);
    b[3] = (byte) (n >> 24 & 0xff);
    return b;
  }

  /**
   * 将float转为低字节在前,高字节在后的byte数组
   */
  private static byte[] toLH(float f) {
    return toLH(Float.floatToRawIntBits(f));
  }

  /**
   * 构造并转换
   */
  public Employee(String name, int id, float salary) {
    byte[] temp = name.getBytes();
    System.arraycopy(temp, 0, buf, 0, temp.length);

    temp = toLH(id);
    System.arraycopy(temp, 0, buf, 20, temp.length);

    temp = toLH(salary);
    System.arraycopy(temp, 0, buf, 24, temp.length);
  }

  /**
   * 返回要发送的数组
   */
  public byte[] getBuf() {
    return buf;
  }

  /**
   * 发送测试
   */
  public static void main(String[] args) {
    try {
      Socket sock = new Socket("127.0.0.1", 8888);
      sock.getOutputStream().write(new Employee("kingfish", 123456789, 8888.99f).
                                   getBuf());
      sock.close();
    }
    catch (Exception e) {
      e.printStackTrace();
    }

} //end

---------------------------------------------------------------------------

当然,也可以利用writeInt,writeFloat方法发送,但字节顺序需要改为低在前。
这个问题稍后在讨论。


如有任何问题,请指正!

kingfish
2005.3.29



Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=333635


[收藏到我的网摘]   kingfish发表于 2005年03月29日 21:39:00

相关文章:



#  
 hayingyezi 发表于2005-04-15 16:37:00  IP: 219.82.172.*
不错!适用!

#  
 james 发表于2005-06-10 15:07:00  IP: 61.186.252.*
是8字节,但有没有办法传送呢?是不是可以同样倒转顺序,将big endian转换成little endian传过去,我试了,可结果不对,请指教,谢谢

#  
 james 发表于2005-06-09 22:09:00  IP: 61.186.252.*
在看了你的文章后我试了一下,正确的执行了,但在传送Double的时候有问题,结果不对,能告诉为什么吗?谢谢

#  
 kingfish 发表于2005-06-10 12:20:00  IP: 61.186.252.*
double范围不一样(8字节),当然不对了。

#  
 zhousheng29 发表于2005-07-15 15:26:00  IP: 61.186.252.*
我实验了您的方法,并增加了一种数据类型short,发现编译时有些问题,报错。
sock.getOutputStream().write(new Employee("kingfish", 123456789, 8888.99f).getBuf());
比如发送增加一个域,
sock.getOutputStream().write(new Employee(0xFFFF,"kingfish", 123456789, 8888.99f).getBuf());
错误显示:
cannot resolve symbol constructor JavaToC(int,java.lang.String,int,float)

如果加强制转换
sock.getOutputStream().write(new Employee((short)0xFFFF,"kingfish", 123456789, 8888.99f).getBuf());
编译通过

0xFFFF本身就是short类型,为什么还要强制转换。

#  
 kingfish 发表于2005-07-19 19:16:00  IP: 61.186.252.*
to zhousheng29
//0xFFFF本身就是short类型,为什么还要强制转换。

不对。java认为0xFFFF缺省为int,所以编译会报错


to james

邮件中收到了吧?

#  
 zhousheng29 发表于2005-07-28 17:15:00  IP: 61.186.252.*
byte型也有这样的问题,0xFF也认为是int?

#  
 engine 发表于2005-08-02 15:29:00  IP: 61.186.252.*
我想问一下,我得client采用的是c++,而server采用的是java,想要在他们之间传递string和char类型的字符串,请问该如何实现?谢谢!

#  
 engine 发表于2005-08-02 15:30:00  IP: 61.186.252.*
刚才忘记说我得邮箱了! 请各位高手帮忙!谢谢谢谢。。。。 我得email是:zhaog@ss.pku.edu.cn

#  
 kingfish 发表于2005-08-11 16:42:00  IP: 61.186.252.*
to engine:

c++里用char
java里用byte
就可以了

#  
 wing 发表于2006-08-22 16:56:00  IP: 218.244.40.*
我正在做一个java socket与c通信的程序,是这样我需要传两位byte类型到c端表示长度(两位分别传n/256,n%256),但是c与java的byte类型取值是范围不同的c是0-256 java是-127-+127,一个有符号一个无符号,java端我一旦大于127或者小于0传过去就不对了,请问我该怎么转换,才可以传过去c端正确认出来?谢谢你!
我的邮箱是wing8204@163.com

#  
 lvwfe 发表于2006-08-23 11:35:00  IP: 218.240.145.*
我也有同样的问题,是C和JAVA通过SOCKET通信,主要是想传int 和char类型,做了些实验,结果不对.希望能够得到一个比较详细的讲解资料.谢谢!!!! 我的邮箱是lvwfe@163.com

#  
 sam 发表于2006-08-24 10:09:00  IP: 121.35.54.*
我正在做一个java socket与c通信的程序,是这样我需要传两位byte类型到c端表示长度(两位分别传n/256,n%256),但是c与java的byte类型取值是范围不同的c是0-256 java是-127-+127,一个有符号一个无符号,java端我一旦大于127或者小于0传过去就不对了,请问我该怎么转换,才可以传过去c端正确认出来?谢谢你!
我也有同样的问题:
我的邮箱是sum_kk@163.com

#  
 kingfish 发表于2006-09-06 15:27:00  IP: 58.246.198.*
java发送byte数组:
head[0] = (byte) (len / 256);
head[1] = (byte) (len % 256);

java接收到byte数组:
n = head[0];
if(n<0) n+=256;



#  
 kingfish 发表于2006-09-06 15:28:00  IP: 58.246.198.*
java发送byte数组:
head[0] = (byte) (len / 256);
head[1] = (byte) (len % 256);

java接收到byte数组:
n = head[0];
if(n<0) n+=256;
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
java整数和byte数组之间的转换
java基于TCP的socket数据包拆分方法
使用DatagramSocket发送、接收数据(Socket之UDP套接字)
Java Socket编程(五)简单的WEB服务器
初始化(清0)数组的函数 - CSDN - FAQ
C#泛型详解
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服