- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在编写一个新的扩展类型,但我在设置数字运算(例如加法/减法/乘法)时遇到了问题。我已经设法设置了一些就地操作,而没有调用正常操作。
例如,我有这个功能:
static PyObject *
MyType_Mul(PyObject *v, PyObject *w)
{
PyErr_SetString(PyExc_ValueError, "testing");
return NULL;
}
然后我将其设置为这样的数字方法:
static PyNumberMethods my_type_as_number = {
0, /* nb_add */
0, /* nb_sub */
(binaryfunc)MyType_Mul, /* nb_mul */
...
0, /* nb_in_place_add */
0, /* nb_in_place_sub */
(binaryfunc)MyType_Mul, /* nb_in_place_mul */
...
};
现在,当我尝试使用我的类型时,我得到了这种行为:
>>> from mytype import MyType
>>> a = MyType()
>>> a * 2
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: unsupported operand type(s) for *: 'mytype.MyType' and 'int'
>>> 2 * a
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: unsupported operand type(s) for *: 'int' and 'mytype.MyType'
但是如果我使用就地运算符:
>>> a *= 2
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: testing
如果我在对象上使用 dir()
,我可以看到 __mul__
和 __rmul__
方法(这意味着 python 可以看到它们),但似乎他们根本没有被召唤。使用 a.__mul__(2)
返回 NotImplemented
。
还有:
>>> a.__mul__
<method-wrapper '__mul__' of mytype.MyType object at 0x7fc2ecc50468>
>>> a.__imul__
<method-wrapper '__imul__' of mytype.MyType object at 0x7fc2ecc50468>
所以,如您所见,它们完全是同一回事。
这是怎么回事?为什么同样的功能适用于就地运算符而不适用于“普通”运算符?我也想过我可能使用了错误的插槽,但我仔细检查它是正确的,并且将它设置为 nb_add
,nb_sub
等也不起作用。
最佳答案
多亏了 nneonneo 的评论,我明白了哪里出了问题。基本上我忘了设置 Py_TPFLAGS_CHECKTYPES
旗帜。
在我给出的描述中有一些关于这种缺失的线索:
a*a
会产生正确的结果,而执行 a*different-type
则不会。<这显然意味着解释器在执行非就地操作时正在检查参数的类型,如果类型是 MyType
则调用我的函数,否则返回 NotImplemented
.
在文档中稍微搜索一下,很容易看出这是数字方法的默认行为。
如果参数类型不是同一个类,则假定操作未实现。
要允许不同类型一起“操作”,您必须在 MyType
中设置 Py_TPFLAGS_CHECKTYPES
标志:
static PyTypeObject MyType = {
PyObject_HEAD_INIT(&PyType_Type)
0, /*ob_size*/
"mytype.MyType", /*tp_name*/
sizeof(MyTypeObject), /*tp_basicsize*/
0, /*tp_itemsize*/
...
0, /*tp_repr*/
&mytype_as_number, /*tp_as_number*/
0, /*tp_as_sequence*/
...
Py_TPFLAGS_DEFAULT | Py_TPFLAGS_CHECKTYPES,/*tp_flags*/
...
};
设置此标志后,解释器将不会检查类型,因此您必须手动处理它们。
相反,就地运算符总是允许不同的类型。为什么会这样,我不知道。
关于python - 实现数字方法总是返回 NotImplemented,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12447462/
我有以下功能: def __eq__(self, other: object) -> Union[bool, NotImplemented]: try:
我正在编写一个新的扩展类型,但我在设置数字运算(例如加法/减法/乘法)时遇到了问题。我已经设法设置了一些就地操作,而没有调用正常操作。 例如,我有这个功能: static PyObject * MyT
查看decimal.py,它在很多特殊的方法中使用了NotImplemented。例如 class A(object): def __lt__(self, a): return
我正在尝试使用 HippoMock 模拟接口(interface),以便在使用所述接口(interface)的类中使用。我构建了一个模拟对象并设置了 ExceptCallOverload,一切都可以正
我有一个用于一些插件式东西的基类,并且有一些方法是绝对需要实现的。 例如,我目前将基类中的那些声明为虚拟的 public virtual void Save { throw new NotIm
Python 有一个名为 NotImplemented 的单例。 . 为什么有人想要返回 NotImplemented 而不是引发 NotImplementedError异常(exception)?这
假设我定义了一个类 A 并且我不希望任何人在不逃避的情况下编写该类的不等式。 class A(): def __ne__(self, other): return NotImp
我最近偶然发现了 Python 的 NotImplemented 内置函数。经过一些阅读后,我现在确实明白了它的目的,但我不明白为什么它会评估为 True 作为 bool 值。下面的例子让我觉得这是一
从 python 3 中的 __eq__ 特殊方法返回 NotImplemented 的结果是什么(如果重要,则为 3.5)? 文档不清晰; only relevant text I found仅含糊
不要把苹果和橙子混在一起 问题 我正在使用 __eq__ 运算符和 NotImplemented 值。 我试图了解当 obj1.__eq__(obj2) 返回 NotImplemented 并且 ob
Python 有一个名为 NotImplemented 的单例。 . 为什么有人想要返回 NotImplemented 而不是提高 NotImplementedError异常(exception)?会
我正在使用我知道可以工作的存储帐户和帐户 key /信用:我有一个使用完全相同的连接字符串的 blob 容器,可以正常工作。 我正在有效地这样做: CloudStorageAccount.Parse(
为了回答另一个问题,我一直在研究 pandas 中的列乘法运算。 A = pd.DataFrame({'Col1' : [1, 2, 3], 'Col2' : [2, 3, 4]}) B = pd.D
我惊讶地发现 python(版本 3.2.2)拒绝 pickle 一个对象,因为它的字典包含对 Ellipsis 的引用。其他built-in constants , pickle 很高兴与 Fals
我正在尝试让一个非常简单的 Scrapy 爬虫工作。我从解析中收到 NotImplemented 错误 - 本质上与此相同的问题:Why does scrapy throw an error for
我有一个代数对象的类层次结构,它实现了特殊方法,例如 __mul__ 和 __add__ ,并使用多重继承。我以某种方式假设 Python (>= 3.5) 会遍历方法解析顺序 (mro) 来查找第一
这个问题是从 this question 的回答和讨论中提出来的.以下片段显示了问题的关键: >>> bool(NotImplemented) True 我的问题如下: 为什么决定 NotImplem
如果我有两个对象 A 和 B,我可以为 A 的 返回 NotImplemented >__iadd__ 方法,并让 B 使用它的 __radd__ 方法修改 A。 >>> class A(): ...
我尝试在 sympy 中求解 4 个微分方程组。我收到“NotImplementedError”。有解决办法吗? 我试图解决的颂歌集是: ![ODE]: /image/2U4BR.jpg 我尝试用数值
我正在尝试设置一个端点以将文件上传到 AWS S3 存储桶。我正在使用 Node.JS、Express、AWS S3 SDK 和 Multer 库。 这是我目前用于上传中间件的代码: export c
我是一名优秀的程序员,十分优秀!