热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

java设计缺陷_可能java设计缺陷、希望高手指正错误

创建表语句createtablet_user(u_idvarchar(255),u_namevarchar(255),u_ageInteger,u_pricedouble(5,2)

创建表语句

create table t_user(

u_id varchar(255),

u_name varchar(255),

u_age Integer,

u_price double(5,2),

uc_id varchar(255),

primary key(u_id)

);

create table t_user_class(

uc_id varchar(255),

uc_classNo Integer,

uc_funds double(5,2),

uc_back varchar(255),

primary key(uc_id)

);

java类:

1、UserT.java

package com.wolf.pojo.oneToone;

import java.io.Serializable;

public class UserT  implements Serializable{

private String id;

public String name;

private Integer age;

private double price;

private UserClass userclass;

public UserT(){}

public String getId() {

return id;

}

public void setId(String id) {

this.id = id;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public Integer getAge() {

return age;

}

public void setAge(Integer age) {

this.age = age;

}

public double getPrice() {

return price;

}

public void setPrice(double price) {

this.price = price;

}

public UserClass getUserclass() {

return userclass;

}

public void setUserclass(UserClass userclass) {

this.userclass = userclass;

}

@Override

public int hashCode() {

final int prime = 31;

int result = 1;

result = prime * result + ((age == null) ? 0 : age.hashCode());

result = prime * result + ((id == null) ? 0 : id.hashCode());

result = prime * result + ((name == null) ? 0 : name.hashCode());

long temp;

temp = Double.doubleToLongBits(price);

result = prime * result + (int) (temp ^ (temp >>> 32));

result = prime * result

+ ((userclass == null) ? 0 : userclass.hashCode());

return result;

}

@Override

public boolean equals(Object obj) {

if (this == obj)

return true;

if (obj == null)

return false;

if (getClass() != obj.getClass())

return false;

UserT other = (UserT) obj;

if (age == null) {

if (other.age != null)

return false;

} else if (!age.equals(other.age))

return false;

if (id == null) {

if (other.id != null)

return false;

} else if (!id.equals(other.id))

return false;

if (name == null) {

if (other.name != null)

return false;

} else if (!name.equals(other.name))

return false;

if (Double.doubleToLongBits(price) != Double

.doubleToLongBits(other.price))

return false;

if (userclass == null) {

if (other.userclass != null)

return false;

} else if (!userclass.equals(other.userclass))

return false;

return true;

}

@Override

public String toString() {

return "UserT [age=" + age + ", id=" + id + ", name=" + name

+ ", price=" + price + ", userclass=" + userclass + "]";

}

public UserT(String id, String name, Integer age, double price,

UserClass userclass) {

super();

this.id = id;

this.name = name;

this.age = age;

this.price = price;

this.userclass = userclass;

}

}

2、UserClass.java

package com.wolf.pojo.oneToone;

import java.io.Serializable;

import java.util.HashSet;

import java.util.Set;

public class UserClass   implements Serializable{

private  String id;

private Integer classNo;

private double funds;

private String back;

private Set users=new HashSet();

public UserClass(){}

public String getId() {

return id;

}

public void setId(String id) {

this.id = id;

}

public Integer getClassNo() {

return classNo;

}

public void setClassNo(Integer classNo) {

this.classNo = classNo;

}

public double getFunds() {

return funds;

}

public void setFunds(double funds) {

this.funds = funds;

}

public String getBack() {

return back;

}

public void setBack(String back) {

this.back = back;

}

public Set getUsers() {

return users;

}

public void setUsers(Set users) {

this.users = users;

}

@Override

public int hashCode() {

final int prime = 31;

int result = 1;

result = prime * result + ((back == null) ? 0 : back.hashCode());

result = prime * result + ((classNo == null) ? 0 : classNo.hashCode());

long temp;

temp = Double.doubleToLongBits(funds);

result = prime * result + (int) (temp ^ (temp >>> 32));

result = prime * result + ((id == null) ? 0 : id.hashCode());

result = prime * result + ((users == null) ? 0 : users.hashCode());

return result;

}

@Override

public boolean equals(Object obj) {

if (this == obj)

return true;

if (obj == null)

return false;

if (getClass() != obj.getClass())

return false;

UserClass other = (UserClass) obj;

if (back == null) {

if (other.back != null)

return false;

} else if (!back.equals(other.back))

return false;

if (classNo == null) {

if (other.classNo != null)

return false;

} else if (!classNo.equals(other.classNo))

return false;

if (Double.doubleToLongBits(funds) != Double

.doubleToLongBits(other.funds))

return false;

if (id == null) {

if (other.id != null)

return false;

} else if (!id.equals(other.id))

return false;

if (users == null) {

if (other.users != null)

return false;

} else if (!users.equals(other.users))

return false;

return true;

}

@Override

public String toString() {

return "UserClass [back=" + back + ", classNo=" + classNo + ", funds="

+ funds + ", id=" + id + ", users=" + users + "]";

}

public UserClass(String id, Integer classNo, double funds, String back,

Set users) {

super();

this.id = id;

this.classNo = classNo;

this.funds = funds;

this.back = back;

this.users = users;

}

}

映射文件:

UserT.hbm.xml

hibernate-mapping PUBLIC

"-//Hibernate/Hibernate Mapping DTD 3.0//EN"

"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

class="com.wolf.pojo.oneToone.UserClass"

column="uc_id"

>

UserClass.hbm.xml

hibernate-mapping PUBLIC

"-//Hibernate/Hibernate Mapping DTD 3.0//EN"

"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

测试类:

package com.wolf.main;

import java.util.UUID;

import org.hibernate.Session;

import org.hibernate.Transaction;

import com.wolf.pojo.oneToone.UserClass;

import com.wolf.pojo.oneToone.UserT;

public class UtilMain {

public static void main(String[] args) {

Session session= HibernateSessionFactory.getSession();

Transaction tr=session.beginTransaction();

UserClass usercls=new UserClass();

usercls.setId(UUID.randomUUID().toString());

UserT user=new UserT();

user.setId(UUID.randomUUID().toString());

user.setName("user0");

UserT user1=new UserT();

user1.setId(UUID.randomUUID().toString());

user1.setName("user1");

usercls.getUsers().add(user1);

usercls.getUsers().add(user);

user.setUserclass(usercls);

user1.setUserclass(usercls);

System.out.println(usercls.getUsers());

session.save(usercls);

tr.commit();

}

}

出现错误是:

Exception in thread "main" java.lang.StackOverflowError

at java.util.HashMap$KeyIterator.(HashMap.java:826)

at java.util.HashMap.newKeyIterator(HashMap.java:840)

at java.util.HashMap$KeySet.iterator(HashMap.java:874)

at java.util.HashSet.iterator(HashSet.java:153)

at java.util.AbstractCollection.toString(AbstractCollection.java:414)

at java.lang.String.valueOf(String.java:2826)

at java.lang.StringBuilder.append(StringBuilder.java:115)

at com.wolf.pojo.oneToone.UserClass.toString(UserClass.java:109)

at java.lang.String.valueOf(String.java:2826)

at java.lang.StringBuilder.append(StringBuilder.java:115)

at com.wolf.pojo.oneToone.UserT.toString(UserT.java:108)

at java.lang.String.valueOf(String.java:2826)

at java.lang.StringBuilder.append(StringBuilder.java:115)

at java.util.AbstractCollection.toString(AbstractCollection.java:422)

at java.lang.String.valueOf(String.java:2826)

at java.lang.StringBuilder.append(StringBuilder.java:115)

at com.wolf.pojo.oneToone.UserClass.toString(UserClass.java:109)

最后解决方案是:java-hashCode内部实现直接循环自己的hashCode方法,测试进入死循环,一直出现错误

解决方案:

1、删除hashCode的方法

2、在使用的bean类中set不要实例化,在使用的时候临时创建set集合,然后再存放到pojo对象所以引用的集合中

3、这是javaAPI中说的异常结论:

public class StackOverflowError

Thrown when a stack overflow occurs because an application recurses too deeply. (堆栈溢出发生时抛出一个应用程序是递归因为太深。)

下面是其他朋友的测试地址:

如果有哪位高手知道这个错误的解决方案,还请多多指教



推荐阅读
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 本文介绍了解决Netty拆包粘包问题的一种方法——使用特殊结束符。在通讯过程中,客户端和服务器协商定义一个特殊的分隔符号,只要没有发送分隔符号,就代表一条数据没有结束。文章还提供了服务端的示例代码。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文介绍了一个Java猜拳小游戏的代码,通过使用Scanner类获取用户输入的拳的数字,并随机生成计算机的拳,然后判断胜负。该游戏可以选择剪刀、石头、布三种拳,通过比较两者的拳来决定胜负。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 关键词:Golang, Cookie, 跟踪位置, net/http/cookiejar, package main, golang.org/x/net/publicsuffix, io/ioutil, log, net/http, net/http/cookiejar ... [详细]
  • Android开发实现的计时器功能示例
    本文分享了Android开发实现的计时器功能示例,包括效果图、布局和按钮的使用。通过使用Chronometer控件,可以实现计时器功能。该示例适用于Android平台,供开发者参考。 ... [详细]
  • Go GUIlxn/walk 学习3.菜单栏和工具栏的具体实现
    本文介绍了使用Go语言的GUI库lxn/walk实现菜单栏和工具栏的具体方法,包括消息窗口的产生、文件放置动作响应和提示框的应用。部分代码来自上一篇博客和lxn/walk官方示例。文章提供了学习GUI开发的实际案例和代码示例。 ... [详细]
  • Go Cobra命令行工具入门教程
    本文介绍了Go语言实现的命令行工具Cobra的基本概念、安装方法和入门实践。Cobra被广泛应用于各种项目中,如Kubernetes、Hugo和Github CLI等。通过使用Cobra,我们可以快速创建命令行工具,适用于写测试脚本和各种服务的Admin CLI。文章还通过一个简单的demo演示了Cobra的使用方法。 ... [详细]
  • Java自带的观察者模式及实现方法详解
    本文介绍了Java自带的观察者模式,包括Observer和Observable对象的定义和使用方法。通过添加观察者和设置内部标志位,当被观察者中的事件发生变化时,通知观察者对象并执行相应的操作。实现观察者模式非常简单,只需继承Observable类和实现Observer接口即可。详情请参考Java官方api文档。 ... [详细]
  • Spring学习(4):Spring管理对象之间的关联关系
    本文是关于Spring学习的第四篇文章,讲述了Spring框架中管理对象之间的关联关系。文章介绍了MessageService类和MessagePrinter类的实现,并解释了它们之间的关联关系。通过学习本文,读者可以了解Spring框架中对象之间的关联关系的概念和实现方式。 ... [详细]
  • 数组的排序:数组本身有Arrays类中的sort()方法,这里写几种常见的排序方法。(1)冒泡排序法publicstaticvoidmain(String[]args ... [详细]
author-avatar
longxi
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有