如果你正在创建一个1d数组,你可以将它实现为一个列表,或者使用标准库中的'array'模块。我一直用链表来表示一维数组。
我想要使用数组模块的原因或情况是什么?
它是为了性能和内存优化,还是我遗漏了一些明显的东西?
如果你正在创建一个1d数组,你可以将它实现为一个列表,或者使用标准库中的'array'模块。我一直用链表来表示一维数组。
我想要使用数组模块的原因或情况是什么?
它是为了性能和内存优化,还是我遗漏了一些明显的东西?
当前回答
Basically, Python lists are very flexible and can hold completely heterogeneous, arbitrary data, and they can be appended to very efficiently, in amortized constant time. If you need to shrink and grow your list time-efficiently and without hassle, they are the way to go. But they use a lot more space than C arrays, in part because each item in the list requires the construction of an individual Python object, even for data that could be represented with simple C types (e.g. float or uint64_t).
数组。另一方面,数组类型只是C数组的精简包装。它只能保存同构数据(也就是说,所有的数据类型都是相同的),因此它只使用sizeof(一个对象)* length字节的内存。通常,当需要将C数组公开给扩展或系统调用(例如,ioctl或ftnl)时,应该使用它。
数组中。array也是Python 2中表示可变字符串的合理方式。x(数组('B',字节))。然而,Python 2.6+和3。X提供了一个可变字节字符串bytearray。
但是,如果您想在数值数据的齐次数组上进行数学运算,那么最好使用NumPy,它可以自动向量化复杂多维数组上的操作。
长话短说:数组。当你出于数学以外的原因需要一个同构C数据数组时,数组是很有用的。
其他回答
我的理解是数组更有效地存储(例如,作为连续的内存块与指向Python对象的指针相比),但我不知道有任何性能上的好处。此外,使用数组必须存储相同类型的原语,而列表可以存储任何类型的原语。
数组模块是一种如果你不知道为什么要使用它,你可能不需要的东西(请注意,我并不是试图以一种居高居高下的方式说!)。大多数情况下,数组模块用于与C代码进行交互。为了更直接地回答你关于性能的问题:
在某些用途上,数组比列表更有效。如果你需要分配一个你知道不会改变的数组,那么数组可以更快,使用更少的内存。GvR有一个优化的轶事,其中数组模块是赢家(长读,但值得一读)。
另一方面,列表比数组占用更多内存的部分原因是,当所有分配的元素都被使用时,python会分配一些额外的元素。这意味着向列表中添加项更快。所以,如果你打算添加项目,列表是最好的方法。
我只会在有特殊的优化需求或者需要与C代码交互(不能使用pyrex)时使用数组。
如果要使用数组,请考虑numpy或scipy包,它们为数组提供了更大的灵活性。
标准库数组对于二进制I/O非常有用,例如将整型数组转换为要写入wave文件的字符串。也就是说,正如许多人已经注意到的,如果你要做任何实际工作,那么你应该考虑使用NumPy。
这个答案将总结几乎所有关于何时使用List和Array的查询:
The main difference between these two data types is the operations you can perform on them. For example, you can divide an array by 3 and it will divide each element of array by 3. Same can not be done with the list. The list is the part of python's syntax so it doesn't need to be declared whereas you have to declare the array before using it. You can store values of different data-types in a list (heterogeneous), whereas in Array you can only store values of only the same data-type (homogeneous). Arrays being rich in functionalities and fast, it is widely used for arithmetic operations and for storing a large amount of data - compared to list. Arrays take less memory compared to lists.