对于在Python中通过引用传递整数感兴趣的读者,本文将会是一篇不错的选择,我们将详细介绍在python中通过引用传递整数的方法,并为您提供关于c–voidfoo(int&x)–>Ruby?通过
对于在Python中通过引用传递整数感兴趣的读者,本文将会是一篇不错的选择,我们将详细介绍在python中通过引用传递整数的方法,并为您提供关于c – void foo(int&x) – > Ruby?通过引用传递整数?、Java怀疑中通过引用传递、PHP在foreach中通过引用传递、Python中如何通过引用传递变量?的有用信息。
本文目录一览:- 在Python中通过引用传递整数(在python中通过引用传递整数的方法)
- c – void foo(int&x) – > Ruby?通过引用传递整数?
- Java怀疑中通过引用传递
- PHP在foreach中通过引用传递
- Python中如何通过引用传递变量?
在Python中通过引用传递整数(在python中通过引用传递整数的方法)
如何在Python中通过引用传递整数?
我想修改传递给函数的变量的值。我读过Python中的所有内容都是按值传递的,但是必须有一个简单的技巧。例如,在Java中,你可以通过引用类型的Integer
,Long
等等。
- 如何通过引用将整数传递给函数?
- 最佳做法是什么?
答案1
小编典典在Python中,这种方式不太有效。Python将引用传递给对象。在函数内部,你有一个对象-你可以随意更改该对象(如果可能)。但是,整数是不可变的。一种解决方法是在可以更改的容器中传递整数:
def change(x): x[0] = 3x = [1]change(x)print x
这充其量是丑陋的/笨拙的,但是你不会在Python中做得更好。原因是因为在Python中,赋值(=)
接收右侧对象结果的任何对象,并将其绑定到左侧对象*(或将其传递给适当的函数)。
理解了这一点,我们可以看到为什么无法更改函数内部不可变对象的值的原因-你不能更改其任何属性,因为它是不可变的,并且你不能仅给新的“变量”赋值值,因为你实际上是在创建一个新对象(与旧对象不同),并为其赋予旧对象在本地名称空间中的名称。
通常,解决方法是简单地返回所需的对象:
def multiply_by_2(x): return 2*xx = 1x = multiply_by_2(x)
*在上述第一个示例中,3实际上传递给x.setitem。
c – void foo(int&x) – > Ruby?通过引用传递整数?
作为一种为我的C编程作业增添趣味的一种方式,我决定不用将书中的C键输入我的计算机,而是将其改为Ruby.是的,这有点傻,但我很无聊.
无论如何,我在将这种功能转换为Ruby时遇到了麻烦
void swap(int &a,int &b){
int c=b;
b=a;
a=c
}
函数中等效的ruby代码是什么?
解决方法:
Ruby是严格按值传递的.总是.但有时候这些价值观就是那些价值观.
这里有几个链接:
> Java is Pass-by-Value, Dammit! (Scott “JavaDude” Stanchfield)
> Parameter passing in Java (Jon Skeet)
> Does Java pass by reference?
> Java, pass-by-value, reference variables
请注意,虽然所有这些都说“Java”,但他们应该说“Smalltalk及其后代”,其中包括Java,Ruby和许多其他语言.
我认为大多数混乱源于两个问题:
> Ruby按值传递引用.但该句中的“引用”一词与“引用引用”中的“引用”一词并不相同.当我们消除歧义时,可能更清楚:让我们将“传递参考”替换为“传递变量”和“参考”替换为“指针”(注意这些是“好的”表现良好的指针,而不是“坏” “来自C的人):
> Fortran是按变量传递的
> Ruby是按值传递的,它传递的值主要是poointers
> Ruby传递的引用(poointers)指向可变对象.因此,虽然您无法更改引用,但可以改变引用指向的对象.这里的问题是Ruby(像大多数命令式面向对象语言一样)混淆了身份,状态和价值的概念.您可以在此处了解有关该问题以及如何解决此问题的更多信息(请注意,虽然他们说“Clojure”,但所呈现的概念是通用的,并且可以同样适用于OO):
> Persistent Data Structures and Managed References – Clojure’s Approach to Identity and State – Rich Hickey – QCon London 2009
> Are We There Yet? – A deconstruction of object-oriented time – Rich Hickey – JVM Language Summit
顺便说一句:我故意用面向对象的OO拼错“poointers”以明确我不是在谈论原始内存地址,我说的是对对象的不透明引用(并且出于显而易见的原因我不想使用这个词“参考”;如果你知道一个更好的词既不是“指针”也不是“参考”,我很乐意听到它.
Java怀疑中通过引用传递
因此,我正在阅读这篇文章,并没有回复。2.在该示例中,调用该方法后,地址42处的Dog值是否更改为Max?
Dog myDog;
Dog myDog = new Dog("Rover");
foo(myDog);
public void foo(Dog someDog) {
someDog.setName("Max"); // AAA
someDog = new Dog("Fifi"); // BBB
someDog.setName("Rowlf"); // CCC
}
PHP在foreach中通过引用传递
我有以下代码:
$a = array ('zero','one','two','three');
foreach ($a as &$v) {
}
foreach ($a as $v) {
echo $v.PHP_EOL;
}
有人可以解释为什么输出是:零一二二。
摘自zend认证学习指南。
Python中如何通过引用传递变量?
如何解决Python中如何通过引用传递变量??
- 传入的参数实际上是对对象的引用(但引用是通过值传递的)
-
有些数据类型是可变的,但有些则不是 所以:
-
如果将可变对象传递给方法,则该方法将获得对该对象的引用,并且可以对其进行突变,但是如果您将该引用重新绑定到该方法中,则外部作用域对此一无所知完成后,外部参考仍将指向原始对象。
-
如果将不可变对象传递给方法,则仍然无法重新绑定外部引用,甚至无法使对象发生突变。
为了更加清楚,让我们举一些例子。
列表-可变类型
让我们尝试修改传递给方法的列表:
def try_to_change_list_contents(the_list):
print(''got'', the_list)
the_list.append(''four'')
print(''changed to'', the_list)
outer_list = [''one'', ''two'', ''three'']
print(''before, outer_list ='', outer_list)
try_to_change_list_contents(outer_list)
print(''after, outer_list ='', outer_list)
输出:
before, outer_list = [''one'', ''two'', ''three'']
got [''one'', ''two'', ''three'']
changed to [''one'', ''two'', ''three'', ''four'']
after, outer_list = [''one'', ''two'', ''three'', ''four'']
由于传入的参数是对的引用outer_list,而不是其副本,因此我们可以使用变异列表方法对其进行更改,并使更改反映在外部作用域中。
现在让我们看看当尝试更改作为参数传入的引用时会发生什么:
def try_to_change_list_reference(the_list):
print(''got'', the_list)
the_list = [''and'', ''we'', ''can'', ''not'', ''lie'']
print(''set to'', the_list)
outer_list = [''we'', ''like'', ''proper'', ''English'']
print(''before, outer_list ='', outer_list)
try_to_change_list_reference(outer_list)
print(''after, outer_list ='', outer_list)
输出:
before, outer_list = [''we'', ''like'', ''proper'', ''English'']
got [''we'', ''like'', ''proper'', ''English'']
set to [''and'', ''we'', ''can'', ''not'', ''lie'']
after, outer_list = [''we'', ''like'', ''proper'', ''English'']
由于the_list
参数是通过值传递的,因此为其分配新列表不会影响方法外部的代码。该the_list
是副本outer_list
的参考,我们不得不the_list指向一个新的列表,但没有办法改变,其中outer_list
尖。
字符串-不可变的类型
它是不可变的,因此我们无能为力,无法更改字符串的内容
现在,让我们尝试更改参考
def try_to_change_string_reference(the_string):
print(''got'', the_string)
the_string = ''In a kingdom by the sea''
print(''set to'', the_string)
outer_string = ''It was many and many a year ago''
print(''before, outer_string ='', outer_string)
try_to_change_string_reference(outer_string)
print(''after, outer_string ='', outer_string)
输出:
before, outer_string = It was many and many a year ago
got It was many and many a year ago
set to In a kingdom by the sea
after, outer_string = It was many and many a year ago
同样,由于the_string
参数是通过值传递的,因此为其分配新的字符串不会影响方法外部的代码。该the_string
是副本outer_string
的参考,我们不得不the_string
指向一个新的字符串,但没有办法改变,其中outer_string
尖。
我希望这可以使事情变得简单。
编辑:注意到这并不能回答@David最初问的问题,“我可以做些什么来通过实际引用传递变量吗?”。让我们继续努力。
我们如何解决这个问题?
如@Andrea的答案所示,您可以返回新值。这不会改变事物传递的方式,但是可以让您获得想要的信息:
def return_a_whole_new_string(the_string):
new_string = something_to_do_with_the_old_string(the_string)
return new_string
# then you Could call it like
my_string = return_a_whole_new_string(my_string)
如果您确实想避免使用返回值,则可以创建一个类来保存您的值,并将其传递给函数或使用现有的类,例如列表:
def use_a_wrapper_to_simulate_pass_by_reference(stuff_to_change):
new_string = something_to_do_with_the_old_string(stuff_to_change[0])
stuff_to_change[0] = new_string
# then you Could call it like
wrapper = [my_string]
use_a_wrapper_to_simulate_pass_by_reference(wrapper)
do_something_with(wrapper[0])
尽管这看起来有点麻烦。
解决方法
Python文档似乎尚不清楚参数是通过引用还是通过值传递,并且以下代码会产生未更改的值“原始”
class PassByReference:
def __init__(self):
self.variable = ''Original''
self.change(self.variable)
print(self.variable)
def change(self,var):
var = ''Changed''
我可以做些什么来通过实际引用传递变量吗?
我们今天的关于在Python中通过引用传递整数和在python中通过引用传递整数的方法的分享就到这里,谢谢您的阅读,如果想了解更多关于c – void foo(int&x) – > Ruby?通过引用传递整数?、Java怀疑中通过引用传递、PHP在foreach中通过引用传递、Python中如何通过引用传递变量?的相关信息,可以在本站进行搜索。
本文标签: