<!--
{
  "availability" : [
    "iOS: 8.0.0 -",
    "iPadOS: 8.0.0 -",
    "macCatalyst: 13.0.0 -",
    "macOS: 10.10.0 -",
    "tvOS: 9.0.0 -",
    "visionOS: 1.0.0 -",
    "watchOS: 2.0.0 -"
  ],
  "documentType" : "symbol",
  "framework" : "Swift",
  "identifier" : "/documentation/Swift/String/withCString(_:)",
  "metadataVersion" : "0.1.0",
  "role" : "Instance Method",
  "symbol" : {
    "kind" : "Instance Method",
    "modules" : [
      "Swift"
    ],
    "preciseIdentifier" : "s:SS11withCStringyxxSPys4Int8VGKXEKlF"
  },
  "title" : "withCString(_:)"
}
-->

# withCString(_:)

Calls the given closure with a pointer to the contents of the string,
represented as a null-terminated sequence of UTF-8 code units.

```
func withCString<Result>(_ body: (UnsafePointer<Int8>) throws -> Result) rethrows -> Result
```

## Parameters

`body`

A closure with a pointer parameter that points to a
null-terminated sequence of UTF-8 code units. If `body` has a return
value, that value is also used as the return value for the
`withCString(_:)` method. The pointer argument is valid only for the
duration of the method’s execution.

## Return Value

The return value, if any, of the `body` closure parameter.

## Discussion

The pointer passed as an argument to `body` is valid only during the
execution of `withCString(_:)`. Do not store or return the pointer for
later use.

---

Copyright &copy; 2026 Apple Inc. All rights reserved. | [Terms of Use](https://www.apple.com/legal/internet-services/terms/site.html) | [Privacy Policy](https://www.apple.com/privacy/privacy-policy)
