gpt4 book ai didi

perl - Perl Inline::C:是否需要Inline_Stack_Vars等以避免内存泄漏(生物序列字符匹配)

转载 作者:行者123 更新时间:2023-12-02 22:43:30 24 4
gpt4 key购买 nike

我的问题与内联C代码的工作有关:是否需要使用内联堆栈函数(Inline_Stack_Vars)传入和传出变量,或者在这种情况下仅就地修改变量是否合适?

为了显示生物序列数据,我只需要显示两个对齐的字符串之间的差异即可。例如给定这两个字符串:

    ATCAGAAA--GACATGGGCCAAAGATTAA-CAGTGGCCATTGACAGGA--
--CCCCAACTGACAGGGGGCAAAGATTAA-CAGTGGCCATTG---GGA--


我想得到这个(第二个字符串中的匹配字符替换为“。”。

    --.CCC..CT....G...G..........-............---...--


我有很多序列(数百万个Illumina读取),因此已将inline :: c用于字符匹配。以下内联代码似乎可以正常工作(将第二个参数更改为适当的add_matchchars函数):

#!/usr/bin/perl
use Inline C;

my($seq1,$seq2) = qw/ ATCAGAAA--GACATGGGCCAAAGATTAA-CAGTGGCCATTGACAGGA--
--CCCCAACTGACAGGGGGCAAAGATTAA-CAGTGGCCATTG---GGA-- /;

print $seq1,"\n";
print $seq2,"\n";
add_matchchars($seq1,$seq2);
print $seq2,"\n";

__END__

__C__

void add_matchchars(char *seq1, char *seq2) {
int seq1char;
int seq2char;
while(seq1char = *seq1++ , seq2char = *seq2++) {
if (seq1char == seq2char) {
*seq2--;
if (seq1char != '-') {
*seq2 = '.';
}
*seq2++;
}
//printf("%c-%c\n",seq1char,seq2char);
}
// printf("%s\n%s\n",seq1,seq2);
}


但是1)它是否合理有效(是否有更聪明/更好的方法)? 2)会泄漏内存吗?

最佳答案

您不应依赖标量的char *是可修改的,甚至不应依赖于标量的原始缓冲区。而是返回一个新字符串。

Inline_Stack_Vars宏仅在处理可变数量的参数或多个返回值时有用。这里也不是。

您的代码当前没有内存泄漏(您没有在C函数内分配任何内存),但是有一些问题,包括。样式,可能的段错误(正确的while(seq1char = *seq1++ , seq2char = *seq2++)while((seq1char = *seq1++) && (seq2char = *seq2++))以及Perl字符串在字符串内可能包含NUL的事实)。

我认为通常让您的C函数直接采用标量是一个更好的主意。大致:

SV *add_matchchars(SV *seq1_sv, SV *seq2_sv) {
STRLEN len1, len2;
char *seq1 = SvPVbyte(seq1_sv, len1);
char *seq2 = SvPVbyte(seq2_sv, len2);
STRLEN min_len = len1 < len2 ? len1 : len2;
SV *seq3_sv = newSVpvn(seq2, min_len);
char *seq3;
STRLEN i;

seq3 = SvPVX(seq3_sv);
for (i = 0; i < min_len; ++i) {
if (seq1[i] == seq2[i])
seq3[i] = '.';
}

return seq3_sv;
}

关于perl - Perl Inline::C:是否需要Inline_Stack_Vars等以避免内存泄漏(生物序列字符匹配),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22919103/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com