What is the difference between an int and an Integer in Java and C#?
我在软件上阅读了更多关于乔尔的文章,当我遇到Joel Spolsky时,他谈到了一个特定类型的程序员,他知道EDCOX1 0和爪哇中的EDCX1 1之间的区别(面向对象的编程语言)。
那么,有什么区别呢?
在Java中,"int"类型是一个原语,而"整数"类型是一个对象。
在C++中,"int"类型与EDCOX1(0)相同,是一种值类型(更类似于Java‘int’)。整数(就像任何其他值类型一样)可以装箱("包装")到对象中。
对象和原语之间的差异在一定程度上超出了这个问题的范围,但要总结一下:
对象提供多态性的工具,通过引用传递(或者更准确地说,通过值传递引用),并从堆中分配。相反,基元是通过值传递的不可变类型,通常从堆栈中分配。
在Java中,int是一个本原,而整数是一个对象。也就是说,如果您生成了一个新的整数:
1 |
你可以在i上调用一些方法:
1 | String s = i.toString();//sets s the string representation of i |
鉴于,对于int:
1 | int i = 6; |
不能对它调用任何方法,因为它只是一个原语。所以:
1 | String s = i.toString();//will not work!!! |
会产生错误,因为int不是对象。
INT是Java中的少数原语之一(连同char和其他一些)。我不是100%确定,但我认为整数对象或多或少有一个int属性和一组与该属性交互的方法(例如toString()方法)。所以整数是一种处理int的奇特方法(就像字符串是处理一组char的奇特方法一样)。
我知道Java不是C,但是因为我从来没有用C编程,这是我最接近的答案。希望这有帮助!
整数对象javadoc
整数ojbect与int原语比较
我将添加上面给出的优秀答案,并讨论拳击和解题,以及如何应用于Java(尽管C语言也有)。我只会使用Java术语,因为我对此更感兴趣。
正如前面提到的答案,
Java 5有一种叫做自动装箱和自动解包的东西,它允许在后台进行装箱/拆箱。比较和对比:Java 5版本:
1 2 3 4 5 6 7 8 9 | Deque<Integer> queue; void add(int n) { queue.add(n); } int remove() { return queue.remove(); } |
Java 1.4或更早版本(无泛型):
1 2 3 4 5 6 7 8 9 | Deque queue; void add(int n) { queue.add(Integer.valueOf(n)); } int remove() { return ((Integer) queue.remove()).intValue(); } |
必须注意的是,尽管Java 5版本中的简洁性,两个版本都生成相同的字节码。因此,虽然自动装箱和自动拆箱非常方便,因为您编写的代码较少,但这些操作确实是在后台进行的,运行时成本相同,因此您仍然必须了解它们的存在。
希望这有帮助!
我只会在这里发帖,因为其他一些帖子在C方面有点不准确。
正确:
错:
基本上,int是C编程语言中的保留关键字,是
但是,float和float不同,因为"
在c中,"EDOCX1"(0)和"EDOCX1"(1)或任何其他对或关键字/系统类型之间没有区别,定义枚举时除外。使用枚举可以指定要使用的存储大小,在这种情况下,只能使用保留关键字,而不能使用系统运行时类型名称。
int中的值将存储在堆栈、内存中,还是作为引用的堆对象存储,这取决于上下文和您如何使用它。
方法中的此声明:
1 | int i; |
定义一个类型为
要获取堆对象,可以使用装箱:
1 | object o = i; |
这将在堆上创建
关于Java 1.5和自动装箱,当比较整数对象时,有一个重要的"奇特"。
在爪哇中,值为128到127的整数对象是不可变的(也就是说,对于一个特定的整数值,如23,所有整数对象通过程序实例化,值23点到完全相同的对象)。
例如,这将返回true:
1 2 3 |
当返回false时:
1 2 3 |
==参照比较(变量是否指向同一对象)。
根据您使用的是什么JVM,这个结果可能不同,也可能不同。Java 1.5的规范自动装箱要求整数(-128到127)总是对同一包装对象进行装箱。
解决方案?=)比较整数对象时,应始终使用integer.equals()方法。
1 | System.out.println(i1.equals(i2)); // true |
更多信息请访问java.net示例:bexhuff.com
在Java中,JVM中有两种基本类型。1)基元类型和2)引用类型。int是基元类型,integer是类类型(这是一种引用类型)。
基元值不与其他基元值共享状态。类型为基元类型的变量始终保存该类型的基元值。
1 2 3 4 | int aNumber = 4; int anotherNum = aNumber; aNumber += 6; System.out.println(anotherNum); // Prints 4 |
对象是动态创建的类实例或数组。引用值(通常只是引用)是指向这些对象的指针,以及一个特殊的空引用,它不引用任何对象。可能有许多对同一对象的引用。
1 2 3 | Integer aNumber = Integer.valueOf(4); Integer anotherNumber = aNumber; // anotherNumber references the // same object as aNumber |
同样在Java中,所有的东西都是通过值传递的。对于对象,传递的值是对对象的引用。因此,在Java中int和整数之间的另一个区别是它们如何在方法调用中传递。例如在
1 2 3 4 5 | public int add(int a, int b) { return a + b; } final int two = 2; int sum = add(1, two); |
变量2作为基元整数类型2传递。而在
1 2 3 4 5 | public int add(Integer a, Integer b) { return a.intValue() + b.intValue(); } final Integer two = Integer.valueOf(2); int sum = add(Integer.valueOf(1), two); |
变量2作为对保存整数值2的对象的引用传递。
@ WolfmanDragon:传递引用的工作方式如下:
1 2 3 4 5 6 | public void increment(int x) { x = x + 1; } int a = 1; increment(a); // a is now 2 |
当调用increment时,它将一个引用(指针)传递给变量A。increment函数直接修改变量A。
对于对象类型,它的工作方式如下:
1 2 3 4 5 6 | public void increment(Integer x) { x = Integer.valueOf(x.intValue() + 1); } Integer a = Integer.valueOf(1); increment(a); // a is now 2 |
你现在看到区别了吗?
在c_中,int只是
就我个人而言,我更喜欢int、string、double等,因为它们不需要
使用包装类有很多原因:
int用于声明基元变量
1 | e.g. int i=10; |
integer用于创建类integer的引用变量
1 |
Java已经回答了这个问题,这里是C的答案:
"integer"不是C中的有效类型名,"int"只是System.Int32的别名。此外,与Java(或C++)不同,C语言中没有任何特殊的基元类型,C类型(包括int)中的每一个实例都是一个对象。下面是一些演示代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | void DoStuff() { System.Console.WriteLine( SomeMethod((int)5) ); System.Console.WriteLine( GetTypeName<int>() ); } string SomeMethod(object someParameter) { return string.Format("Some text {0}", someParameter.ToString()); } string GetTypeName<T>() { return (typeof (T)).FullName; } |
在像Java这样的平台中,EDCOX1×0的S是基元,而EDCOX1×1是一个包含整数字段的对象。重要的区别是,原语总是按值传递,按定义传递是不可变的。
任何涉及基元变量的操作总是返回一个新值。另一方面,对象是通过引用传递的。有人可能认为指向对象的点(也就是引用)也是通过值传递的,但内容不是。
还有一件事我在之前的回答中没有看到:在Java中,原始包装类如整数、双、浮点、布尔…字符串被认为是不变的,因此当您传递这些类的一个实例时,被调用的方法不能以任何方式改变您的数据,在opositi_n中,与大多数其他类一起,这些类的内部数据可以被其公共方法改变。这样,除了构造函数之外,这个类只有"getter"方法,没有"setters"。
在Java程序中,字符串文本存储在堆内存的单独部分中,仅用于文本的实例,以保存内存重用这些实例。
你以前编程过吗(int)是你可以为变量设置的基本类型之一(就像char,float,…)。
但是integer是一个包装类,您可以使用它对int变量执行一些函数(例如,将它转换为字符串或反之亦然),但是请注意,包装类中的方法是静态的,因此您可以随时使用它们,而不必创建integer类的实例。作为一个综述:
1 2 | int x; Integer y; |
x和y都是int类型的变量,但是y被一个整型类包装,并且有几个方法可以使用,但是我想您需要调用整型包装类的一些函数,您可以简单地做到这一点。
1 | Integer.toString(x); |
但是请注意,x和y都是corect类型,但是如果您想将它们用作基本类型,请使用简单形式(用于定义x)。
Java语言:
用JAVA JDK 5开始,包括两个非常有特点:自动装箱和autounboxing helpful。自动装箱/拆箱和streamlines是大大simplifies代码必须转换为原始类型的对象,和反之亦然。
例子:构造函数
1 2 3 4 | Integer(int num) Integer(String str) throws NumberFormatException Double(double num) Double(String str) throws NumberFormatException |
例子:装箱/拆箱
1 2 3 4 5 6 7 | class ManualBoxing { public static void main(String args[]) { Integer objInt = new Integer(20); // Manually box the value 20. int i = objInt.intValue(); // Manually unbox the value 20 System.out.println(i +"" + iOb); // displays 20 20 } } |
例子:自动装箱/ autounboxing
1 2 3 4 5 6 7 | class AutoBoxing { public static void main(String args[]) { Integer objInt = 40; // autobox an int int i = objInt ; // auto-unbox System.out.println(i +"" + iOb); // displays 40 40 } } |
赫伯特:schildt’s Book是考虑的参考。
爪哇和C中的int和整数是用来表示不同事物的两个不同的术语。它是可以分配给可以精确存储的变量的基本数据类型之一。一次声明类型的一个值。
例如:
1 | int number = 7; |
其中,
而
例如:
1 |
int变量保存一个32位有符号整数值。整数(大写I)包含对(类)类型整数或空的对象的引用。
Java自动在两个之间进行转换;每当整数对象作为int参数出现或被分配给int变量时,从整数到int,或者int值被赋给整型变量。这种铸造称为装箱/拆箱。
如果引用空值的整数变量未绑定、显式或隐式,则会引发NullPointerException。
在Java中,
在C型#,
在两种语言中(Java和C语言)
与Java不同,C语言提供了有符号和无符号整数值。由于Java和C语言是面向对象的,所以这些语言中的某些操作不直接映射到运行时提供的指令,因此需要定义为某种类型的对象的一部分。
C提供
Java提供了EDCOX1×2的引用,这是一个在EDCOX1(0)中运行的引用类型。由于
在c variable int中,变量int指的是内存中的
Java INT是一种原始数据类型,而整数是辅助类,它用于将一种数据类型转换为其他类型。
例如:
1 2 3 4 | double doubleValue = 156.5d; Double doubleObject = new Double(doubleValue); Byte myByteValue = doubleObject.byteValue (); String myStringValue = doubleObject.toString(); |
原始数据类型存储最快的可用内存,其中helper类比较复杂,并存储在heep内存中。
参考"David Gassner"Java基本训练。
这些库函数C是在
是"国际"和"原始数据类型包装类的整数中的"Java"。"可以用一个整数参数的方法,对面向对象的要求,在"int"可以用来对这一问题的方法,需要的是整型值,可以使用算术表达式。
01。整数可以为空。但不能为空。
1 2 3 | Integer value1 = null; //OK int value2 = null //Error |
02。的CAN型封装类,仅通值的任何集合类。
(包装班-布尔,字节,字符,整数,长,短,浮点,双)
1 2 3 4 |
但我们通常添加到原始值的集合类?02点是正确的吗?
1 2 |
02是一
Autoboxing is the automatic conversion that the java compiler makes
between the primitive type and their corresponding wrapper class.
然后转换成整数的值由5自动装箱。
java学习的知识,如果你按我的来,然后当你写一个Java类,它将编译码
(JAVA版)在简单的话,是原始的int是整数int对象和包装它。
在一个例子使用的整数与int,int当你想比较一变空,它将距离误差。
1 2 3 4 5 6 7 8 9 10 11 | int a; //assuming a value you are getting from data base which is null if(a ==null) // this is wrong - cannot compare primitive to null { do something...} Instead you will use, Integer a; //assuming a value you are getting from data base which is null if(a ==null) // this is correct/legal { do something...} |