Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cython
Commits
af6e2058
Commit
af6e2058
authored
Jan 26, 2014
by
Stefan Behnel
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
clarify memory view section in string processing docs
parent
800bbe49
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
13 additions
and
11 deletions
+13
-11
docs/src/tutorial/strings.rst
docs/src/tutorial/strings.rst
+13
-11
No files found.
docs/src/tutorial/strings.rst
View file @
af6e2058
...
@@ -193,20 +193,22 @@ good idea to instead receive a 1-dimensional memory view, e.g.
...
@@ -193,20 +193,22 @@ good idea to instead receive a 1-dimensional memory view, e.g.
def process_byte_data(unsigned char[:] data):
def process_byte_data(unsigned char[:] data):
length = data.shape[0]
length = data.shape[0]
first_byte = data[0]
first_byte = data[0]
byte_slice
= data[1:-1]
slice_view
= data[1:-1]
...
...
Cython's memory views are described in more detail in
Cython's memory views are described in more detail in
:doc:`../userguide/memoryviews`,
:doc:`../userguide/memoryviews`, but the above example already shows
but the above example already shows most of the relevant functionality
most of the relevant functionality for 1-dimensional byte views. They
for 1-dimensional byte views. They allow for efficient processing of
allow for efficient processing of arrays and accept anything that can
arrays and accept anything that can unpack itself into a byte buffer,
unpack itself into a byte buffer, without intermediate copying. The
without intermediate copying. The processed content can finally be
processed content can finally be returned in the memory view itself
returned in the memory view itself (or a slice of it), but it is
(or a slice of it), but it is often better to copy the data back into
often better to copy the data back into a :obj:`bytes` or :obj:`bytearray`
a flat and simple :obj:`bytes` or :obj:`bytearray` object, especially
object, especially when only a small slice is returned (as the memoryview
when only a small slice is returned. Since memoryviews do not copy the
would otherwise keep the entire original buffer alive). This can simply
data, they would otherwise keep the entire original buffer alive. The
be done as follows::
general idea here is to be liberal with input by accepting any kind of
byte buffer, but strict with output by returning a simple, well adapted
object. This can simply be done as follows::
def process_byte_data(unsigned char[:] data):
def process_byte_data(unsigned char[:] data):
# ... process the data
# ... process the data
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment