포인터 및 동적 메모리 할당: 포인터는 다른 메모리 블록의 주소를 저장하는 데 사용되는 프로그래밍 언어의 기능입니다. 포인터를 사용하면 런타임 시 필요에 따라 필요한 메모리를 할당할 수 있습니다. malloc() 또는 new와 같은 할당자 함수를 사용하여 포인터 변수에 메모리 주소를 저장합니다. 실제 사례: 포인터를 사용하여 텍스트 파일에서 읽은 학생 성적을 저장하기 위한 배열을 동적으로 할당합니다.
포인터 및 동적 메모리 할당
포인터는 다른 메모리 부분을 가리키는 주소를 저장하는 프로그래밍 언어 기능입니다. 포인터를 사용하면 런타임에 필요에 따라 메모리를 할당하는 동적 메모리 할당을 달성할 수 있습니다.
Principle
포인터 변수가 생성되면 아직 할당되지 않은 메모리 영역을 가리킵니다. 메모리를 할당하려면 malloc()
또는 new
와 같은 할당자 함수를 사용해야 합니다. 할당자 함수는 지정된 크기의 새 메모리 블록의 주소를 반환하고 이를 포인터 변수에 저장합니다. malloc()
或 new
之类的分配器函数。分配器函数返回一块具有指定大小的新内存块的地址,并将其存储在指针变量中。
语法
C/C++
int *ptr; // 声明一个指向 int 型变量的指针 ptr = (int *) malloc(sizeof(int)); // 分配 sizeof(int) 大小的内存并存储地址到 ptr
Java
int[] arr; // 声明一个指向 int 型数组的指针 arr = new int[10]; // 分配大小为 10 的数组并存储地址到 arr
实战案例
假设我们有一个包含学生成绩的文本文件 grades.txt
Syntax
C/C++
#include <iostream> #include <fstream> using namespace std; int main() { ifstream file("grades.txt"); int numStudents; file >> numStudents; // 分配一个具有 numStudents 个元素的数组 int *grades = new int[numStudents]; // 读取文件并存储成绩 for (int i = 0; i < numStudents; i++) { file >> grades[i]; } // 打印成绩 for (int i = 0; i < numStudents; i++) { cout << grades[i] << " "; } cout << endl; // 释放动态分配的内存 delete[] grades; return 0; }🎜Java🎜🎜
import java.io.File; import java.io.IOException; import java.nio.file.Files; import java.nio.file.Paths; public class Main { public static void main(String[] args) throws IOException { File file = new File("grades.txt"); int numStudents = Integer.parseInt(Files.readAllLines(Paths.get(file.getPath())).get(0)); // 分配一个具有 numStudents 个元素的数组 int[] grades = new int[numStudents]; // 读取文件并存储成绩 for (int i = 0; i < numStudents; i++) { grades[i] = Integer.parseInt(Files.readAllLines(Paths.get(file.getPath())).get(i + 1)); } // 打印成绩 for (int i = 0; i < numStudents; i++) { System.out.print(grades[i] + " "); } System.out.println(); } }🎜🎜실용 사례🎜🎜🎜학생 성적이 포함된 텍스트 파일
grades.txt
가 있다고 가정합니다. 우리는 이 파일을 읽고 동적으로 할당된 배열에 성적을 저장하는 프로그램을 만들 것입니다. 🎜🎜🎜C++ 코드🎜🎜rrreee🎜🎜Java 코드🎜🎜rrreee위 내용은 포인터는 동적 메모리 할당을 어떻게 구현합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!