回答編集履歴

2

文言

2021/07/07 07:09

投稿

int32_t
int32_t

スコア21695

test CHANGED
@@ -1,4 +1,4 @@
1
- **文字列リテラルだけ**を返すのなら、関数 `str` のように単純に`return`して大丈夫です。(返り値の型は `const char*` がいいだろうとか `str` の後に`(void)`が無いとかの問題はありますが)
1
+ 文字列リテラルだけを返すのなら、関数 `str` のように単純に`return`して大丈夫です。(返り値の型は `const char*` がいいだろうとか `str` の後に`(void)`が無いとかの問題はありますが)
2
2
 
3
3
 
4
4
 
@@ -10,7 +10,7 @@
10
10
 
11
11
  * `strdup()` のように、`malloc()`した領域を返して呼び出し側で `free()` してもらう
12
12
 
13
- * スレッドセーフである必要がないのであれば、グローバルバッファ関数 static なバッファに文字列を格納してそのアドレスを返す。
13
+ * スレッドセーフである必要がないのであれば、大域変数配列や static な局所変数の配列に文字列を格納してそのアドレスを返す。
14
14
 
15
15
 
16
16
 

1

いろいろ

2021/07/07 07:09

投稿

int32_t
int32_t

スコア21695

test CHANGED
@@ -1,4 +1,26 @@
1
- 文字列リテラルだけを返すのなら、関数 `str()` のように単純に`return`して大丈夫です。(返り値の型は `const char*` がいいだろうとか `str` の後に`(void)`が無いとかの問題はありますが)
1
+ **文字列リテラルだけ**を返すのなら、関数 `str` のように単純に`return`して大丈夫です。(返り値の型は `const char*` がいいだろうとか `str` の後に`(void)`が無いとかの問題はありますが)
2
+
3
+
4
+
5
+ 文字列リテラルではない文字列を返すなら、一般的には `snprintf()` や `strcpy_s()` のように結果を入れるバッファとバッファのサイズを引数として渡します。
6
+
7
+
8
+
9
+ 引数で指定できない場合は、
10
+
11
+ * `strdup()` のように、`malloc()`した領域を返して呼び出し側で `free()` してもらう
12
+
13
+ * スレッドセーフである必要がないのであれば、グローバルのバッファや関数 static なバッファに文字列を格納してそのアドレスを返す。
14
+
15
+
16
+
17
+ などが考えられます。
18
+
19
+
20
+
21
+ ----
22
+
23
+
2
24
 
3
25
 
4
26