檔案數太多砍不掉該怎麼辦

 原贴:http://plog.longwin.com.tw/my_note-unix/2007/01/18/file_most_cant_del_2007

檔案數太多砍不掉該怎麼辦

當檔案數太多, 砍不掉的時後該怎麼辦(錯誤訊息: rm: too many arguments 或 rm: Argument list too long)

  1. 先轉成 file owner 的身份去下指令(不然就轉成 root 吧!)
  2.  ls -l | awk '{print $9}' | xargs rm  # 再來這樣子就可以砍掉
  3.  ls -l *.jpg | awk '{print $9}' | xargs rm # 如果只要砍那目錄下的所有 jpg 檔

簡單的 shell script 就搞定囉 :)

不過使用前請小心確認一下, 最後 xargs rm 先拿掉, 改成 less, 先確定一下是自己要砍的, 再下此指令吧 :)

  • gslin 長輩提供的解法:  find /path -name '*.jpg' -depth 1 -delete
  • jeffhung 長輩提供簡化方法: ls *.jpg | xargs rm
### 回答1: 如果二维结构体数组中层数太多,可以考虑使用动态内存分配来解决问题。动态内存分配可以使数组的维数不受限制,而且可以根据实际需要进行动态调整。以下是一个使用动态内存分配创建二维结构体数组的例子: ``` #include <stdio.h> #include <stdlib.h> typedef struct { int x; int y; } Point; int main() { int rows = 5; // 行数 int cols = 10; // 列数 // 动态分配二维结构体数组 Point **arr = (Point **)malloc(rows * sizeof(Point *)); for (int i = 0; i < rows; i++) { arr[i] = (Point *)malloc(cols * sizeof(Point)); } // 使用二维结构体数组 for (int i = 0; i < rows; i++) { for (int j = 0; j < cols; j++) { arr[i][j].x = i; arr[i][j].y = j; } } // 释放二维结构体数组 for (int i = 0; i < rows; i++) { free(arr[i]); } free(arr); return 0; } ``` 在上面的例子中,我们使用了两次动态内存分配来创建了一个5行10列的二维结构体数组,并对其进行了初始化。使用完毕后,我们需要对其进行释放,以防止内存泄露。 ### 回答2: 在C语言中,二维结构体数组中层数太多可以采取以下几种解决方案: 1. 使用动态内存分配:可以使用malloc函数动态分配内存来创建二维结构体数组。这样可以根据需要来动态调整数组的大小,避免层数过多的问题。示例代码如下: ```c typedef struct { // 定义结构体成员 } MyStruct; int main() { int rows = 10; // 行数 int cols = 10; // 列数 MyStruct** array = (MyStruct**)malloc(rows * sizeof(MyStruct*)); for (int i = 0; i < rows; i++) { array[i] = (MyStruct*)malloc(cols * sizeof(MyStruct)); } // 使用二维结构体数组 // 释放内存 for (int i = 0; i < rows; i++) { free(array[i]); } free(array); return 0; } ``` 2. 使用一维结构体数组和索引计算:如果数组的维度过多,可以将多维结构体数组转换为一维结构体数组,并通过索引计算来获取对应的元素。示例代码如下: ```c typedef struct { // 定义结构体成员 } MyStruct; int main() { int rows = 10; // 行数 int cols = 10; // 列数 MyStruct* array = (MyStruct*)malloc(rows * cols * sizeof(MyStruct)); // 使用一维结构体数组 int index = 3 * cols + 2; // 计算二维数组的索引 MyStruct element = array[index]; // 释放内存 free(array); return 0; } ``` 通过以上两种方法,可以避免二维结构体数组中层数太多的问题,并灵活地使用数组元素。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值