在java开发中,简述set里的元素是不能重复的,那么用什么方法来区分重复与否呢? 是用==还是equals()? 它们有何区别 ?


在Java中,`Set`是一个不允许存储重复元素的集合。它主要通过`equals()`方法来判断元素是否重复。 在比较对象时,`==`和`equals()`这两个方法的主要区别在于: * `==`:这是Java中的基本比较操作符,用来比较两个对象的引用是否相同。如果两个对象引用的是内存中的同一位置,则`==`返回`true`。也就是说,`==`比较的是两个对象的内存地址,而不是它们的内容。 * `equals()`:这是Object类中的一个方法,所有的类都从Object类继承了这个方法。默认情况下,`equals()`方法的行为和`==`操作符是一样的,也是比较两个对象的引用。许多类(包括集合类,比如`Set`、`Map`等)重写了这个方法,让它比较的是对象的内容而不是引用。 对于`Set`来说,它使用`equals()`方法来判断两个元素是否相等。这就意味着,只要你通过`add()`方法成功添加了一个元素到`Set`,那么你再试图添加一个与这个元素内容完全相同(通过`equals()`判断)的元素时,`add()`方法会返回`false`,表示这个元素并没有被成功添加到`Set`中。 如果你需要判断两个对象的内容是否相同,你应该使用`equals()`方法;如果你需要判断两个对象是否指向内存中的同一位置,你应该使用`==`操作符。 [2023-11-09 16:38:52 | AI小红书种草文 | 305点数解答]
相关提问
- import javax.swing.*; import java.awt.*; import java.awt.datatransfer.clipboard; import java.awt.datatransfer.stringselection; import java.awt.datatransfer.transferable; import java.awt.event.*; import java.io.*; import java.nio.file.files; import java.nio.file.path; import java.nio.file.paths; import java.time.localdatetime; import java.util.hashmap; import java.util.list; import java.util.map; import java.util.random; public class copy { static private final jtextarea textarea = new jtext(1497点数解答 | 2024-08-25 09:40:33)325
- dm.jdbc.driver.dmexception: 数据溢出 at dm.jdbc.driver.dberror.throwexception(dberror.java:636) at dm.jdbc.c.b.p.s(msg.java:225) at dm.jdbc.c.b.p.p(msg.java:185) at dm.jdbc.c.b.p.o(msg.java:166) at dm.jdbc.c.a.a(dbaccess.java:776) at dm.jdbc.c.a.a(dbaccess.java:327) at dm.jdbc.c.a.a(dbaccess.java:435) at dm.jdbc.driver.dmdbpreparedstatement.executeinner(dmdbpreparedstatement.java:284) at dm.jdbc.driver.dmdbpreparedstatement.do_executequery(dmdbpreparedstatement.java:383) at dm.jdbc.driver.(598点数解答 | 2024-10-15 15:48:38)227
- 问题排查:dm.jdbc.driver.dmexception: 数据溢出 at dm.jdbc.driver.dberror.throwexception(dberror.java:636) at dm.jdbc.c.b.p.s(msg.java:225) at dm.jdbc.c.b.p.p(msg.java:185) at dm.jdbc.c.b.p.o(msg.java:166) at dm.jdbc.c.a.a(dbaccess.java:776) at dm.jdbc.c.a.a(dbaccess.java:327) at dm.jdbc.c.a.a(dbaccess.java:435) at dm.jdbc.driver.dmdbpreparedstatement.executeinner(dmdbpreparedstatement.java:284) at dm.jdbc.driver.dmdbpreparedstatement.do_executequery(dmdbpreparedstatement.java:383) at dm.jdbc.dr(403点数解答 | 2024-10-15 15:48:41)920
- 作为c#工程师,set⾥的元素是不能重复的,那么⽤什么⽅法来区分重复与否呢? 是⽤==还是equals()? 它们有 何区别?(305点数解答 | 2023-11-09 17:55:21)265
- 作为javascript开发,简述 jquery中 $ .get()提交和$.post()区别 ?(341点数解答 | 2023-11-09 01:15:01)227
- use [smarttagsystem] go /****** object: storedprocedure [dbo].[pr_createdtables] script date: 2024/8/29 星期四 15:33:01 ******/ set ansi_nulls on go set quoted_identifier on go alter procedure [dbo].[pr_createdtables] @table_name_sign varchar(50) --课程标识 as declare @sql_answer nvarchar(max) --答案表创建sql declare @sql_classify nvarchar(max) --章节考点表 declare @sql_exam nvarchar(max)--试卷表 declare @sql_problem nvarchar(max)--题目表 declare @sql_problemtype nvarchar(max)--题目类型表 set @sql_an(33点数解答 | 2024-08-29 15:34:33)251
- create table `py_plan_opportunity_point` ( `id` bigint not null auto_increment comment '主键id', `location_code` varchar(32) character set utf8mb4 collate utf8mb4_0900_ai_ci not null comment '规划点/机会点编码', `location_name` varchar(20) character set utf8mb4 collate utf8mb4_0900_ai_ci default null comment '规划点名称', `point_type` char(2) character set utf8mb4 collate utf8mb4_0900_ai_ci default null comment '点类型(1:规划点/2:机会点)', primary key (`id`) using **ree, key `py_plan_opportunity_point_uniq(328点数解答 | 2024-09-04 16:07:48)240
- create table `py_plan_opportunity_point` ( `id` bigint not null auto_increment comment '主键id', `location_code` varchar(32) character set utf8mb4 collate utf8mb4_0900_ai_ci not null comment '规划点/机会点编码', `location_name` varchar(20) character set utf8mb4 collate utf8mb4_0900_ai_ci default null comment '规划点名称', `point_type` char(2) character set utf8mb4 collate utf8mb4_0900_ai_ci default null comment '点类型(1:规划点/2:机会点)', primary key (`id`), unique key `py_plan_opportunity_point_uniq` (`location_code(188点数解答 | 2024-09-04 16:08:40)361
- create table `py_plan_opportunity_point` ( `id` bigint not null auto_increment comment '主键id', `location_code` varchar(32) character set utf8mb4 collate utf8mb4_0900_ai_ci not null comment '规划点/机会点编码', `location_name` varchar(20) character set utf8mb4 collate utf8mb4_0900_ai_ci default null comment '规划点名称', `point_type` char(2) character set utf8mb4 collate utf8mb4_0900_ai_ci default null comment '点类型(1:规划点/2:机会点)', primary key (`id`), unique key `py_plan_opportunity_point_uniq` (`location_code`(348点数解答 | 2024-09-04 16:09:36)205
- if (@code2 like 'item_ch_' + @itemcodeprefix + '_a_rare' and @optlevel >= 1 - @ck and @cl1 = 24670 and @cl2 = 24669 and @clsl1 > 1 and @clsl2 > 1) begin select @charname = charname16 from _char where charid = @charid; update _inventory set itemid=0 where charid=@charid and slot=13 update sro_vt_shard.._items set data=data-1 where id64 in (select itemid from sro_vt_shard.._inventory where slot=14and charid=@charid) update sro_vt_shard.._items set data=data-1 where id64 in ((51点数解答 | 2024-10-22 11:24:35)207
- if (@code2 like 'item_ch_' + @itemcodeprefix + '_a_rare' and @optlevel >= 1 - @ck and @cl1 = 24670 and @cl2 = 24669 and @clsl1 > 1 and @clsl2 > 1) begin select @charname = charname16 from _char where charid = @charid; update _inventory set itemid=0 where charid=@charid and slot=13 update sro_vt_shard.._items set data=data-1 where id64 in (select itemid from sro_vt_shard.._inventory where slot=14and charid=@charid) update sro_vt_shard.._items set data=data-1 where id64 in (select itemid from sro_(969点数解答 | 2024-10-22 11:26:02)262
- 作为c#工程师,整数list中取出最⼤数(找最⼤值)不能⽤max⽅法?(448点数解答 | 2023-11-09 17:55:36)281