LabVIEW strings are not null-terminated C-style strings. LabVIEW strings are similar to Pascal-style strings in the sense that the first four bytes contain the length of the string.
There are two ways to take a LabVIEW string and pass it to a DLL that is expecting a char * (pointer to character array). The most common method is to define the function parameter as a
CStr. When you place a Call Library Function Node on the block diagram, double-click it to specify the prototype of the function you want to call. Here you will specify the parameter to be type
String and the format to be
C String Pointer. Notice how the prototype displays the data type
CStr. This data type is equivalent to
char *.
data:image/s3,"s3://crabby-images/9d4a4/9d4a403ec22435839d374d325c047d8f92d79dbd" alt=""
data:image/s3,"s3://crabby-images/cf7a4/cf7a41ab1bc137b7b20412d7e1978866a112a780" alt=""
If you are working with string-based instrument control, it may be easier to pass an array of 8-bit integers than C strings because of the possibility of NULL values in the string. When you place a Call Library Function Node, double-click it to specify the prototype of the function you want to call. The key here is to specify the parameter type as
Array and its data type as
Unsigned 8-bit Integer. The dimension of the array is
1 and the format is
Array Data Pointer. In LabVIEW you must convert the string to a byte array using the
String to Byte Array.vi.data:image/s3,"s3://crabby-images/1d120/1d120526da36696d9f5b98f51c3fcd02bb2d549a" alt=""