使用 R 的 C API 函数可能有一种更惯用的方法来做到这一点——我倾向于通过 Rcpp 坚持使用 C++,因为它更安全、更简洁——但添加以下内容应该可以:
SEXP n = PROTECT(Rf_allocVector(STRSXP, 2));
prtCnt++;
SET_STRING_ELT(n, 0, Rf_mkChar("a"));
SET_STRING_ELT(n, 1, Rf_mkChar("b"));
Rf_setAttrib(OS, R_NamesSymbol, n);
但是,我强烈建议使用 Rcpp,因为您可以消除 R 的 C 函数附带的大部分样板。这里有两种选择,以及原始函数的修改版本:
#include <Rcpp.h>
// [[Rcpp::export]]
SEXP do_bla() {
int prtCnt = 0;
SEXP a = PROTECT(Rf_allocMatrix(REALSXP, 5, 5));
prtCnt++;
SEXP b = PROTECT(Rf_allocVector(REALSXP, 5));
prtCnt++;
SEXP OS = PROTECT(Rf_allocVector(VECSXP, 2));
prtCnt++;
SET_VECTOR_ELT(OS, 0, a);
SET_VECTOR_ELT(OS, 1, b);
SEXP n = PROTECT(Rf_allocVector(STRSXP, 2));
prtCnt++;
SET_STRING_ELT(n, 0, Rf_mkChar("a"));
SET_STRING_ELT(n, 1, Rf_mkChar("b"));
Rf_setAttrib(OS, R_NamesSymbol, n);
UNPROTECT(prtCnt);
return OS;
}
// [[Rcpp::export]]
SEXP do_bla2() {
return Rcpp::List::create(
Rcpp::Named("a") = Rcpp::NumericMatrix(5, 5),
Rcpp::Named("b") = Rcpp::NumericVector(5));
}
// [[Rcpp::export]]
SEXP do_bla3() {
Rcpp::NumericMatrix m(5, 5);
Rcpp::NumericVector v(5);
Rcpp::List res = Rcpp::List::create(m, v);
res.names() = Rcpp::CharacterVector::create("a", "b");
return res;
}
如果您直接使用,您可能需要使用mkChar
andsetAttrib
而不是Rf_mkChar
and 。Rf_setAttrib
<Rinternals.h>
do_bla()
# $a
# [,1] [,2] [,3] [,4] [,5]
# [1,] 2.371515e-322 4.743030e-322 9.654277e-315 8.695555e-322 6.518868e-310
# [2,] 2.794759e-316 2.371515e-322 6.763004e-317 2.371515e-322 6.952759e-310
# [3,] 3.458460e-323 2.797257e-316 1.630417e-322 2.852530e-316 1.630417e-322
# [4,] 6.441834e+170 1.976263e-323 4.092581e-316 1.976263e-323 4.125824e-316
# [5,] 1.818440e-306 6.952931e-310 4.008825e-316 2.121996e-314 2.154669e-316
#
# $b
# [1] 2.144130e-316 2.168146e-316 3.468674e-316 2.155101e-316 2.172224e-316
#
do_bla2()
# $a
# [,1] [,2] [,3] [,4] [,5]
# [1,] 0 0 0 0 0
# [2,] 0 0 0 0 0
# [3,] 0 0 0 0 0
# [4,] 0 0 0 0 0
# [5,] 0 0 0 0 0
#
# $b
#[1] 0 0 0 0 0
do_bla3()
# $a
# [,1] [,2] [,3] [,4] [,5]
# [1,] 0 0 0 0 0
# [2,] 0 0 0 0 0
# [3,] 0 0 0 0 0
# [4,] 0 0 0 0 0
# [5,] 0 0 0 0 0
#
# $b
#[1] 0 0 0 0 0